* {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.fl {
	float: left;
}

.fr {
	float: right;
}

.fn {
	float: none;
}

.df {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

body {
	font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size: 15px;
	line-height: 30px;
	min-width: inherit;
	min-height: inherit;
	max-height: 100%;
	letter-spacing: 1.5px;
	color: #000;
	background: url('../img/index/pat1.jpg');
}

.nav--opened {
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
}

.nav--opened #pagetop {
	z-index: -1;
}

body.nav--opened,
body.nav--opened *,
body.nav--opened *:hover,
body.nav--opened *:focus,
body.nav--opened *:active {
	pointer-events: none !important;
	-ms-touch-action: none !important;
	touch-action: none !important;
}

body.nav--opened .hamburger,
body.nav--opened #menu_toggle,
body.nav--opened #menu_toggle * {
	pointer-events: visible !important;
	-ms-touch-action: auto !important;
	touch-action: auto !important;
}

body.iphone .bg-parallax {
	background-attachment: inherit !important;
}

main {
	position: relative;
	clear: both;
	overflow: hidden;
	width: 100%;
}

.wrap {
	width: 1000px;
}

header {
	position: relative;
	z-index: 2;
}

header h1 {
	font-size:14px;
	position: absolute;
	top:1%;
	left:2%;
	z-index: 999;
}

@media only screen and (max-width:767px) {

header h1 {
	width: 65%;
	line-height:22px;
	}

}


#key {
  color: #fff;
	position: relative;
}
@media only screen and (max-width:767px) {

	#key {
	
	}
	#key .slider-fadeIn div{
		width:150%;
		translate:20px;
		text-align:center;
		position:relative;
		right :15%;
		z-index:0;
	}

}
#key .logo {
	position: absolute;
	z-index: 999;
	top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

#key .bnr {
	position: absolute;
	z-index:999;
	left: 50%;
	bottom: 10%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}


@media only screen and (max-width:1080px) {
	#key {

	}
	#key .logo {
	width: 300px;
    top: 30%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);

	}
	#key .bnr {
    width: 400px;
	position: absolute;
	z-index:999;
	left: 50%;
	bottom: 17%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}
}

@media only screen and (max-width:767px) {

	#key .logo {
	width: 40%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	}
	
	#key .bnr {
    width: 96%;
    bottom: -6%;
}

}


header .tel {
	font-size: 18px;
	margin-top: 31px;
	letter-spacing: 1px;
}
header .tel a:hover{
	text-decoration: none;
}
@media only screen and (max-width:767px) {
	header .tel {
		font-size: 3.8vw;
		line-height: 7vw;
		margin-top: 6%;
	}

}

header .tel strong {
	font-size: 30px;
	font-weight: normal;
}

@media only screen and (max-width:767px) {
	header .tel strong {
		font-size: 6.5vw;
	}

}

header .tel strong:before {
	font-size: 26px;
}

@media only screen and (max-width:767px) {
	header .tel strong:before {
		font-size: 6vw;
	}

}

header .tel small {
	font-size: 13px;
	display: block;
	padding-left: 23px;
	letter-spacing: 1.3px;
}

@media only screen and (max-width:767px) {
	header .tel small {
		font-size: 3vw;
		padding-left: 0;
	}

}

header .time {
	font-size: 19px;
	line-height: 27px;
	width: 468px;
	margin: 10px auto 0;
	padding-top: 19px;
	letter-spacing: 2px;
	border-top: 1px solid #555;
}

@media only screen and (max-width:767px) {
	header .time {
		font-size: 5vw;
		line-height: 7vw;
		width: 92%;
		margin-top: 3%;
		padding-top: 3%;
	}

}

header .time small {
	font-size: 14px;
}

@media only screen and (max-width:767px) {
	header .time small {
		font-size: 3.5vw;
	}

}

@media only screen and (max-width:767px) {
	header .mail-btn {
		padding-bottom: 8%;
	}

}

header .mail-btn a {
	font-size: 17px;
	position: relative;
	display: block;
	width: 333px;
	height: 57px;
	margin: 30px auto 0;
	padding: 15px 0 0 30px;
	-webkit-transition: .3s all ease-in-out;
	transition: .3s all ease-in-out;
	text-align: center;
	letter-spacing: 1.8px;
	border-radius: 10px;
	background-image: url('../img/index/pat3.jpg');
}

