/* Scss Document */
/* Scss Document */
.box_shadown {
	-webkit-box-shadow: 0px 1px 18px 1px rgba(4, 0, 0, 0.5);
	-moz-box-shadow: 0px 1px 18px 1px rgba(4, 0, 0, 0.5);
	box-shadow: 0px 1px 18px 1px rgba(4, 0, 0, 0.5);
}
.f_cl {
	color: #c04636;
}
i {
	font-style: normal;
}
.d_flex {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.txt-center {
	text-align: center;
}

@media screen and (max-width: 999px) {
.pc {
	display: none;
}
body {
	font-size: 14px;
	line-height: 30px;
	letter-spacing: 0.1em;
}
	header h1 {
	text-align: left!important;
		    width: 80%!important;
    left: 5px!important;
}
}

@media screen and (min-width: 999px) {
.sp {
	display: none;
}
}
header {
	color: #fff;
	position: relative;
	padding-bottom: 80px;
	z-index: 999;
}
header .logo {
	position: absolute;
	right: 5px;
	top: 515px;
	z-index: 9;
}
header h1 {
	position: absolute;
	top: 0;
	right: 5px;
	text-align: right;
	color: #fff;
	font-size: 14px;
	line-height: 20px;
	z-index: 9;
}
header .hamburger {
	height: 56px;
	box-sizing: border-box;
	padding: 16px 10px;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 999;
	background: url(../img/shared/hd_bg.jpg) 0 0 repeat;
}
header .sub_nav {
	position: absolute;
	top: 632px;
	right: 132px;
	z-index: 9;
	font-size: 0;
	letter-spacing: 0;
}
header .sub_nav li {
	margin-left: 2px;
	display: inline-block;
	vertical-align: bottom;
	border: 1px solid #fff;
	-webkit-box-shadow: 0px 1px 18px 1px rgba(4, 0, 0, 0.5);
	-moz-box-shadow: 0px 1px 18px 1px rgba(4, 0, 0, 0.5);
	box-shadow: 0px 1px 18px 1px rgba(4, 0, 0, 0.5);
}
header .sub_nav li a, header .sub_nav li i {
	background: url(../img/shared/map.jpg) 0 0 repeat;
	display: block;
	text-decoration: none;
	font-size: 18px;
	line-height: 26px;
	letter-spacing: 0.2em;
	padding: 4px 12px;
	box-sizing: border-box;
	transition: opacity .3s ease;
	-moz-transition: opacity .3s ease;
	-webkit-transition: opacity .3s ease;
}
header .sub_nav li a img, header .sub_nav li i img {
	margin-right: 5px;
	vertical-align: top;
}
header .sub_nav li a:hover {
	opacity: 0.8;
}
header .sub_nav li.tel {
    background: url(../img/shared/tel1.jpg) 0 0 repeat;
    border: none;
    padding: 2px;
    z-index: 9999;
}
header .sub_nav li.tel a {
	background: none;
	padding: 0;
	width: 100%;
	height: 100%;
}
header .sub_nav li.tel i {
	background: none;
	line-height: 19px;
	border: 1px solid #fff;
	font-size: 15px;
	letter-spacing: 0.1em;
	padding: 6px 14px 5px;
}
header .sub_nav li.tel i span {
	font-size: 17px;
	letter-spacing: 0.1em;
	padding-left: 7px;
}
header .sub_nav li.tel i span span {
	font-size: 25px;
	padding-left: 0;
}
header #belt {
	background: url(../img/shared/hd_bg.jpg) center 0 repeat;
	height: 80px;
	padding-top: 29px;
	box-sizing: border-box;
	position: absolute;
	top: 700px;
	left: 0;
	right: 0;
	z-index: 99;
	-webkit-box-shadow: 0px -1px 28px -6px rgba(4, 0, 0, 0.5);
	-moz-box-shadow: 0px -1px 28px -6px rgba(4, 0, 0, 0.5);
	box-shadow: 0px -1px 28px -6px rgba(4, 0, 0, 0.5);
}
header #belt.fixed {
	position: fixed;
	top: 0;
}
header #belt nav {
	justify-content: center;
	text-align: center;
}
header #belt nav a {
	color: #fff;
	font-size: 18px;
	letter-spacing: 0.2em;
	line-height: 31px;
	position: relative;
}
header #belt nav a.last span {
	border-right: 1px solid #fff;
}
header #belt nav a.active span:before, header #belt nav a:hover span:before {
	content: '';
	position: absolute;
	bottom: -20px;
	left: 15px;
	right: 15px;
	border-top: 3px solid #fff;
}

@media screen and (max-width: 999px) {
header #belt nav a.active span:before, header #belt nav a:hover span:before {
	bottom: 0;
}
}
header #belt nav a span {
	line-height: 31px;
	display: inline-block;
	border-left: 1px solid #fff;
	padding: 0 15px;
	position: relative;
}

