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

html{font-size: 62.5%;
	padding: 0;
	margin: 0;}

body{ font-family: YuGothic, "Yu Gothic medium", "sans-serif"; padding-top: 120px;
	font-size:1.4rem; letter-spacing: 0.1em; color:#000; position: relative; z-index: 0;
	-webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body:after{ content: ""; width: 100%; height: 180px;
	position: absolute; left: 0; top: 0; z-index: -1;
	background: url("../img/common/bg-marble.png") no-repeat top center/cover ;}

section,article{ margin: 0 auto; }
.content{ width:800px; margin: 0 auto; }

main{display: block;}

a{color: inherit;transition-duration: .3s;}

a:hover{ opacity: .5; }

img{max-width: 100%;}

.sp{display: none;}

.min{ font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif"; font-weight: 400; }

/*
font-family: yu-mincho-pr6, sans-serif;
font-weight: 400;
font-style: normal;
*/


/*  common-------------------------------------*/
.btn a{ display: inline-flex; align-items: center; justify-content: center;
	width: 250px; height: 60px; font-size: 1.8rem; position: relative;
	border-radius: 30px 0 30px 30px; background: #381F06; color: #fff;
	font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif"; font-weight: 400;}

.btn a:after{ content: ""; border: 4px solid; border-color: #fff #fff transparent transparent;
	position: absolute; top: 5px; right: 5px; }

.btn a:hover{ opacity: 1; border-radius: 0; }


/*  header-------------------------------------*/
header .logo{ position: absolute; top: 15px; left: 50px; }
header .eng{ font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif";
	font-size: 1.4rem; color: #B4102E;
	position: absolute; top: 32px; right: 580px; z-index: 10; }
header .eng a{ display: block; }
header .eng a:before{ content: ""; display: block; width: 36px; height: 36px; margin: 0 auto 5px;
	background: url("../img/common/ico-eng.png") no-repeat center/contain; }

header .cv{ font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif";
	display: flex; align-items: center;
	position: fixed; top: 30px; right: 120px; z-index: 90; }
header .cv li:not(:last-child){ margin-right: 10px; }

header .cv a{ display: flex; align-items: center; justify-content: center;
	width: 220px; height: 60px; font-size: 1.8rem; position: relative;
	border-radius: 30px 0 30px 30px;
	background: linear-gradient( -55deg, #969696, #E1E1DC, #969696 ); }
header .cv li:nth-child(1){ color: #614C3F; }

header .cv li:nth-child(1) a:before{ content: ""; width: 20px; height: 20px; margin-right: 5px;
	background: url("../img/common/ico-yoyaku.png") no-repeat center/contain; }
header .cv li:nth-child(2) a:before{ content: ""; width: 20px; height: 20px; margin-right: 5px;
	background: url("../img/common/ico-tel.png") no-repeat center/contain; }

header .cv a:after{ content: ""; border: 4px solid; border-color: #fff #fff transparent transparent;
	position: absolute; top: 5px; right: 5px; }
header .cv a:hover{ opacity: 1; border-radius: 0; }

header .gnav input{ display: none; }
header label{ font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif"; font-size: 1.4rem; color: #614C3F;
	display: flex; flex-direction: column; justify-content: center; align-items: center;
	width: 80px; height: 80px; background: #fff; border-radius: 100px;
	position: fixed; top: 20px; right: 20px; z-index: 90; transition-duration: .3s; }
header label:hover{ opacity: .5; }

header label span:before,
header label span:after{ content: ""; display: block; margin-bottom: 8px;
	width: 30px; height: 2px; background: #614C3F; border-radius: 10px; transition-duration: .3s; }

header .gnav-in{ display: flex;  flex-direction: column; justify-content: center; align-items: center;
	width: 100%; height: 100%; text-align: center; color: #fff;
	background: url("../img/common/bg-dark.jpg") no-repeat center/cover;
	position: fixed; top: 0; left: 0; z-index: 10;
	transition-duration: .3s; visibility: hidden; opacity: 0; }
input#gnav:checked ~ .gnav-in{ visibility: visible; opacity: 1; }

header .gnav-in ul{ display: flex; width: 800px; margin: 50px auto 100px; justify-content: space-between;
	color: #969696; font-size: 1.4rem; letter-spacing: 0.1em; font-weight: bold; position: relative; z-index: 0; }
header .gnav-in li:not(:last-child){ border-right: 1px solid #969696; }
header .gnav-in li a{ padding: 0 8px; font-size: 13px;}
header .gnav-in li:first-child a{ padding-left: 0; }
header .gnav-in li:last-child a{ padding-right: 0; }

header .gnav-in li:nth-last-child(2){ border-right:none; }

header .gnav-in .eng2{ position: absolute; left: 50%; bottom: -90px; transform: translateX(-50%); }
header .gnav-in .eng2 a{ display: flex; justify-content: center; align-items: center; border-radius: 40px;
	width: 170px; height: 40px; color: #fff; border: 1px solid #fff;
	font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif"; }
header .gnav-in .eng2 a:before{ content: ""; display: block; width: 28px; height: 28px; margin-right: 5px;
	background: url("../img/common/ico-eng.png") no-repeat center/contain; }

header .gnav-in p:last-child{ font-size: 1.2rem; line-height: 2.5; }

input#gnav:checked ~ label span:before{ width: 35px; transform: rotate(-30deg) translate(-4px,6px);}
input#gnav:checked ~ label span:after{ width: 35px; transform: rotate(30deg) translate(-1px,-3px);}

.hour-access{ position: relative; }
.hour-access:after{ content: ""; width: 580px; height: 460px; 
	background: url("../img/common/map.png") no-repeat left bottom/contain;
	position: absolute; bottom: 0; right: calc( (50vw - 400px)* -1 ); }
@media screen and (max-width:1159px){ .hour-access:after{ width: 48vw; } }

.hour-access table{ width: 100%; color: #381F06; font-size: 1.6rem; margin-bottom: 15px; }
.hour-access table tr:not(:first-child){ border-bottom: 1px solid #fff; }
.hour-access table th{ background: #fff; vertical-align: middle; padding: 14px 0; width: 20px; }
.hour-access table th:first-child{ text-align: left; border-top-left-radius: 10px;
	padding: 14px 5px 14px 15px; }
.hour-access table th:last-child{ border-top-right-radius: 10px; padding: 14px 5px 14px 0px; }

.hour-access table td{ vertical-align: middle; text-align: center; padding: 14px 0px; }
.hour-access table td:first-child{ text-align: left; padding: 14px 5px 14px 15px; }
.hour-access table .small{ font-size: 1rem; line-height: 1; padding: 0 5px; }

.hour-access table + p{ font-feature-settings : "palt"; line-height: 1.7; }

.hour-access .access{ position: relative; margin-top: 60px; }
.hour-access .access .tit{ font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif"; font-weight: 400;
	font-size: 3rem; letter-spacing: 0.1em; color: #381F06; margin-bottom: 15px; }
.hour-access .access .tit:before{ content: ""; display: inline-block; margin-right: 10px;
	width: 50px; height: 50px; border-radius: 50px; vertical-align: -15px;
	background: url("../img/common/ico-access.png") no-repeat center/contain #fff; }
.hour-access .access .tit + p{ line-height: 1.7; margin-bottom: 15px; }

.hour-access .access ul li{ font-weight: bold; line-height: 1.7; }
.hour-access .access ul li:before{ content: "●"; margin-right: 5px; }
.hour-access .access .btn-min{ position: absolute; top: 5px; right: 0; }

.hour-access .access .btn-min a{ display: flex; align-items: center; justify-content: center;
	width: 180px; height: 40px; position: relative;
	font-family: YuMincho, "Yu Mincho", yu-mincho-pr6, "serif"; font-weight: 400;
	border-radius: 30px 0 30px 30px; background: #381F06; color: #fff; }
.hour-access .access .btn-min a:after{ content: ""; border: 4px solid; border-color: #fff #fff transparent transparent;
	position: absolute; top: 5px; right: 5px; }
.hour-access .access .btn-min a:hover{ opacity: 1; border-radius: 0;  }

.footer-info{ padding: 125px 0 120px; }

footer{ overflow: hidden; }
footer .logo-area{ display: flex; align-items: center; justify-content: center; height: 320px;
	border-radius: 0 0 50% 50%/0 0 150px 150px; width: 110%;transform: translateX(-5%);
	background: url("../img/common/webp/footer-img.webp") no-repeat center/cover; position: relative; z-index: 1; }
/*no*/.no-webp footer .logo-area{ background: url("../img/common/footer-img.jpg") no-repeat center/cover; }

footer .link-area{ background: url("../img/common/bg-dark.jpg") no-repeat center/cover;
	padding: 220px 0 120px; color: #fff; position: relative; z-index: 0; margin-top: -120px; }
footer .link-area:after{ content: ""; width: 400px; height: 400px; z-index: -1;
	position: absolute; bottom: 20px; right: 0;
	background: url("../img/common/footer-ill.png") no-repeat center/contain; }

footer .link-area .content{ display: flex; }

footer .link-area .bnr-area{ width: 300px; padding-right: 50px; }
footer .link-area .bnr-area:after{ content: ""; width: calc( 50vw - 100px ); height: 100%; 
	background: rgba(0,0,0,.2);position: absolute; left: 0; top: 0; z-index: -1; }
footer .link-area .bnr-area p:not([class]){ margin-bottom: 5px; }
footer .link-area .bnr-area p:not(:first-child):not([class]){ margin-top: 30px; }

footer .link-area .bnr-area .btn.yoyaku{ margin-bottom: 5px; }
footer .link-area .bnr-area .btn.yoyaku a{ color: #614C3F; }
footer .link-area .bnr-area .btn.tel a{ color: #000; }

footer .link-area .bnr-area .btn.yoyaku a,
footer .link-area .bnr-area .btn.tel a{ background: linear-gradient( -55deg, #969696, #E1E1DC, #969696 ); }

footer .link-area .bnr-area .btn.yoyaku a:before{ content: ""; width: 20px; height: 20px; margin-right: 5px;
	background: url("../img/common/ico-yoyaku.png") no-repeat center/contain; }
footer .link-area .bnr-area .btn.tel a:before{ content: ""; width: 20px; height: 20px; margin-right: 5px;
	background: url("../img/common/ico-tel.png") no-repeat center/contain; }

footer .link-area .bnr-area .btn.jidv-btn a{ background: #64A99F; }
footer .link-area .bnr-area .btn.jidv-btn a:before{ content: ""; display: inline-block; width: 20px; height: 20px; 
	vertical-align: -15px; margin-right: 10px;
	background: url("../img/common/ico-jidv.png") no-repeat center/contain; }

footer .link-area .bnr-area .btn.eng a{ background: #fff; color: #000; }
footer .link-area .bnr-area .btn.eng a:before{ content: ""; display: inline-block; width: 20px; height: 20px; 
	margin-right: 10px; background: url("../img/common/ico-eng.png") no-repeat center/contain; }
footer .link-area .bnr-area .btn.eng a:after{ border-color: #544137 #544137 transparent transparent; }

footer .link-area .sitemap{ padding-left: 50px; }
footer .link-area .sitemap .wrap{ display: flex; justify-content: space-between; margin-bottom: 20px; }

footer .link-area .sitemap .box p,
footer .link-area .sitemap .box2 p{ font-weight: bold; margin-bottom: 10px; }
footer .link-area .sitemap ul li{ font-size: 1rem; line-height: 2; }

footer .link-area .sitemap .box2 > ul > li{ display: flex; }
footer .link-area .sitemap .box2 > ul > li ul:first-child{ margin-right: 50px; }

footer .copy{ border-top: 1px solid #807972; color: #807972; padding-top: 15px; margin-top: 15px; }
footer .copy small{ font-size: 1.2rem; line-height: 1.5; letter-spacing: 0.1em; }

.hour-access > .en_table{
	width: 420px;
}

.hour-access .en_table table th{
	font-size: 12px;
}

.hour-access .en_table table th:first-child{
	font-size: 10px;
}

/*  responsive ------------------------------------------------------------*/
@media screen and (max-width:599px){
	
	.pc{display: none;}
	.sp{display: initial}
	
	body{ padding-top: 75px; }
	
	.btn a{ height: 50px; font-size: 1.4rem; }
	.content{ width: 100%; }
	
	header .logo{ top: 10px; left: 10px; }
	header .logo img{ width: auto; height: 53.5px; }
	
	header .eng{ top: 15px; right: 80px; font-size: 0.9rem; letter-spacing: 0.1em; }
	header .eng a:before{ width: 25px; height: 25px; }
	
	header .cv{ width: 100%; top: auto; bottom: 0; right: 0; padding: 0 10px 5px; }
	header .cv li{ flex-basis: calc( 50% - 5px ); }
	header .cv a{ width: 100%; }
	
	header label{ width: 50px; height: 50px; font-size: 0.9rem; letter-spacing: 0.1em; top: 10px; right: 10px; }
	header label span:before, header label span:after{ width: 20px; height: 1px; margin-bottom: 4px; }
	input#gnav:checked ~ label span:before{ width: 25px; transform: rotate(-25deg) translate(-2px,2px);}
	input#gnav:checked ~ label span:after{ width: 25px; transform: rotate(25deg) translate(-2px,-2px);}

	header .gnav-in{ padding-bottom: 60px; }
	header .gnav-in .logo2 img{ width: 160px; }
	
	header .gnav-in ul{ width: 210px; flex-wrap: wrap; font-size: 1.2rem; margin: 30px auto 50px; }
	header .gnav-in ul li{ flex-basis: 100px; }
	header .gnav-in li:not([class]){ border-bottom: 1px solid #969696; }
	header .gnav-in li:not(:last-child){ border-right: none; }
	header .gnav-in li:not([class]) a{ display: block; padding: 15px 0; }
	
	header .gnav-in .eng2{ position: static; transform: none; padding-top: 15px; }
	header .gnav-in .eng2 a{ width: 100%; height: 30px; font-size: 1rem; }
	header .gnav-in .eng2 a:before{ width: 16px; height: 16px; }
	
	.hour-access > div{ width: 100%; }
	.hour-access table{ font-size: 1.3rem; white-space: nowrap; }
	.hour-access table td:first-child{ padding: 14px 0 14px 15px; }
	.hour-access table .small{ padding: 0; }
	.hour-access .access{ margin-top: 30px; }
	.hour-access .access .tit{ font-size: 2.5rem; }
	.hour-access .access .tit + p{ font-size: 1.2rem; }
	.hour-access .access ul li{ font-size: 1.2rem; }
	.hour-access .access .btn-min{ top: 10px; }
	.hour-access .access .btn-min a{ width: 42vw; height: 30px; font-size: 1.2rem; }
	.hour-access:after{ width: 94vw; height: 75vw; position: static; display: block; margin-top: 20px; }
	.footer-info{ padding: 60px 6vw; }

	footer .logo-area{ border-radius: 0 0 50% 50%/0 0 75px 75px; }
	footer .link-area{ padding: 0; margin-top: -55px; }
	footer .link-area:after{ width: 200px; height: 200px; }
	footer .link-area .content{ display: block; }
	footer .link-area .bnr-area{ width: 100%; text-align: center; position: relative; padding: 120px 0 55px; }
	footer .link-area .bnr-area:after{ width: 100%; }
	
	footer .link-area .sitemap{ padding: 60px 6vw 90px; }
	.hour-access > .en_table{
	width: 100%;
}
	
	.hour-access .en_table table th{
	font-size: 2.8vw;
}

.hour-access .en_table table th:first-child{
	font-size: 2.8vw;
}
	
	
}