@media only screen and (max-width:767px) {
	header .mail-btn a {
		font-size: 4vw;
		width: 80%;
		margin-top: 6%;
	}

}

header .mail-btn a:hover {
	text-decoration: none;
	opacity: .8;
}

header .mail-btn a:before {
	position: absolute;
	top: 19px;
	left: 28px;
	width: 27px;
	height: 21px;
	margin-right: 17px;
	content: '';
	background-image: url('../img/index/mail-ico.png');
	background-repeat: no-repeat;
	background-size: 100%;
}

@media only screen and (max-width:767px) {
	header .mail-btn a:before {
		top: 21px;
		width: 22px;
		height: 17px;
	}

}

header .hd-info {
	position: relative;
	z-index: 2;
	height: 446px;
	margin-top: 93px;
	padding-top: 5px;
	text-align: center;
	background-image: url('../img/index/key-top.png');
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: cover;
}

@media only screen and (max-width:767px) {
	header .hd-info {
		height: auto;
		margin-top: 12%;
	}

}

header .hd-info .txt1 {
	font-size: 33px;
	line-height: 40px;
	letter-spacing: 3.5px;
}

@media only screen and (max-width:767px) {
	header .hd-info .txt1 {
		font-size: 6.5vw;
		line-height: 9vw;
	}

}

header .hd-info .txt1 small {
	font-size: 18px;
	display: block;
	letter-spacing: 2px;
}

@media only screen and (max-width:767px) {
	header .hd-info .txt1 small {
		font-size: 4vw;
	}

}

header nav {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	background-image: url('../img/index/navi_bg.jpg');
	color: #fff;
}

@media only screen and (max-width:980px) {
	header nav {
		bottom: -90px;
	}

}

header nav ul {
	font-size: 19px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 126px;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

@media only screen and (max-width:980px) {
	header nav ul {
		font-size: 16px;
		height: 100px;
	}

}

header nav ul li {
	padding-top: 52px;
}

header nav ul li.home {
	font-size: 95%;
    padding: 8px 20px 8px 30px;
    border: 1px solid rgba(255,255,255,0.3);
    height: 46px;
    margin-top: 41px;
	cursor: pointer;
	background: url("../img/index/btn_icon.png") no-repeat center left 15px;
}

@media only screen and (max-width:980px) {
	header nav ul li {
		padding-top: 35px;
	}
	header nav ul li.home {
    margin-top: 28px;
}

}

header nav ul li a {
	padding-bottom: 3px;
}

header nav ul li a:hover {
	text-decoration: none;
	border-bottom: 2px solid #b5774e;
}
header nav ul li.home a:hover {
	text-decoration: none;
	border-bottom: none;
}
header nav ul li a.active{
	border-bottom: 2px solid #b5774e;
}
header .nav-fixed {
	position: fixed;
	z-index: 102;
	top: 0;
	right: 0;
	left: 0;
	visibility: hidden;
	height: 85px;
	-webkit-transition: opacity .5s ease;
	transition: opacity .5s ease;
	opacity: 0;
	background-image: url('../img/index/navi_bg.jpg');
	color: #fff;
}

header .nav-fixed ul {
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

header .nav-fixed ul li {
	padding-top: 26px;
}

header .nav-fixed ul a {
	font-size: 19px;
	position: relative;
}

header .nav-fixed ul li.home {
	font-size: 95%;
    padding: 8px 20px 8px 30px;
    border: 1px solid rgba(255,255,255,0.3);
    height: 46px;
    margin-top: 19px;
	cursor: pointer;
	background: url("../img/index/btn_icon.png") no-repeat center left 15px;
}

header .nav-fixed ul li.home a:hover {
	text-decoration: none;
	border-bottom: none;
}

@media only screen and (max-width:980px) {
	header .nav-fixed ul a {
		font-size: 16px;
	}

}

header .nav-fixed ul a:hover {
	text-decoration: none;
	border-bottom: 2px solid #b5774e;
}
header .nav-fixed ul .active a{
	border-bottom: 2px solid #b5774e;
}
header .nav-fixed.fixed {
	visibility: visible;
	opacity: 1;
}

header .menu_toggle {
	position: fixed;
	z-index: 99;
	top: 0;
	right: 0;
	left: 0;
	visibility: hidden;
	height: 100vh;
	-webkit-transition: all .5s ease 0s;
	-moz-transition: all .5s ease 0s;
	transition: all .5s ease 0s;
	opacity: 0;
	color: #fff;
	background: #000;
}

header .menu_toggle ul {
	padding: 65px 0;
	text-align: center;
}

header .menu_toggle ul li {
	padding: 17px 0;
}

header .menu_toggle a {
	font-size: 16px;
	font-weight: normal;
	position: relative;
	padding-bottom: 5px;
	text-align: center;
	letter-spacing: 2px;
	color: #fff;
}

header .menu_toggle .active a {
	border-bottom: 1px solid #fff;
}

header #menu_toggle li {
	-webkit-transition-duration: .6s;
	transition-duration: .6s;
	-webkit-transform: translateX(100px);
	transform: translateX(100px);
	opacity: 0;
}

header #menu_toggle li.active::before {
	bottom: 13px;
	width: 111px;
	border-bottom: 1px solid #000;
}

