*{	
	font-family: 'Noto Sans JP', sans-serif;
	font-feature-settings: "palt";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color: #fff;
	box-sizing: border-box;
	word-break: break-all;
	overflow-wrap: break-word;
	font-size: 14px;
	font-style: normal;
	font-weight: 400;
	line-height: 1.6em;
	letter-spacing: 0.08em;
	text-align: justify;
}

.mincho{ font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif; }
.garamond{ font-family: garamond-premier-pro, serif; font-weight: 400; font-style: normal; }

body{ background: #000; }

a{ transition: .3s; }
a:hover{ opacity: .7; }

br{ line-height: inherit; }

span, a, strong, small{ color: inherit; font-size: inherit; font-family: inherit; font-weight: inherit; letter-spacing: inherit; }

.wrap{ width: 800px; margin: 0 auto; }
.linkwrap{ width: 100%; height: 100%; display: block; position: absolute; top: 0; left: 0; z-index: 10; }
.body-wrap{ overflow: hidden; position: relative; }

.sp{ display: none; }

a.btn.sp {display:none;}

a.btn{ width: 210px; height: 40px; border-radius: 20px; border: solid 1px; display: flex; justify-content: center; align-items: center; font-size: 12px; position: relative; }
a.btn::after{ content: ''; width: 61px; height: 5px; background: url(../images/common/arrow01.png) no-repeat; background-size: contain; position: absolute; top: 50%; right: -30px; transform: translateY(-50%); }

header{ display: flex; justify-content: space-between; align-items: center; width: 1120px; margin: 0 auto; padding-top: 20px; position: absolute; top: 0; left: 50%; transform: translateX(-50%); z-index: 100; }
header > .logo{ display: block; width: 120px; }
header .sns{ display: flex; align-items: center; justify-content: flex-end; margin-bottom: 10px; }
header .sns li{ margin-left: 13px; }
header .sns li a.tel{ font-size: 22px; padding-left: 20px; background: url(../images/common/icon-tel01.png) no-repeat; background-size: 12px; background-position: top 50% left 0; }
header .sns li img{ display: block; width: 20px; }
header .gnav{ display: flex; align-items: center; justify-content: flex-end; }
header .gnav li{ font-size: 11px; text-align: center; padding: 0 1.5em; position: relative; transition: .3s; }
header .gnav li:hover{ opacity: .7; }
header .gnav li:last-of-type{ padding-right: 0; }
header .gnav li:not(:nth-of-type(n+6)):after{ content: ''; width: 5px; height: 5px; border-radius: 5px; background: #fff; position: absolute; top: 50%; transform: translateY(-50%); right: -2.5px; }
header .gnav li span{ display: block; text-align: center; font-size: 18px; }
header .gnav li:last-of-type a{ width: 150px; height: 40px; border: solid 1px; border-radius: 20px; font-size: 12px; display: flex; justify-content: center; align-items: center; padding-left: 1em; background: url(../images/common/icon-contact01.png) no-repeat; background-size: 14px; background-position: top 50% left 20px; }

.contact-box{ padding: 110px 0 130px; background: url(../images/common/bg-contact-box01.jpg) no-repeat; background-size: cover; }
.contact-box .wrap{ width: 660px; }
.contact-box h2{ font-size: 28px; text-align: center; line-height: 1.8; margin-bottom: 40px; }
.contact-box .btn-list{ display: flex; justify-content: space-between; }
.contact-box .btn-list li a{ width: 280px; height: 60px; border-radius: 30px; border: solid 1px; display: flex; justify-content: center; align-items: center; font-size: 18px; }
.contact-box .btn-list li a.mincho{ font-size: 28px; letter-spacing: 0; }
.contact-box .btn-list li a span{ padding-left: 28px; background-repeat: no-repeat; background-position: top 50% left 0; }
.contact-box .btn-list li:nth-of-type(1) a span{ background-image: url(../images/common/icon-tel01.png); background-size: 15px; }
.contact-box .btn-list li:nth-of-type(2) a span{ background-image: url(../images/common/icon-contact01.png); background-size: 18px; }

.gmap{ height: 350px; position: relative; }
.gmap iframe{ width: 100%; height: 100%; position: absolute; top: 0; left: 0; -webkit-filter: grayscale(1); filter: grayscale(1); }

footer{ background: #fff; padding: 115px 0 10px; }
footer *{ color: #000; }
footer .wrap{ width: 900px; display: flex; justify-content: space-between; align-items: flex-end; }
footer .wrap .left{ width: 320px; }
footer .wrap .left .logo{ display: block; width: 190px; margin: 0 auto 30px; }
footer .wrap .left .logo + table{ width: 100%; border-top: solid 1px #f2f2f2; }
footer .wrap .left .logo + table tr{ border-bottom: solid 1px #f2f2f2; }
footer .wrap .left .logo + table th{ width: 1px; padding: 1em 1em 1em 0; white-space: nowrap; font-size: 13px; position: relative; }
footer .wrap .left .logo + table th:after{ content: ''; width: 1px; height: calc(100% - 20px); background: #f2f2f2; position: absolute; top: 50%; right: 0; transform: translateY(-50%); }
footer .wrap .left .logo + table td{ padding: 1em 0 1em 1em; font-size: 13px; }
footer .wrap .left .tel{ letter-spacing: 0; font-size: 28px; display: table; padding-left: 20px; margin: 20px auto 0; background: url(../images/common/icon-tel02.png) no-repeat; background-size: 15px; background-position: top 50% left 0; }
footer .wrap .right{ width: 525px; display: flex; justify-content: space-between; }
footer .wrap .right dl dt{ margin-bottom: 10px; }
footer .wrap .right dl dd ul li{ font-size: 11px; padding-left: 1.5em; position: relative; margin-bottom: 1em; }
footer .wrap .right dl dd ul li:before{ content: '-'; position: absolute; left: 0; }
footer p.copy{ font-size: 11px; text-align: center; color: #6a6766; margin-top: 110px; }

.totop{ display: block; width: 60px; height: 60px; background: url(../images/common/totop.jpg) no-repeat; background-size: contain; position: fixed; bottom: 0; right: 20px; z-index: 900; transition: .3s; opacity: 0; visibility: hidden; }
.totop.active{ opacity: 1; visibility: visible; }


@media(max-width: 768px){
	*{ font-size: 3.7333vw; }

	.pc{ display: none !important; }
	.sp{ display: block; }

	.wrap{ width: 100%; padding-left: 5.3333vw; padding-right: 5.3333vw; }

	a.btn{ width: 56vw; height: 10.666vw; font-size: 3.2vw; margin-left: auto; margin-right: auto; }
	a.btn:after{ width: 13.6vw; height: 1.0666vw; right: -5.3333vw; }

	header{ width: 100%; left: 0; transform: none; z-index: 9999; }
	header > .logo{ width: 44.666vw; position: absolute; top: 3.2vw; left: 5.3333vw; }
	header nav{ opacity: 0; visibility: hidden; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000; display: flex; flex-wrap: wrap; padding: 0 5.3333vw; transition: .3s;}
	header nav.active{ opacity: 1; visibility: visible; }
	header .sns{ order: 2; }
	header .gnav{ order: 1; flex-wrap: wrap; counter-reset: gnav; width: 100%; height: 66vw; flex-direction: column; margin-top: 36vw; align-items: flex-start; }
	header .gnav li{ font-size: 2.933vw; width: 50%; padding-left: 8vw; white-space: nowrap; text-align: left; }
	header .gnav li:not(:nth-of-type(3n)){ margin-bottom: 10.5vw; }
	header .gnav li:before{ counter-increment: gnav; content: counter(gnav,decimal-leading-zero); font-size: 3.7333vw; font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif; position: absolute; top: 50%; left: 0; transform: translateY(-50%); }
	header .gnav li:not(:nth-of-type(n+6)):after{ content: none; }
	header .gnav li span{ font-size: 5.3333vw; white-space: nowrap; letter-spacing: 0; text-align: left; }
	header .gnav li span:first-letter{ font-size: 10.666vw; }
	header .sns{ align-items: flex-start; }
	header .sns{ width: 100%; justify-content: center; }
	header .sns li{ margin: 0 10.666vw; }
	header .sns li img{ width: 10.666vw; height: 10.666vw; }
	header nav .logo{ width: 44.666vw; position: absolute; top: 3.2vw; left: 5.3333vw; }

	.contact-box{ padding: 9.3333vw 0 10.6666vw; }
	.contact-box .wrap{ width: 100%; }
	.contact-box h2{ font-size: 4.8vw; letter-spacing: 0; white-space: nowrap; margin-bottom: 4vw; }
	.contact-box .btn-list{ flex-wrap: wrap; }
	.contact-box .btn-list li{ margin: 0 auto; }
	.contact-box .btn-list li + li{ margin-top: 5.3333vw; }
	.contact-box .btn-list li a{ width: 56vw; height: 12vw; font-size: 3.6vw; }
	.contact-box .btn-list li a.mincho{ font-size: 5.6vw; }
	.contact-box .btn-list li a span{ padding-left: 5.333vw; }
	.contact-box .btn-list li:nth-of-type(1) a span{ background-size: 3.0666vw; }
	.contact-box .btn-list li:nth-of-type(2) a span{ background-size: 3.6vw; }

	.gmap{ height: 40vw; }

	footer{ padding: 13.333vw 0 20vw; }
	footer .wrap{ width: 100%; }
	footer .wrap .left .logo{ width: 50.666vw; margin-bottom: 5.3333vw; }
	footer .wrap .left .logo + table th{ font-size: 3.466vw; }
	footer .wrap .left .logo + table th:after{ height: calc(100% - 2em); }
	footer .wrap .left .logo + table td{ font-size: 3.466vw; }
	footer p.copy{ font-size: 2.6666vw; margin-top: 15.333vw; }

	.float-list.sp{ width: 100%; display: flex; position: fixed; bottom: 0; left: 0; z-index: 999; }
	.float-list li{ width: 100%; height: 16vw; display: flex; justify-content: center; align-items: center; position: relative; background: #000; }
	.float-list li:nth-of-type(n+2){ border-left: solid 1px #fff; }
	.float-list li span{ font-size: 3.6vw; padding-left: 5.333vw; background-repeat: no-repeat; background-position: top 50% left 0; color: #fff; }
	.float-list li:nth-of-type(1) span{ font-size: 4vw; background-image: url(../images/common/icon-float01.png); background-size: 3.466vw; }
	.float-list li:nth-of-type(2) span{ background-image: url(../images/common/icon-contact01.png); background-size: 3.6666vw; }

	.menu-btn{ position: fixed; top: 4vw; right: 5.3333vw; z-index: 100000; width: 8vw; height: 6vw; }
	.menu-btn span{ width: 100%; height: 1px; background: #fff; position: absolute; left: 0; transition: .3s; }
	.menu-btn span:nth-of-type(1){ top: 0; }
	.menu-btn span:nth-of-type(2){ top: 50%; transform: translateY(-50%); }
	.menu-btn span:nth-of-type(3){ bottom: 0;  }
	.menu-btn.active span:nth-of-type(1){ transform: rotate(45deg) translate(2vw,2vw); }
	.menu-btn.active span:nth-of-type(2){ opacity: 0; }
	.menu-btn.active span:nth-of-type(3){ transform: rotate(-45deg) translate(2vw,-2vw); }

	.totop{ width: 13.333vw; height: 13.333vw; bottom: 16vw; right: 0; }
}