@media screen and (max-width: 999px) {
header #belt {
	padding: 0;
	height: 0;
}
header #belt nav {
	display: block;
	padding: 60px 0 80px;
}
header #belt nav a {
	display: block;
	padding: 5px;
	margin-bottom: 10px;
}
header #belt nav a.last span {
	border: none;
}
header #belt nav a span {
	border: none;
}
header #belt nav a.sp {
	background: url(../img/shared/map.jpg) 0 0 repeat;
	max-width: 140px;
	margin: 0 auto 10px;
}
header #belt nav a.sp img {
	margin-right: 8px;
	position: relative;
	top: -2px;
}
header #belt #navigation {
	background: url(../img/shared/hd_bg.jpg) center 0 repeat;
	padding: 0 20px;
	box-sizing: border-box;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 999;
	opacity: 0;
	visibility: hidden;
	overflow: auto;
	-moz-transition: all all 0.5s ease 0s;
	-webkit-transition: all 0.5s ease 0s;
	transition: all 0.5s ease 0s;
}
}

@media screen and (max-width: 999px) {
header {
	padding-bottom: 0;
}
header .logo {
	top: auto;
	right: 15px;
	bottom: 15px;
	width: 20%;
}
header .logo img {
	width: 100%;
	height: auto;
}
}
.navOpen header #belt #navigation {
	opacity: 1;
	visibility: visible;
}
footer {
	background: url(../img/shared/line.jpg) center 0 repeat-x, url(../img/shared/bg1.jpg) center 0 repeat;
	padding: 10px 0 60px;
	line-height: 25px;
	letter-spacing: 0.15em;
	position: relative;
}
footer:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 10px;
	-webkit-box-shadow: 0px -3px 9px 3px rgba(4, 0, 0, 0.14);
	-moz-box-shadow: 0px -3px 9px 3px rgba(4, 0, 0, 0.14);
	box-shadow: 0px -3px 9px 3px rgba(4, 0, 0, 0.14);
}
footer .shop {
	width: 368px;
}
footer .shop .tit {
	font-size: 14px;
	letter-spacing: 0;
	line-height: 20px;
	padding-bottom: 33px;
}
footer .ft-nav {
	line-height: 20px;
}
footer .ft-nav li {
	margin-bottom: 20px;
}
footer .logo {
	margin-bottom: 10px;
}
footer .gr {
	position: absolute;
	left: 0;
	top: 542px;
}
footer .vcard {
	padding-top: 76px;
	max-width: 535px;
	width: calc(100% - 390px);
}
footer .vcard dl {
	padding-bottom: 25px;
}
footer .fixed_tel {
	background: url(../img/shared/tel1.jpg) 0 0 repeat;
	border: none;
	padding: 2px;
	position: fixed;
	left: 0;
	bottom: 0;
	right: 0;
	z-index: 99;
}
footer .fixed_tel a:hover {
	text-decoration: none;
}
footer .fixed_tel i {
	display: block;
	border: 1px solid #fff;
	color: #fff;
	text-decoration: none;
	font-size: 15px;
	line-height: 19px;
	letter-spacing: 0.1em;
	padding: 7px 0px 4px 16px;
	text-decoration: none !important;
	box-sizing: border-box;
	transition: opacity .3s ease;
	-moz-transition: opacity .3s ease;
	-webkit-transition: opacity .3s ease;
}
footer .fixed_tel i span {
	font-size: 17px;
	letter-spacing: 0.1em;
	padding-left: 7px;
}
footer .fixed_tel i span span {
	font-size: 25px;
	padding-left: 0;
}
footer .fixed_tel a {
	display: block;
}

@media screen and (max-width: 374px) {
footer .fixed_tel i {
	font-size: 14px;
	padding-left: 20px;
}
footer .fixed_tel i span {
	letter-spacing: 0.06em;
	padding-left: 4px;
}
footer .fixed_tel i span span {
	font-size: 18px;
}
}
footer .tel {
	background: url(../img/shared/tel1.jpg) 0 0 repeat;
	border: none;
	padding: 2px;
	margin-bottom: 6px;
}
footer .tel a:hover {
	text-decoration: none;
}
footer .tel i {
	display: block;
	border: 1px solid #fff;
	color: #fff;
	text-decoration: none;
	font-size: 15px;
	line-height: 19px;
	letter-spacing: 0.1em;
	padding: 7px 0px 4px 16px;
	text-decoration: none !important;
	box-sizing: border-box;
	transition: opacity .3s ease;
	-moz-transition: opacity .3s ease;
	-webkit-transition: opacity .3s ease;
}
footer .tel i span {
	font-size: 17px;
	letter-spacing: 0.1em;
	padding-left: 7px;
}
footer .tel i span span {
	font-size: 25px;
	padding-left: 0;
}
footer .tel a {
	display: block;
}
footer .sub_nav {
	position: absolute;
	top: 78px;
	left: 128px;
	width: 240px;
}
footer .bnr_shared {
	position: relative;
	z-index: 1;
	margin-bottom: 4px;
}
footer .bnr_shared a {
	padding-left: 25px;
	font-size: 17px;
	height: 47px;
	padding-top: 10px;
}