header .hamburger {
	position: fixed;
	z-index: 9999;
	top: 10px;
	right: 0;
	-webkit-transition: .3s all ease-in-out;
	transition: .3s all ease-in-out;
	background: #000;
}

header .hamburger:hover {
	opacity: 1;
}

header .hamburger:after {
	font-size: 11px;
	font-weight: 600;
	position: absolute;
	top: 50%;
	left: 8px;
	content: 'MENU';
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	text-align: left;
	letter-spacing: 1px;
	color: #fff;
}

header .hamburger.is-active:hover {
	opacity: 1;
}

.nav--opened header #menu_toggle {
	z-index: 999;
	visibility: visible;
	overflow-y: scroll;
	pointer-events: visible;
	opacity: 1;
}

.nav--opened header #menu_toggle li {
	-webkit-transform: translateX(0);
	transform: translateX(0);
	opacity: 1;
}

.nav--opened header #menu_toggle li:nth-child(1) {
	-webkit-transition-delay: .15s;
	transition-delay: .15s;
}

.nav--opened header #menu_toggle li:nth-child(2) {
	-webkit-transition-delay: .20s;
	transition-delay: .20s;
}

.nav--opened header #menu_toggle li:nth-child(3) {
	-webkit-transition-delay: .25s;
	transition-delay: .25s;
}

.nav--opened header #menu_toggle li:nth-child(4) {
	-webkit-transition-delay: .30s;
	transition-delay: .30s;
}

.nav--opened header #menu_toggle li:nth-child(5) {
	-webkit-transition-delay: .35s;
	transition-delay: .35s;
}

.nav--opened header #menu_toggle li:nth-child(6) {
	-webkit-transition-delay: .40s;
	transition-delay: .40s;
}

.nav--opened .hamburger:after {
	content: 'CLOSE';
}





@media only screen and (max-width:980px) {
	section {
		margin-top: 100px;
	}

}

@media only screen and (max-width:767px) {
	section {
		margin-top: 0;
	}

}