@media screen and (max-width: 999px) {
footer {
	padding: 15% 20px 70px;
	box-sizing: border-box;
}
footer .logo {
	margin: 0 auto 10%;
}
footer .tel {
	margin: 0 auto 5px;
	max-width: 390px;
	text-align: left;
}
footer .tel i span span {
	font-size: 21px;
}
footer .shop, footer .vcard {
	width: 100%;
	box-sizing: border-box;
	text-align: center;
}
footer .vcard {
	max-width: 100%;
	padding: 0px 0 20px;
}
footer .vcard dl {
	padding-bottom: 15px;
}
footer .sub_nav {
	position: static;
	width: 86%;
	margin: 0 auto;
}
footer .bnr_shared {
	width: 100%;
}
footer .gr {
	position: static;
	width: 100%;
	text-align: center;
	padding-top: 30px;
}
footer .gr address {
	text-align: center;
}
}

@media screen and (max-width: 374px) {
footer .tel i {
	font-size: 14px;
	padding-left: 10px;
}
footer .tel i span {
	letter-spacing: 0.06em;
	padding-left: 4px;
}
footer .tel i span span {
	font-size: 18px;
}
}
.bnr_shared {
	position: relative;
	transform: none !important;
	-moz-transform: none !important;
	-webkit-transform: none !important;
	max-width: 390px;
}
.bnr_shared:before {
	content: '';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 2px;
	background: url(../img/shared/pt_bg.jpg) center repeat;
	width: 2px;
	height: 21px;
	z-index: 1;
}
.bnr_shared a {
	display: block;
	background: url(../img/shared/pt_bg.jpg) center repeat;
	color: #fff;
	font-size: 20px;
	letter-spacing: 0.2em;
	line-height: 30px;
	padding: 20px 0 0 40px;
	height: 67px;
	box-sizing: border-box;
	text-decoration: none !important;
	transition: opacity .3s ease;
	-moz-transition: opacity .3s ease;
	-webkit-transition: opacity .3s ease;
}
.bnr_shared a:after {
	content: '';
	position: absolute;
	top: 50%;
	right: 3px;
	width: 30px;
	border-top: 1px solid #fff;
}
.bnr_shared a:before {
	content: '';
	position: absolute;
	top: 2px;
	right: 2px;
	left: 2px;
	bottom: 2px;
	border: 1px solid #fff;
}
.bnr_shared a:hover {
	opacity: 0.8;
}

@media screen and (max-width: 999px) {
.bnr_shared {
	width: 86%;
	margin: 0 auto;
}
.bnr_shared a {
	font-size: 17px;
	padding: 14px 0 0 18px;
	height: 56px;
}
}

@media screen and (max-width: 999px) {
#pagetop {
	bottom: 60px;
}
section img {
	width: 100%;
	height: auto;
}
}
.bg1 {
	background: url(../img/index/bg1.jpg) center 0 repeat;
}
.bg2 {
	background: url(../img/index/bg2.jpg) center 0 repeat;
}
.slick-dots {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: center;
	width: 100%;
	margin-top: -15px;
}
.slick-dots li {
	display: block;
	line-height: 1;
	margin: 0 10px;
}
.slick-dots button {
	font-size: 0;
	width: 15px;
	height: 15px;
	-webkit-appearance: none;
	border: none;
	background-color: #000000;
	border-radius: 50%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.slick-active button {
	background-color: #c04636;
}

@media screen and (min-width: 1000px) {
.txt-ver-pc {
	cursor: vertical-text;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	word-wrap: break-word;
}
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
.bnr_shared a {
	padding-top: 24px;
}
header .sub_nav li a, header .sub_nav li i {
	padding-top: 8px;
	padding-bottom: 0px;
}
#news .blog a {
	padding-top: 13px !important;
}
footer .bnr_shared a {
	padding-top: 12px;
}
}

@media screen and (min-width: 1000px) {
body.has_nav header .sub_nav {
	position: fixed;
	right: 0px;
	top: 76px;
}
body.has_nav header .sub_nav li.tel {
	text-align: left;
	position: absolute;
	top: 50px;
	right: 0;
	width: 58px;
	height: 324px;
	box-sizing: border-box;
	font-size: 15px;
	letter-spacing: 0.1em;
	white-space: nowrap;
}
body.has_nav header .sub_nav li.tel i {
	display: block;
	width: 100%;
	height: 100%;
	padding: 0;
	box-sizing: border-box;
	padding-top: 13px;
	padding-right: 6px;
	cursor: vertical-text;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	word-wrap: break-word;
}
body.has_nav header .sub_nav li.tel i span {
	letter-spacing: 0.1em;
	font-size: 20px;
	cursor: vertical-text;
	direction: rtl;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: sideways-right;
	-o-text-orientation: sideways-right;
	-ms-text-orientation: upright;
	-ms-text-orientation: sideways-right;
	-moz-text-orientation: sideways-right;
	-webkit-text-orientation: sideways-right;
}
body.has_nav header .sub_nav li.tel i > span {
	display: block;
	position: absolute;
	top: 128px;
	left: 11px;
	font-size: 17px;
}
}