footer .df{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

@media only screen and (max-width:767px) {
	footer .df{
		display: block;
	}

}

footer .ggmap {
	width: 50%;
	position:relative;
}

@media only screen and (max-width:767px) {
	footer .ggmap {
		width: 100%;
		height: 480px;
	}

}

footer .ggmap iframe {
	width: 100%;
	height: 100%;
	top:0;
	left:0;
    position: absolute;
}

footer .ft-info {
	width: 50%;
	padding-bottom: 80px;
	color: #fff;
	background: #000;
}

@media only screen and (max-width:767px) {
	footer .ft-info {
		width: 100%;
	}

}

footer .ft-info h2 {
	font-size: 35px;
	line-height: 52px;
	padding-top: 82px;
	text-align: center;
	letter-spacing: 3px;
}

@media only screen and (max-width:767px) {
	footer .ft-info h2 {
		font-size: 6vw;
		line-height: 9vw;
		padding-top: 13%;
	}

}

footer .ft-info h2 small {
	font-size: 22px;
	display: block;
	letter-spacing: 2px;
}

@media only screen and (max-width:767px) {
	footer .ft-info h2 small {
		font-size: 4vw;
	}

}

footer .ft-info .vcard {
	line-height: 25px;
	width: 424px;
	margin: 29px auto 0;
}

@media only screen and (max-width:980px) {
	footer .ft-info .vcard {
		width: 100%;
		padding: 0 15px;
	}

}

@media only screen and (max-width:767px) {
	footer .ft-info .vcard {
		font-size: 13px;
		line-height: 22px;
		width: 92%;
		margin-top: 9%;
		padding: 0;
	}

}

footer .ft-info .vcard dl {
	display: table;
	width: 100%;
	margin-bottom: 12px;
	padding-bottom: 12px;
	border-bottom: 1px dashed #5c5c5c;
}

@media only screen and (max-width:767px) {
	footer .ft-info .vcard dl {
		display: block;
		margin-bottom: 10px;
		padding-bottom: 10px;
	}

}

footer .ft-info .vcard dl dt {
	display: table-cell;
	width: 139px;
	padding-left: 24px;
}

@media only screen and (max-width:980px) {
	footer .ft-info .vcard dl dt {
		width: 90px;
		padding-left: 0;
	}

}

@media only screen and (max-width:767px) {
	footer .ft-info .vcard dl dt {
		display: block;
		width: 100%;
		padding-left: 0;
	}

}

footer .ft-info .vcard dl dd {
	display: table-cell;
}

@media only screen and (max-width:767px) {
	footer .ft-info .vcard dl dd {
		display: block;
	}

}

footer .btn-group {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin-top: 37px;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

@media only screen and (max-width:980px) {
	footer .btn-group {
		display: block;
		text-align: center;
	}

}

@media only screen and (max-width:767px) {
	footer .btn-group {
		margin-top: 7%;
	}

}

footer .btn-group .btn-left {
	margin-right: 25px;
}

@media only screen and (max-width:980px) {
	footer .btn-group .btn-left {
		margin-right: 0;
		margin-bottom: 10px;
	}

}

@media only screen and (max-width:767px) {
	footer .btn-group .btn-left {
		display: none;
	}

}

footer .btn-group .btn-left .print {
	margin-top: 5px;
	text-align: right;
}

@media only screen and (max-width:980px) {
	footer .btn-group .btn-left .print {
		text-align: center;
	}

}

footer .btn-group .btn-left .print a {
	font-size: 12px;
	color: #797979;
}

@media only screen and (max-width:767px) {
	footer .btn-group .btn-right {
		width: 220px;
		margin: 0 auto;
	}

}

footer .ft-btn a {
	font-size: 20px;
	position: relative;
	display: block;
	width: 364px;
	height: 66px;
	margin: 25px auto 0;
	padding: 20px 0 0 48px;
	-webkit-transition: .3s all ease-in-out;
	transition: .3s all ease-in-out;
	text-align: center;
	letter-spacing: 1.8px;
	color: #000;
	border-radius: 10px;
	background-image: url('../img/index/pat3.jpg');
}

@media only screen and (max-width:980px) {
	footer .ft-btn a {
		width: 90%;
	}

}

@media only screen and (max-width:767px) {
	footer .ft-btn a {
		font-size: 4vw;
		width: 80%;
		height: 55px;
		margin-top: 9%;
		padding: 14px 0 0 35px;
	}

}

footer .ft-btn a:hover {
	text-decoration: none;
	opacity: .8;
}

footer .ft-btn a:before {
	position: absolute;
	top: 18px;
	left: 39px;
	width: 32px;
	height: 32px;
	margin-right: 17px;
	content: '';
	background-image: url('../img/index/post-ico.png');
	background-repeat: no-repeat;
	background-size: 100%;
}

@media only screen and (max-width:767px) {
	footer .ft-btn a:before {
		top: 15px;
		width: 25px;
		height: 25px;
	}

}

footer #socialbuttons {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin-top: 57px;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

@media only screen and (max-width:980px) {
	footer #socialbuttons {
		margin-top: 30px;
	}

}

@media only screen and (max-width:767px) {
	footer #socialbuttons {
		margin-top: 13%;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
	}

}

footer #socialbuttons > div {
	height: 20px;
	margin: 0 2px;
}

footer .social-google {
	display: none;
}

.ft-add {
	margin-top: 28px;
}

@media only screen and (max-width:767px) {
	.ft-add {
		margin-top: 5%;
	}

}

address {
	font-size: 15px;
}

@media only screen and (max-width:767px) {
	address {
		font-size: 14px;
		letter-spacing: .5px;
	}

}

.cookie {
	text-align: center;
}

.cookie a {
	font-size: 13px;
	text-decoration: underline;
}

@media only screen and (max-width:767px) {
	.cookie a {
		font-size: 11px;
		letter-spacing: 1px;
		letter-spacing: .5px;
	}

}

.cookie a:hover {
	text-decoration: none;
}

.ft_fixed_shared {
	position: fixed;
	z-index: 100;
	right: 0;
	bottom: 0;
	left: 0;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	visibility: hidden;
	width: 100%;
	padding: 10px 0;
	text-align: center;
	opacity: 0;
	color: #fff;
	background: #000;
}

.ft_fixed_shared li {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
}

.ft_fixed_shared li + li {
	border-left: 1px solid #666;
}

.ft_fixed_shared li a {
	font-weight: normal;
	font-weight: 500;
	position: relative;
	display: block;
	padding: 5px 0;
	letter-spacing: 1px;
}

.ft_fixed_shared li:first-child a {
	font-size: 4vw;
}

.ft_fixed_shared li:first-child a:before {
	font-size: 4vw;
	margin-right: 2%;
}

.ft_fixed_shared li:last-child a {
	font-size: 3.3vw;
}

.ft_fixed_shared li:last-child a:before {
	font-size: 3.5vw;
	margin-right: 2%;
}

.navOpen .ft_fixed_shared {
	z-index: 0;
}

.has_nav .ft_fixed_shared {
	visibility: visible;
	opacity: 1;
}

@media only screen and (max-width:980px) {
	#pagetop {
		width: 60px;
	}

}

@media only screen and (max-width:767px) {
	#pagetop {
		right: 0;
		bottom: 60px;
		width: 45px;
	}
	header .nav-fixed{
		height: 0;
	}

}

.sp {
	display: block;
}
.sp2 {
	display: none;
}

.slick-dots {
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.slick-dots li {
	line-height: 0;
	width: 15px;
	height: 15px;
	margin: 0 9px;
}

.slick-dots li button {
	font-size: 0;
	width: 15px;
	height: 15px;
	cursor: pointer;
	border: none;
	border: 1px solid #000;
	border-radius: 50%;
	background: transparent;
}

.slick-dots li.slick-active button {
	background: #000;
}

@media only screen and (max-width:1080px) {
	html.responsive img {
		width: auto !important;
	}

}

@media only screen and (max-width:980px) {
	html.responsive .wrap {
		padding: 0 3%;
	}

}

@media only screen and (max-width:767px) {
	body {
		font-size: 14px;
		line-height: 28px;
		text-align: justify;
		font-family: 'Noto Serif JP', serif;
	}

	html.responsive img,
	img {
		width: 100% !important;
	}

	.pc {
		display: none;
	}

	.sp {
		display: none;
	}
	.sp2 {
		display: block;
	}

	.slick-dots li {
		width: 10px;
		height: 10px;
		margin: 0 5px;
	}

	.slick-dots li button {
		width: 10px;
		height: 10px;
	}

}

@media only screen and (max-width:480px) {
	html.responsive .wrap {
		padding: 0;
	}

	.p4 {
		padding: 0 4%;
	}

}

@media all and (-ms-high-contrast:none) {
	.btn a img {
		-webkit-transition: opacity 0s ease !important;
		-moz-transition: opacity 0s ease !important;
		transition: opacity 0s ease !important;
	}

}

@-moz-document url-prefix() {
	.txt-vertical .txt-latin {
		position: relative;
		left: 4px;
	}

}

@media only screen and (max-width:767px) {
	html.show-navi {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
	}

}