@charset "utf-8";

/*==================================================================
	Import setting
===================================================================*/
@import url("import/reset.css");
@import url("import/util.css");
@import url('https://fonts.googleapis.com/css2?family=Libre+Caslon+Display&family=Noto+Serif+JP:wght@200..900&display=swap');
/*==================================================================
	Common setting
===================================================================*/
* {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
}
*:before,
*:after {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
}

html { font-size: 62.5%;}
body {
	margin: 0;
	padding: 0;
	position: relative;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	font-family: "Noto Serif JP", serif;
	opacity: 0;
	visibility: hidden;
	transition: all ease-out 0.4s;
	overflow-x: hidden;
}
body.loaded {
	opacity: 1;
	visibility: visible;
}
sup { font-size: 70%; }
.page {
	color: #4D4D4D;
	font-size: 14px;
	line-height: 1.71;
	letter-spacing: 0.1em;
	font-family: "Noto Serif JP", serif;
}
.libre { font-family: "Libre Caslon Display", serif; }
.pc, .pc_only {	display: block !important; }
.sp, .sp_only {	display: none !important; }
.ipad, .ipad_only {	display: block!important; }

@media screen and (max-width: 767px) {
	.pc_only { display: none !important; }
	.sp_only { display: block !important; }
}
a { text-decoration: none;}
a.disable {
	color: #999999 !important;
	cursor: default;
}
a.disable:hover { opacity: 1;}
figure {
    margin: 0;
    padding: 0;
}
img.full {
    width:100%;
    max-width: 100%;
    height:auto;
}
@media only screen and (max-width:1000px){
	.ipad_only { display: none !important; }
}
a {
	background-color: transparent;
	background-image: none;
	background-repeat: no-repeat;
	background-position: top left;
	color: #333333;
	text-decoration: none;
}
a:hover { opacity: 0.8;}
@media only screen and (min-width:1001px){
	a[href^="tel:"] { pointer-events: none;}
}
.btns {
	display: flex;
	justify-content: center;
}
.btns li + li { margin-left: 12px;}
.btns a {
	position: relative;
	transition: all 0.5s;
	font-size: 1.4rem;
	letter-spacing: 0.22em;
	/* height: 40px; */
	line-height: 40px;
	display: block;
	text-align: center;
	display: block;
	border-style: solid;
	border-color: #fff;
	border-width: 1px 1px 0 1px;
	padding: 5px 5px 0;
	min-width: 200px;
	overflow: hidden;
}
/*.btns a::before {
	content: '';
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: -100%;
	animation: shine 1.8s infinite;
	background-image: linear-gradient(130deg, rgba(240, 240, 240, 0) 25%, rgba(240, 240, 240, 0.5) 50%, rgba(240, 240, 240, 0) 75%);
	z-index: 2;
}*/
/* 10秒に1回 */
.btns a::before {
	content: '';
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: -100%;
	animation: shine 10s linear infinite;
	background-image: linear-gradient(
		130deg,
		rgba(240, 240, 240, 0) 25%,
		rgba(240, 240, 240, 0.5) 50%,
		rgba(240, 240, 240, 0) 75%
	);
	z-index: 2;
}

.btns a .btnText {
	display: block;
	background: -webkit-gradient(linear,  left top, right top,  from(rgba(125,117,102,1)),color-stop(37%, rgba(179,172,161,1)),color-stop(93%, rgba(75,72,59,1)));
	background: -o-linear-gradient(left,  rgba(125,117,102,1) 0%,rgba(179,172,161,1) 37%,rgba(75,72,59,1) 93%);
	background: linear-gradient(to right,  rgba(125,117,102,1) 0%,rgba(179,172,161,1) 37%,rgba(75,72,59,1) 93%);
	color: #fff;
	position: relative;
	z-index: 0;
}
.btns a .btnText:after {
	content: "";
	visibility: hidden;
	position: absolute;
	height: 100%;
	opacity: 0;
	transition: all 0.5s;
	width: 100%;
	background: -webkit-gradient(linear,  left top, right top,  from(rgba(125,117,102,1)),color-stop(37%, rgba(179,172,161,1)),color-stop(93%, rgba(75,72,59,1)));
	background: -o-linear-gradient(left,  rgba(125,117,102,1) 0%,rgba(179,172,161,1) 37%,rgba(75,72,59,1) 93%);
	background: linear-gradient(to left,  rgba(125,117,102,1) 0%,rgba(179,172,161,1) 37%,rgba(75,72,59,1) 93%);
	top: 0;
	left: 0;
}
.btns a:hover .btnText:after {
	visibility: visible;
	opacity: 1;
}
.btns a .btnText .jp {
	position: relative;
	z-index: 2;
}
.btns.bdr_black a { border-color: #38322c!important;}
.btns.btns01 a { border-color: #38322c!important;}
.btns.btns01 a .btnText {
	background: #ddd9d4!important;
	color: #38322c!important;
}
.btns.btns01 a .btnText:after { content: none;}
.btns.btns01 a:hover { opacity: .7;}
/*@keyframes shine {
	0%{
	  left: -150%;
	}
	100% {
	  left: 250%;
	}
}*/
/* 10秒に1回  */
@keyframes shine {
	0% {
		left: -150%;
	}
	18% { /* 1.8s / 10s = 18% でshine終了 */
		left: 250%;
	}
	100% {
		left: 250%; /* 残りの時間は止める */
	}
}


@media screen and (max-width: 1200px) {
	.btns a { font-size: 1.3rem;}
}
@media screen and (max-width: 1000px) {
	.btns { display: block;}
	.btns li { width: auto;}
	.btns li + li { margin: 10px 0 0;}
}
/*==================================================================
	Header setting
===================================================================*/
@media only screen and (min-width:1001px){
	#btn-hambeger {
		padding: 10px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
		cursor: pointer;
		height: 70px;
		width: 70px;
		color: #FFF;
		position: fixed;
		right: 10%;
		top: 25vh;
		transition: all 0.4s cubic-bezier(1,1,0,0);
		z-index: 1001;
	}
	#btn-hambeger.active_difference { mix-blend-mode: difference;}
	#btn-hambeger.active { background: transparent;}
	#btn-hambeger.active.active_difference { mix-blend-mode: inherit;}
	#btn-hambeger .txt {
		font-size: 1.3rem;
		line-height: 1;
		letter-spacing: 0.015em;
		color: #ffffff;
		margin-bottom: 10px;
	}
	#btn-hambeger.active .txt { color: #fff;}
	#btn-hambeger .lines {
		width: 100%;
		height: 30px;
		display: flex;
		flex-direction: column;
		transition: all 0.4s cubic-bezier(1,1,0,0);
		justify-content: space-between;
	}
	#btn-hambeger .lines span {
		background: #FFF;
		display: block;
		height: 1px;
		width: 100%;
		margin: 2px 0;
		opacity: 1;
	}
	#btn-hambeger.active .lines {
		opacity: 1;
		visibility: visible;
	}
	#btn-hambeger:hover .lines span { background: #FFF;}
	#btn-hambeger.active .lines span { background: #fff;}
	#btn-hambeger.active .lines span:nth-child(2) {
		transform: translateX(10px);
		opacity: 0;
	}
	#btn-hambeger.active .lines span:nth-child(1) {
		transform: rotate(45deg);
		margin-bottom: 0;
		position: absolute;
		top: 55%;
		left: 20%;
		width: 60%;
	}
	#btn-hambeger.active .lines span:nth-child(3) {
		transform: rotate(-45deg);
		margin-top: 2px;
		position: absolute;
		top: 55%;
		left: 20%;
		width: 60%;
	}
}
@media only screen and (min-width:1001px){
	#btn-hambeger {
		right: 15px;
		top: 15px;
	}
}
@media only screen and (min-width:1200px){
	#btn-hambeger {
		right: 30px/*5%*/;
		top: 30px/*5vh*/;
	}
}

@media only screen and (max-width:1000px){
	#btn-hambeger {  display:none; }
}

@media only screen and (max-width:640px){
	.site-header { height: 140px;}
	.site-header .tools .head-btns li a {
		height: 55px;
		background-size: auto 40px;
	}
	.site-header .tools li.links a { background-image: url(../imgs/hdr-sp-map.png);}
	.site-header .tools li.tel a { background-image: url(../imgs/hdr-sp-tell.png);}
	.site-header .tools li.menu-button a { background-image: url(../imgs/hdr-sp-menu.png);}
	.site-header .tools li.menu-button.on a { background-image: url(../imgs/hdr-sp-close_ov.png);}
	.sp-navi { top: 55px!important;}
}

/* ----------------------------------------
 header-style only-pc 
*/
header {
	box-sizing: border-box;
	position: absolute;
	width: 100%;
	height: 100px;
	z-index: 999;
	padding-bottom: 20px;
}
header .body { position: relative;}
header .title a:hover { opacity: 1;}
header .title { padding: 0px 0 0 60px;}
@media only screen and (min-device-width: 1001px) and (max-device-width: 1024px) {
	header .title { padding-left: 40px;}
}
header .title .placeName {
	padding-bottom: 2px;
    max-width: 138px;
    margin-top: 0!important;
    width: 30%;
    vertical-align: bottom;
}
header .title img {
	float: left;
	vertical-align: bottom;
}
header .title img + img { margin-top: 7px;}
header .text {
	position: absolute;
	top: 3vh;
	right: 11%;
	font-size: 10px;
	line-height: 1.2;
	color: rgba(255,255,255,0.8);
}
header .text.black { color: #ffffff;}
header .tools {
	position: absolute;
	right: 58px;
	top: 40px;
}
header .menu-button { display: none;}
header .tools li {
	float: left;
	margin-left: 1px;
	position: relative;
}
header .tools li.links {
	text-align: left;
	padding-right: 9px;
}
header .tools li.links a {
	color: #ffffff;
	font-size: 12px;
    display: inline;
    margin-top: 3px;
    line-height: 8px;
}
header .tools li.links a:hover span { opacity: 0.7;}
header .tools li.links .outline { padding-top: 16px;}
header .tools li.request a:hover,
header .tools li.request a:hover img,
header .tools li.reserve a:hover,
header .tools li.reserve a:hover img {
	opacity: 1;
}
header .tools li.request,
header .tools li.reserve,
.site-footer .btns .requestBtn,
.site-footer .btns .reserveBtn,
.site-footer .btns .remoteBtn {
	position: relative;
	overflow: hidden;
}
header .tools li.request > span,
header .tools li.reserve > span,
.site-footer .btns .requestBtn > span,
.site-footer .btns .reserveBtn > span,
.site-footer .btns .remoteBtn > span {
	position: relative;
	z-index: 1;
}
@media screen and (min-width: 1001px) {
	header .tools { display: none;}
	header .tools li.requestBtn {
		border: 1px solid #ffffff;
	    position: relative;
	    overflow: hidden;
	    height: 43px;
	    width: 160px;
	    text-align: center;
	    line-height: 43px;
	    color: #fff;
	    font-size: 1.3em;
		letter-spacing: 0.2em;
		margin-left: 10px;
	    background: transparent;
	}
	header .tools li.reserveBtn {
		border: 1px solid #ffffff;
	    position: relative;
	    overflow: hidden;
	    height: 43px;
	    width: 160px;
	    text-align: center;
	    line-height: 43px;
	    color: #fff;
	    font-size: 1.3em;
		letter-spacing: 0.2em;
		margin-left: 10px;
	    background: transparent;
	}
	header .tools li.remoteBtn {
		border: 1px solid #ffffff;
	    position: relative;
	    overflow: hidden;
	    height: 43px;
	    width: 160px;
	    text-align: center;
	    line-height: 43px;
	    color: #fff;
	    font-size: 1.3em;
	    letter-spacing: 0.1em;
	    margin-left: 10px;
	    background: transparent;
	}
}
header .tools .head-btns li.requestBtn:hover a,
header .tools .head-btns li.reserveBtn:hover a,
header .tools .head-btns li.remoteBtn:hover a,
.site-footer .btns li:hover a { color: #333;}
header .tools li.requestBtn:hover:before,
header .tools li.reserveBtn:hover:before,
header .tools li.remoteBtn:hover:before,
.site-footer .btns .reserveBtn:hover:before,
.site-footer .btns .requestBtn:hover:before,
.site-footer .btns .remoteBtn:hover:before {
	width: 100%;
}

@-webkit-keyframes reflection {
 0% {
    left: -40%;
  }
  55% {
    left: 110%;
  }
  100% {
    left: 110%;
  }
}

@keyframes reflection {
 0% {
    left: -40%;
  }
  55% {
    left: 110%;
  }
  100% {
    left: 110%;
  }
}
@media screen and (min-width: 1001px) {
	.sp-navi { display: none !important;}
	header .title .placeName {
		display: inline-block;
		height:auto;
		position: absolute;
		top: 0 !important;
    	z-index: 9999;
	}
}
/*
 End-header-style only-pc 
 ---------------------------------------- */

/* ----------------------------------------
 header-style only-tablet 
*/
@media screen and (max-width: 1000px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	header .tools li.requestBtn::before,
	header .tools li.reserveBtn::before,
	header .tools li.remoteBtn::before{
		display: none;
		animation: reflection 0s ease infinite;
	}
}
/*
 End-header-style only-tablet 
 ---------------------------------------- */

/* ----------------------------------------
 header-style tablet-sp 
*/
@media screen and (max-width: 1000px) {
	header .tools li.request:after,
	header .tools li.reserve:after {
		display: none;
	}
	header {
		background: #fff;
		height: 164px;
		border-bottom: 1px solid #cbcbcb;
		position: relative;
	}
	header .title {
		padding: 20px 10px 0 10px;
		text-align: center;
	}
	header .title .placeName {
		display: inline-block;
		width: auto;
		height: 15px;
		max-width: 220px;
		margin-top: 0 !important;
	}
	header .title .clio.sp {
		display: block !important;
		margin: 0 auto 15px auto;
		width: auto;
		height: 20px;
	}
	header .title img {
		display: block;
		margin: 0 auto 10px auto;
		max-width: 100%;
		height: 20px;
		float: inherit;
	}
	header .text { display: none;}
	header .tools { position: static;}
	header .tools li img { display: none;}
	header .tools .sp-navi li img {
		display: inline-block;
		width: auto;
	}
	header .tools .sp-navi li.off a {
		pointer-events: none;
		opacity: 0.3;
	}
	header .tools .sp-navi li.nolink img {opacity: 0.3;}
	header .menu-button {
		display: block;
	}
	header .tools-base {
		position: relative;
		height: 55px;
	}
	header .tools {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: auto;
	}
	header .tools li {
		/*width: 25%;*/
		/* width: 20%; */
		 /*width: calc(100% / 4);*/
		width: calc(100% / 6);
		box-sizing: border-box;
		text-align: center;
		margin: 0;
		border-width: 1px 0 1px 1px;
	}
	header .tools .sp-navi { z-index: 10;}
	header .tools .head-btns li {
		border-right: none;
		background-color: #fff;
	}
	header .tools .head-btns li.sp { display: block !important;}
	header .tools .head-btns li:first-child { border-left: none;}
	header .tools li.links { 
		padding-right: 0;
		text-align: center;
	}
	header .tools .head-btns li a:hover { opacity: 1;}
	header .tools li div.outline { display: none;}
	header .tools .head-btns li a {
		box-sizing: border-box;
		display: block;
		width: auto;
		height: 80px;
		padding: 9px 0 6px !important;
		border: none;
		line-height: 1;
		text-decoration: none;
		background-repeat: no-repeat;
		background-position: center;
		background-size: auto 60px;
	}
	header .tools li.menu-button.on a { background-color: rgba(255,255,255,1);}
	header .tools li.links a {
		display: block;
		margin-top: 0;
		background-image: url(../imgs/hdr-sp-map.png);
	}
	header .tools .head-btns .requestBtn .btnText,
  	header .tools .head-btns .reserveBtn .btnText,
	header .tools .head-btns .remoteBtn .btnText{
		display: none;
	}
	header .tools .head-btns li.requestBtn a { background-image: url(../imgs/hdr-sp-request.png);}
	header .tools .head-btns li.reserveBtn a { background-image: url(../imgs/hdr-sp-reserve.png);}
	header .tools .head-btns li.remoteBtn a { background-image: url(../imgs/hdr-sp-web.png);}
	header .tools li.tel a { background-image: url(../imgs/hdr-sp-tell.png);}
	header .tools li.menu-button a { background-image: url(../imgs/hdr-sp-menu.png);}
	header .tools li.menu-button.on a { background-image: url(../imgs/hdr-sp-close_ov.png);}
	header .tools .sp-navi ul {
		border-top: 1px solid rgba(51, 51, 51, 0.1);
		position: static;
		margin: 0px 0 20px;
	}
	header .tools .sp-navi .navi-list li {
		-webkit-box-sizing: border-box;
		   -moz-box-sizing: border-box;
		        box-sizing: border-box;
		float: left;
		width: 50%;
		border-bottom: 1px solid rgba(51, 51, 51, 0.1);
		border-right: 1px solid rgba(51, 51, 51, 0.1);
	}
	.site-header .tools .sp-navi .navi-list li:nth-child(odd):last-child {
		border-right: none;
		width: 100%;
	}
	header .tools .sp-navi .navi-list li:nth-child(2n) { border-right: none;}
	header .tools .sp-navi .navi-list li a {
		color: #191919;
		padding: 17px 0 15px;
	}
	header .tools .sp-navi .navi-list li.compact { padding: 10px 0 7px !important;}
	header .tools .sp-navi .navi-list li.disable a { opacity: 0.3;}
	header .tools .sp-navi .navi-list:before {
		position: absolute;
		bottom: 0;
		left: 0;
		display: block;
		width: 100%;
		height: 1px;
		background: #8680a5;
	}
	header .tools .head-btns {
		position: relative;
		z-index: 20;
	}
	.sp-navi a {
		display: block;
		color: #fff;
	}
	header .tools .sp-navi .btns {
		clear: both;
		margin: 0 auto;
		padding: 0 0 15px;
		width: 70%;
		background: none;
	}
	header .tools .sp-navi .btns li {
		float: none;
		clear: both;
		margin: 0 auto;
		margin-bottom: 10px;
		width: auto;
		text-align: center;
	}
	header .tools .sp-navi .btns li:last-child { margin-bottom: 0;}
	header .tools .sp-navi .btns li a {
		display: block;
		box-sizing: border-box;
		width: auto;
		font-size: 13px;
	}
	header .head-btns .requestBtn a,
	header .head-btns .reserveBtn a { background-color: transparent;}
	header .head-btns .requestBtn a:after,
	header .head-btns .reserveBtn a:after { display: none !important;}
	header .btns .requestBtn a:after,
	header .btns .reserveBtn a:after { display: none !important;}
}

/*
 End-header-style tablet-sp 
 ---------------------------------------- */
@media only screen and (min-width: 1001px) {
	header { position: absolute; }
}
/* 
 End-header-style 
---------------------------------------- */
.global-navi-base {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	font-feature-settings: normal;
	z-index: -1;
	pointer-events: none;
}
.global-navi-base.active {
	z-index: 1000;
	pointer-events: all;
}
.global-navi-base .layer {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../imgs/navi_bg.jpg) no-repeat center center / cover;
	transition: opacity 1s;
	opacity: 0;
}
.global-navi-base.active .layer {
	pointer-events: inherit;
	opacity: 1;
	z-index: 1;
}
.global-navi {
	position: absolute;
	right: 0;
	color: #fff;
	box-sizing: border-box;
	padding: 0px;
	z-index: 100;
	width: 100%;
	min-height: 100%;
	z-index: -1;
	opacity: 0;
	transform: scaleX(1);
	transform-origin: right;
	transition: opacity 0.7s, transform 0.5s;
	pointer-events: none;
	display: flex;
	align-items: center;
}
.global-navi-base.active .global-navi {
	pointer-events: all;
	opacity: 1;
	transform: scaleX(1);
	z-index: 100;
}
.global-navi .in {
	width: 80%;
	margin: auto;
	max-width: 1140px;
}
.global-navi .block01 {
	padding-left: 40px;
	padding-bottom: 10vh;
	padding-bottom: 6vh;
	width: 50%;
	max-width: 500px;
}
.global-navi .block01 img { max-width: 80%;}
.global-navi .block02 .links {
	display: flex;
	flex-wrap: wrap;
	max-width: 585px;
	margin: auto;
}
.global-navi .block02 .links li {
	width: calc(100%/3);
	padding-bottom: 0;
	margin-bottom: 60px;
	position: relative;
}
.global-navi .block02 .links li.zeh { white-space: nowrap;}
.global-navi .block02 .links li.off {
	pointer-events: none;
	opacity: 0.3;
}
.global-navi .links li { padding-bottom: 30px;}
.global-navi .links a {
	position: relative;
	display: inline-block;
	padding-bottom: 4px;
}
.global-navi .block02 .links a {
	display: block;
	position: relative;
	color: #fff;
}
.global-navi .links a::before {
	content: "";
	font-family: "Libre Caslon Display", serif;
	display: none;
	position: absolute;
	font-size: 1.4rem;
	color: #c6af85;
	transform: translateY(-50%);
	padding: 3px 5px 0;
	top: -8px;
	margin-top: 0;
	letter-spacing: 0.1em;
	line-height: 1.25;
}
.global-navi .links .new a::before {
	content: "new";
	display: block;
}
.global-navi .links .current a::after { width: 100%;}
.global-navi .block02 .links a span {
	position: absolute;
	top: 0;
	left: 0;
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	opacity: 0;
	transition: all 0.5s;
}
.global-navi .block02 .links a span.en { opacity: 1;}
.global-navi .block02 .links a span.ja { display: none; letter-spacing: -0.05em;}
.global-navi .block02 .links a:hover .en { color: #eed57e;}
.global-navi .block02 .links a:hover .ja { opacity: 1;}
.global-navi .block02 .contact .ttl {
	color: #ffffff;
	font-size: 1.2rem;
	margin-bottom: 6px;
}
.global-navi .block02 .contact .txt {
	color: #ffffff;
	float: left;
	margin-right: 40px;
}
.global-navi .block02 .contact .txt img {
	height: 30px;
	margin-bottom: 10px;
}
.global-navi .block02 .contact .txt span {
	display: block;
	font-size: 1rem;
	line-height: 1.5;
}
.global-navi .in-block { 
	max-width: 585px;
	margin:  5.5% auto 0;
}
.global-navi .links01 {
	display: flex;
	font-size: 1.4rem;
	line-height: 1.6;
	margin-bottom: 30px;
}
.global-navi .links01 li { display: block;}
.global-navi .links01 li + li { margin-left: 20px;}
.global-navi .links01 a { color: #fff;}
.global-navi .in-block .btns {justify-content: flex-start;}
.global-navi .in-block .btns a{
	min-width: 185px;
}
.global-navi .contact {
	display: flex;
	margin-top: 35px;
}
/* nav 調整  */
.global-navi .links li.on span:first-child,
.global-navi .links li a:hover span:first-child {
	opacity: 0;
	visibility: hidden;	
}
.global-navi .links li a:hover span:last-child,
.global-navi .links li.on span:last-child {
	opacity: 1;
	visibility: visible;
	display: block;
}
.global-navi .links li span:last-child::before {
	background: #ffffff;
	content: "";
	display: inline-block;
	height: 6px;
	width: 6px;
	position: relative;
	top: 0;
	bottom: 0;
	left: -8px;
	margin: auto;
	margin-right: 5px;
	transform: rotate(45deg);
	opacity: 0;
	position: absolute;
}
.global-navi .links li.on span:last-child::before { opacity: 1;}

/* ----------------------------------------
 navi-style only-pc 
*/
@media screen and (min-width: 1001px) {
	.sp-navi { display: none !important;}
	.global-navi-base { z-index: 101;}
}
/* 
 End-navi-style only-pc 
---------------------------------------- */
@media only screen and (min-width: 1001px) {
}
/* ----------------------------------------
 navi-style tablet-sp
*/
@media screen and (max-width: 1000px) {
	.global-navi-base { display: none;}
	.global-navi { display: none;}
	.global-navi.fd_fixed { top: 80px;}
	.sp-navi {
		display: none;
		position: absolute;
		box-sizing: border-box;
		top: 80px;
		left: 0;
		width: 100%;
		text-align: center;
		font-size: 10px;
		background: rgba(255, 255, 255, 1);
		z-index: 10;
	}
	.sp-navi li { margin-bottom: 4px;}
	.sp-navi li.current a {
		box-sizing: border-box;
		text-decoration: underline;
	}
	.sp-navi .close { display: none;}
	.sp-navi .close a {
		display: block;
		box-sizing: border-box;
		border: 1px solid #333;
		background-color: #FFF;
	}
	.sp-navi .close a span {
		display: inline-block;
		line-height: 50px;
		background-repeat: no-repeat;
		background-position: left;
		padding-left: 30px;
		font-size: 24px;
		color: #333;
		background-image: url(../imgs/gNav-close-icn.png);
	}
	.sp-navi li.new a:before {
		content: "new";
		display: inline-block;
		position: absolute;
		padding: 0 3px;
		top: 3px;
		left: 50%;
		transform: translateX(-50%);
		color: #c6af85;
		font-size: 1.4rem;
		font-family: "Libre Caslon Display", serif;
		line-height: 1.0;
		letter-spacing: 0;
		font-weight: normal;
	}
	.sp-navi li.Pickup a:before {
		content: "Pick up";
		display: inline-block;
		position: absolute;
		margin-left: -17.5px;
		padding: 0 3px;
		top: 2px;
		left: 12%;
		color:#bd0808;
		font-size: 10px;
		line-height: 1.2;
		letter-spacing: 0;
		
		font-weight: normal;
		font-style: italic;
	}
	.sp-navi .nolink span{ color: rgba(255,255,255,.1)!important;}
}

/*==================================================================
	Footer setting
===================================================================*/
.site-footer {
	position: relative;
	background-color: #FFF;
	z-index: 50;
}
.foot-navi li.disable a { opacity: 0.3;}
.site-footer .infoes {
	margin-bottom: 25px;
    padding: 0;
	background-color: #23201e;
}
.site-footer .infoes .infoes-base {
	position: relative;
	min-height: 70px;
}
.site-footer .infoes .base {
	position: relative;
	padding: 58px 0 52px;
	left: 0;
	bottom: 0;
	width: 100%;
}
.site-footer .infoes .base.fixed {
	position: fixed;
	z-index: 99;
	padding: 25px 0 15px;
	background-color: #23201e;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease-out;
}
body.fm_vis .site-footer .infoes .base.fixed {
	opacity: 1;
	visibility: visible;
}
.site-footer .infoes .inner:after {
	content: "";
	width: 1px;
	height: 1px;
	display: table;
	clear: both;
}
.site-footer .infoes a:hover { opacity: 1;}
.site-footer .infoes img {
	max-width: 270px;
	height: auto;
}
@keyframes button {
	0% {
		left: -10%;
	}
	17% {
		left: 110%;
	}
	100% {
		left: 110%;
	}
}
.site-footer .btns {
	margin: 0;
	float: right;
	width: 27%/*42.8%*/;
	width: auto;
	display: block;
}
.site-footer .btns li {
	background: transparent;
	box-sizing: border-box;
	position: relative;
	float: left;
	text-align: center;
	width: 185px;
}
.site-footer .btns li a { min-width: 185px;}
/* .site-footer .btns li a:hover { opacity: 0.7;} */
.site-footer .btns li a img {
	max-width: 100%;
	height: auto;
}
.site-footer .btns li .caption {
	position: absolute;
	right: 1%;
	bottom: 1%;
	line-height: 1;
	font-size: 10px;
	color: #fff;
}
.site-footer .links {
	float: right;
    padding: 0 10px 0 0;
    font-size: 11px;
	margin-right: 5%;
	margin-right: 2%;
	position: relative;
	top: 7px;
}
.infoes .site-footer .links li:first-child { margin-bottom: 0px;}
.site-footer .links a { color: #fff;}
.site-footer .contact {
	margin-bottom: 0;
    padding: 0 0 0;
    float: left;
    width: 38%;
	width: 27%;
    line-height: 1;
	margin-top: -6px;
	
}
.site-footer .contact a { color: #ffffff;}
.site-footer .contact .title {
	color: #fff;
	letter-spacing: -0.1px;
	padding-bottom: 10px;
	font-size: 12px;
}
.site-footer .contact .number {
	float: left;
	padding-right: 14px;
	position: relative;
	font-size: 36px;
}
.site-footer .foot-bnr {
	padding: 40px 10px;
	background: #c2b8a9;
}
.site-footer .foot-bnr ul {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	max-width: 1110px;
	margin: 0 auto;
	padding-left: 14px;
}
.site-footer .foot-bnr li {
	float: left;
	width: 50%;
	margin-left: 14px;
	line-height: 0;
}
.site-footer .foot-bnr li:first-child { margin-left: -14px;}
.site-footer .foot-bnr li img {
	max-width: 100%;
	height: auto;
}
.site-footer .foot-bnr li a { display: block;}
@media only screen and (max-width:1200px) {
	.site-footer .btns li { max-width: 145px;}
	.site-footer .btns li a { min-width: auto;}
	.site-footer .infoes img { max-width: 190px;}
}
@media screen and (min-width: 1001px) {
	.site-footer .contact .number span.pc { display: inline-block !important;}
}
.site-footer .contact .number a {
	display: block;
	position: relative;
}
.site-footer .contact .businessHours {
	color: #fff;
	float: left;
	line-height: 0.5;
	font-size: 11px;
	letter-spacing: 0.05em;
	margin-top: 10px;
}
.site-footer .foot-navi ul li.off a {
	opacity: 0.2;
	cursor: default;
}
.site-footer .foot-navi ul li.off a span:after { display: none;}

/* ----------------------------------------
 footer-style only-pc 
*/
@media screen and (min-width: 1001px) {
	.site-footer .infoes .bg .caption {
		position: absolute;
		bottom: 0;
		right: 0;
		width: 105px;
		line-height: 20px;
		background: rgba(43, 43, 43, 0.74);
		text-align: center;
	}
	.site-footer .contact .num { pointer-events: none;}
	.site-footer .foot-navi {
		background-color: #47403a;
		display: none;
		text-align: center;
		border-top: none;
	}
	.site-footer .foot-navi ul {
		margin: 0 auto;
		padding: 20px 0 20px;
		max-width: 900px;
	}
	.site-footer .foot-navi ul li {
		-webkit-box-sizing: border-box;
		   -moz-box-sizing: border-box;
		        box-sizing: border-box;
		float: left;
		width: calc(100% / 10);
		position: relative;
		font-size: 11px;
		letter-spacing: 0;
	}
	.site-footer .foot-navi ul li a {
		display: inline-block;
		position: relative;
		text-decoration: none;
		color: #fff;
		font-size: 10px;
		opacity: 0.6;
	}
	.site-footer .foot-navi ul li.on a { opacity: 1;}
	.site-footer .foot-navi ul li.new a:before {
	    content: "";
	    display: none;
	    position: absolute;
	    margin-left: -15px;
	    padding: 1px 3px 0;
	    top: -14px;
	    left: 50%;
	    width: 30px;
	    height: 10px;
	    background: url(../imgs/ico_new.svg) no-repeat center center;
	    background-size: contain;
	    font-weight: normal;
	}
}
/*
 End-footer-style only-pc 
---------------------------------------- */
/* ----------------------------------------
 footer-style only-tablet 
*/
@media screen and (max-width: 1000px) and (min-width: 640px) {
	.site-footer .pc { display: none !important;}
	.site-footer .sp { display: block !important;}
}
/* 
 End-footer-style only-tablet 
---------------------------------------- */
/* ----------------------------------------
 footer-style tablet-sp
*/
@media screen and (max-width: 1000px) {
	header .tools.fixed {
		position: fixed;
		background: #877848;
	}
	.site-footer .infoes {
		margin-bottom: 0;
		text-align: center;
	}
	.site-footer .infoes .infoes-base { min-height: inherit;}
	.site-footer .infoes .btns {
		float: none;
		margin: 0 auto;
		width: 70%;
	}
	.site-footer .infoes .btns li { float: none;}
	.site-footer .infoes .btns li a { width: auto;}
	.site-footer .infoes .base {
		border-top: none;
		position: static !important;
		padding: 25px 0 15px;
	}
	.site-footer .infoes .contact {
		float: none;
		margin: 0 auto;
		width: 94%;
		text-align: center;
	}
	.site-footer .infoes .contact .title {
		float: none;
		width: auto;
	}
	.site-footer .infoes .contact .title img { margin-bottom: 0;}
	.site-footer .infoes .contact .businessHours {
		padding-top: 0;
		float: none;
		width: auto;
	}
	.site-footer .contact .businessHours img {
		margin: 0 auto;
		height: auto;
	}
	#gFooter img { max-width: 100%;}
	#gFooter .meiwaLink {
		margin-top: 0;
		border-top: 1px solid #E1E1E1;
		margin-bottom: 0;
	}
	#gFooter .meiwaLink li {
		border: 1px solid #E1E1E1;
		border-width: 0 0 1px 0;
		width: 100%;
	}
	#gFooter .ftrCompanyLink {
		text-align: center;
		padding: 20px 10px 0 10px;
		border-bottom: 1px solid #E1E1E1;
		margin-bottom: 0;
	}
	#gFooter .ftrCompanyLink .companyLink {
		position: static;
		margin-top: 20px;
	}
	#gFooter .ftrCompanyLink .companyLink li {
		float: none;
		margin: 10px 0;
	}
	#gFooter .ftrCopy { text-align: center;}
	.foot-navi {
		border-top: 1px solid rgba(51, 51, 51, 0.1);
		position: relative;
		height: auto;
		overflow: hidden;
	}
	.foot-navi:before {
		position: absolute;
		bottom: 0;
		left: 0;
		display: block;
		width: 100%;
		height: 1px;
		background-color: #8d8d8d;
	}
	.foot-navi li {
		box-sizing: border-box;
		display: block;
		float: left;
		width: 50%;
		margin-right: 0;
		text-align: center;
		font-size: 10px;
		border-bottom: 1px solid rgba(51, 51, 51, 0.1);
		border-right: 1px solid rgba(51, 51, 51, 0.1);
		padding: 15px 0;
		color: #8d8d8d;
	}
	.foot-navi li:nth-child(2n) {
		border-right: none;
	}
	.foot-navi li:nth-child(odd):last-child {
		border-right: none;
		width: 100%;
	}
	.foot-navi li a {
		display: block;
		position: relative;
		color: #333333;
	}
	.foot-navi li.new a:before {
		content: "new";
		display: inline-block;
		position: absolute;
		padding: 0 3px;
		top: -18px;
		top: -13px;
		left: 41%;
		left: 50%;
		transform: translateX(-50%);
		color: #c6af85;
		font-size: 1.4rem;
		font-family: "Libre Caslon Display", serif;
		font-weight: normal;
		line-height: 1.0;
		letter-spacing: 0;
	}
	.foot-navi li.Pickup a:before {
		content: "Pick up";
		display: inline-block;
		position: absolute;
		margin-left: -17.5px;
		padding: 0 3px;
		top: 2px;
		left: 14%;
		color: #bd0808;
		font-size: 10px;
		line-height: 1.2;
		letter-spacing: 0;
		font-family: 'Noto Sans Japanese';
	}
	.foot-navi li a:hover { text-decoration: none;}
	.site-footer .btns { padding-bottom: 30px;}
	.site-footer .btns li {
		float: none;
		width: auto;
		height: auto;
		margin-right: 0;
		margin-bottom: 10px;
		max-width: 100%;
	}
	.site-footer .btns li.remoteBtn { margin-bottom: 0;}
	.site-footer .btns li img { margin: 0 0 0 auto;}
	.site-footer .links {
		float: none;
		margin-bottom: 30px;
		padding: 0 ;
		margin-right: 0;
		top: 0;
	}
	.site-footer .links li:first-child { margin-bottom: 4px;}
	.site-footer .contact {
		float: none;
		clear: both;
		width: auto;
	}
	.site-footer .contact .title { padding-bottom: 10px;}
	.site-footer .contact .title .pc { display: none !important;}
	.site-footer .contact .title .sp { display: block !important;}
	.site-footer .contact .number {
		float: none;
		clear: both;
		padding: 0 0px 10px 0;
		position: relative;
		font-size: 36px;
	}
	.site-footer .foot-bnr { padding: 40px 15px;}
	.site-footer .foot-bnr ul { padding-left: 0;}
	.site-footer .foot-bnr li {
		float: none;
		width: auto;
		margin-left: 0;
		text-align: center;
	}
	.site-footer .foot-bnr li:first-child { margin: 0 0 15px;}
}
@media screen and (max-width: 1000px) and (min-width: 1001px) {
	.site-footer .contact .number span.pc { display: inline-block !important;}
}
@media screen and (max-width: 1000px) {
	.site-footer .contact .number a {
		box-sizing: border-box;
		border: 1px solid #fff;
		padding: 18px 0 18px 28px;
		width: 100%;
		color: #fff;
		font-size: 15px;
	}
	.site-footer .contact .number a .sp {
		display: inline-block !important;
		width: auto;
	}
	.site-footer .contact .number a:before {
		position: absolute;
		left: 50%;
		bottom: 25%;
		margin: 0px 0 0 -115px;
		width: 28px;
		height: 27px;
		display: inline-block;
		content: '';
		background-image: url("../imgs/icon_tel.png");
		background-size: 100% auto;
	}
	.site-footer .contact .businessHours { font-size: 10px;}
	.site-footer .copyright { text-align: center;}
	.site-footer .copyright p { width: 94%;}
	.site-footer .copyright img {
		width: 100%;
		height: auto;
		max-width: 279px;
	}
	.site-footer .copyright img.sp { display: inline-block !important;}
}
@media screen and (min-width: 1001px) {
	.site-footer ul.reserve .reserveBtn a {
		width: 260px;
		transition: all .3s;
	}
	.site-footer ul.reserve .requestBtn a {
		width: 150px;
		opacity: 0.7;
		transition: all .3s;
	}
	.site-footer ul.request .requestBtn a {
		width: 260px;
		transition: all .3s;
	}
	.site-footer ul.request .reserveBtn a {
		width: 150px;
		opacity: 0.7;
		transition: all .3s;
	}
}
footer { background-color: #FFF;}
footer .gFooterBody {
	max-width: 1000px;
	margin: 0 auto;
}
footer .meiwaLink {
	margin-top: 20px;
	margin-bottom: 35px;
	font-size: 14px;
	text-align: center;
}
footer .meiwaLink li {
	box-sizing: border-box;
	border-left: 1px solid #E1E1E1;
	display: inline-block;
	width: 32.333333%;
}
footer .meiwaLink li:first-child { border-left: none;}
footer .meiwaLink a {
	display: block;
	color: #333;
	text-decoration: none;
	padding: 14px 10px;
}
footer .meiwaLink a:hover span { text-decoration: underline;}
footer .meiwaLink a span {
	background-image: url(../imgs/ftr-link-arr.png);
	background-repeat: no-repeat;
	background-position: left center;
	padding-left: 20px;
	font-size: 12px;
	font-family: '?ᥤ??E?',Meiryo,'?ͣ??Х????å?',sans-serif,'?ҥ饮?νǥ? Pro W3','Hiragino Kaku Gothic Pro';
	letter-spacing: 0;
}
footer .ftrCompanyLink {
	position: relative;
	margin: 0 auto 15px auto;
	padding: 15px 0;
}
footer .ftrCompanyLink .companyLink {
	position: absolute;
	top: 0;
	right: 0;
}
footer .ftrCompanyLink .companyLink li {
	float: left;
	margin-left: 20px;
}
footer .ftrCopy {
	margin: 0 auto;
	padding: 20px 0;
	text-align: right;
	display: none;
}

@media only screen and (max-width:1000px){
	footer img { max-width: 100%;}
	
	footer .meiwaLink {
		margin-top: 0;
		border-top: 1px solid #E1E1E1;
		margin-bottom: 0;
	}
	footer .meiwaLink li {
		border: 1px solid #E1E1E1;
		border-width: 0 0 1px 0;
		width: 100%;
	}
	footer .ftrCompanyLink {
		text-align: center;
		padding: 20px 10px 0 10px;
		border-bottom: 1px solid #E1E1E1;
		margin-bottom: 0;
	}
	footer .ftrCompanyLink .companyLink {
		position: static;
		margin-top: 20px;
	}
	footer .ftrCompanyLink .companyLink li {
		float: none;
		margin: 10px 0;
	}
	footer .ftrCopy { text-align: center;}
}

/* ?եå??`??E?? */
.site-footer .foot-navi li a span{
	position: relative;
    display: inline-block;
}
.site-footer .foot-navi li a span::after {
    position: absolute;
    bottom: -5px;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #fff;
    transform: scale(0, 1);
    transform-origin: center top;
    transition: transform .3s;
}
.site-footer .foot-navi li a:hover span::after {
    transform: scale(1, 1);
    transition: transform .3s;
}
.site-footer .foot-navi li.on a span::after { transform: scale(1, 1);}

/*==================================================================
	Foot caption setting
===================================================================*/
.foot_caption {
	background: #fff;
	color: #4d4d4d;
	font-size: 10px;
	line-height: 1.4;
	padding: 60px 15px;	
	position: relative;
	z-index: 1;
}
.foot_caption a { color: #4d4d4d;}
.foot_caption ul {
	margin: 0 auto;
	max-width: 1170px;
}
.foot_caption ul li {
	padding-left: 1em;
	text-indent: -1em;
}
.foot_caption ul li.no_indent {
	padding-left: 0;
	text-indent: 0;
}
@media only screen and (max-width: 767px) {
	.foot_caption { padding: 15px 15px;}
}
/*==================================================================
	Contents setting
===================================================================*/
body #container {
	background-color: #fff;
    color: #4D4D4D;
	width: 100%;
	box-sizing: border-box;
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	text-align: left;
}
img {
	max-width: 100%;
	height: auto;
}
.inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 15px;
}
.pageTop {
	position: fixed;
	right: 0;
	bottom: 0;
	width: 40px;
	z-index: 100;
}
@media only screen and (max-width: 1000px) {
	.pageTop { width: 40px;}
	.pageTop img {
		width: 100%;
		height: auto;
	}	
}

/* print */
@media print {
	.site-header,
	.global-navi-base,
	.site-footer {
		display: none;
	}
}
.pos_rel { position: relative;}
.pic_cap {
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 20;
	color: #000 !important;
	font-size: 10px;
	line-height: 1.0 !important;
	padding: 5px;
}
.pic_cap.l_side {
	right: auto;
	left: 0;
}
.pic_cap.bg {
	background: rgba(0, 0, 0, .50);
	color: #fff !important;
}
.pic_cap.w { color: #fff !important;}
@media only screen and (min-width: 1001px) {
	.pic_cap.r_side { right: 65px;}
}
.caption {
	color: #000 !important;
	font-size: 10px;
	line-height: 1.2 !important;
}

/* Swipe icon */
.swipe_scroll{position: relative;}
.swipe_icon {display: none;}

@media only screen and (max-width: 767px) {
	.swipe_scroll {
		overflow-x: auto;
		padding-bottom: 15px;
	}
	.swipe_scroll img {
		width: 768px !important;
		max-width: inherit;
	}
	.swipe_icon {
		position: absolute;
		top: 50%;
		left: 50%;
		width: 70px;
		height: 70px;
		display: block;
		margin: -35px;
		animation:horizontal 1s ease-in-out infinite alternate;
		z-index: 10;
	}
	.swipe_icon img {
		max-width: 100%!important;
		width: 70px!important;
	}
	@keyframes horizontal {
		0% { transform:translate(-20%,-20%); }
		100% { transform:translate(30%,-20%); }
	}
}

.nolink { pointer-events: none;}
a.disabled{ pointer-events: none;}
@media only screen and (min-width: 1024px) and (max-width: 1366px) {
	header .tools li.links { padding-right: 0px;}
	header .tools li.links a { letter-spacing: 0.05em;}
}	

.tab_only {display: none !important; }
@media only screen and (min-width: 768px) and (max-width: 1366px) {
	.tab_only {display: block !important;}
}
/* IE11 */
@media all and (-ms-high-contrast:none){
	.site-footer .foot-navi ul li.new a:before { top: -24px;}
}
.businessHours li{ padding-bottom: 13px;}
.businessHours li:nth-child(2){ margin-top: -3px;}

/*instagram*/
.pc_only_insta_bnr{display: block;}
.sp_only_insta_bnr{display: none;}
@media only screen and (max-width: 1000px) {
	.pc_only_insta_bnr{display: none;}
	.sp_only_insta_bnr{display: block;}	
}
.insta_logo{
	margin: 0 auto;
	max-width: 450px;
	padding: 20px 0;	
}
@media only screen and (max-width: 1000px) {
	.insta_logo{
		margin: 0 auto;
		max-width: 330px;
		padding: 40px 0;
	}
	.insta_btn{
		margin: 0 auto;
		max-width: 290px;
		padding: 10px 0 30px;
	}
}

/*==================================================================
	Common page setting
===================================================================*/

/* */
.fs10{font-size: 10px;}
.fs12{font-size: 12px;}
.d_inline_block{
	display: inline-block;
}

/* zoom_modalWrap */
.modaal-container { background: #1e262b;}
.zoom_modalWrap { position: relative;}
.zoomIcon { display: none;}
.zoomIcon {
    width: 30px;
    height: 30px;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    padding: 5px;
    border: 1px solid #ffffff;
    background-color: #a1a1a1;
}
.modaal-wrapper .modaal-close {
	background-color: #a1a1a1;
	border: 1px solid #ffffff;
}
a.zoom_modalOpen {
    pointer-events: none;
    display: block;
}
.modal_swipeWrap {
    position: relative;
    overflow-y: hidden;
    overflow-x: auto;
}
.modal_swipeWrap > figure > img {
    max-width: none;
    width: 100%;
}
.swipeIcon {
    display: none;
    position: absolute;
    top: 45%;
    left: 25%;
    z-index: 3;
    width: 100px;
    animation: swipeAnimation 1s ease-in-out infinite alternate;
}
.modaal-wrapper * { margin: 0 !important;}
@keyframes swipeAnimation {
    0% {
        transform: translate(-30%, -50%);
    }
    to {
        transform: translate(-70%, -50%);
    }
}
@media only screen and (max-width: 767px) {
    .zoomIcon { display: block; }
    a.zoom_modalOpen { pointer-events: auto; }
    .modaal-content-container { padding: 0px !important;}
    .modal_swipeWrap > figure > img {
        max-width: none;
        width: 800px !important;
    }
    .swipeIcon { display: block;}
}
.slick-slide { outline: none !important;}
.c-white { color: #FFF;}
.main-lower {
	background: url(../imgs/bg_main_lower.jpg) no-repeat center center / cover;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 325px;
	text-align: center;
}
.main-lower h2 {
	color: #ddd9d4;
	display: flex;
	flex-direction: column;
	gap: 12px;
	letter-spacing: 0.16em;
}
.main-lower h2 .jp {
	font-size: 1.6rem;
}
.main-lower h2 .en {
	font-size: 4.2rem;
}
@media screen and (max-width:1000px){
	.main-lower {
		min-height: 125px;
	}
	.main-lower h2 {
		gap: 0;
	}
	.main-lower h2 .jp {
		font-size: 1.4rem;
	}
	.main-lower h2 .en {
		font-size: 3.2rem;
	}
}
.wood-bg {
	background: url(../imgs/bg_content_lower.jpg) repeat-y center top / cover;
}

.bg_color01 {
	background: url(../imgs/bg_color01.jpg) no-repeat left center / cover;
	position: absolute;
	z-index: -1;
	opacity: 0;
	transition: all 1s linear;
	transition-delay: 1.5s;
}
.bg_color02 {
	background: url(../imgs/bg_color02.jpg) no-repeat center center / cover;
	position: absolute;
	z-index: -1;
	opacity: 0;
	transition: all 1s linear;
	transition-delay: 1.75s;
}
.on .bg_color01 { opacity: 1;}
.on .bg_color02 { opacity: 1;}
.line_style {
	border: 5px solid #ddd9d4;
	position: absolute;
	z-index: -1;
	overflow: hidden;
	transition: all 1s cubic-bezier(0.4, 0, 0.2, 1);
	transition-delay: 0.5s;
}
.on .line_style { clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);}
.lines_v01 {
	height: calc(100% + 265px);
	width: 65px;
	left: 0;
	top: -265px;
	clip-path: polygon(0 0, 100% 0, 100% 0%, 0 0%);
}
.lines_v02 {
	height: calc(100% + 70vh);
	width: 50vw;
	right: calc(100% + 55px);
	top: calc(100% - 95px);
	clip-path: polygon(0 0, 100% 0, 100% 0%, 0 0%);
}
.lines_h01 {
	height: 45px;
	width: 120vw;
	left: -30vw;
	top: 100%;
	clip-path: polygon(0 0, 0% 0, 0% 100%, 0 100%);
}
.lines_h02 {
	height: 45px;
	width: 70px;
	left: -160px;
	top: 100%;
	clip-path: polygon(0 0, 0% 0, 0% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
	.line_style { border-width: 2px;}
	.lines_v01 {
		height: calc(100% + 45px);
		width: 60px;
		top: -45px;
	}
	.lines_v02 {
		height: calc(100% + 40vh);
		height: calc(100% + 150px) !important;
		right: calc(100% + 18px);
		top: calc(100% - 40px);
	}
	.lines_h01 {
		height: 20px;
		width: 100vw;
		left: -68px;
	}
	.lines_h02 {
		height: 20px;
		width: 100px;
		left: -156px;
	}
}
.headline .cont {
	padding-top: 145px;
	padding-left: 95px;
	padding-bottom: 110px;
	position: relative;
	z-index: 0;
	max-width: 900px;
	margin: auto;
}
.headline .cont .c_top { padding-bottom: 30px; }
.headline .cont .c_bot { padding-top: 50px; }
.headline .ttl {
	font-size: 2.4rem;
	letter-spacing: 0.06em;
	margin: 0 0 15px;
	color: #b3aca1;
}
.headline .ttl_jp {
	font-size: 2rem;
	letter-spacing: 0.1em;
	line-height: 2;
	color: #38322c;
}
.headline .txt {
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	line-height: 2.4;
	color: #4b483b;
}
.headline.white .txt,
.headline.white .ttl_jp {
	color: #fff;
}
.headline.white .line_style { border-color: #7d7566;}
.ver01 .lines_v01 {
	border-left: none;
	border-top: none;
	right: calc(100% + 55px);
	top: -315px;
	height: calc(100% + 395px);
	width: 80px;
	left: auto;
}
.ver01 .lines_v02 {
	width: 40px;
	border-right: none;
	border-bottom: none;
	top: -150px;
	height: 405px;
}
.ver01 .lines_h01 {
	border-top: none;
	border-right: none;
	left: -135px;
	top: auto;
	bottom: -5px;
	z-index: 1;
}
.ver01 .lines_h02 {
	border-left: none;
	border-bottom: none;
	border-right: none;
	left: auto;
	width: calc(100% + 10vw);
	bottom: -5px;
	top: auto;
	right: calc(100% + 92px);
}
.ver01 .lines_h02 .bg_color01 {
	width: 40px;
	height: 40px;
	top: 0;
	right: 0;
}
.ver01 .lines_v01 .bg_color02 {
	width: 35px;
	height: 75px;
	bottom: 0;
	right: 0;
}
.ver02 .cont {
	padding-left: 0 !important;
	padding-right: 65px !important;
	display: flex;
	justify-content: flex-end;
}
.ver02 .lines_v01 {
	border-left: none;
	border-top: none;
	right: -68px;
	top: auto;
	height: 406px;
	width: 37px;
	bottom: -146px;
	left: auto;
}
.ver02 .lines_v02 {
	border-right: none;
	border-bottom: none;
	height: 403px;
	width: 80px;
	right: -110px;
	top: -88px;
}
.ver02 .lines_h01 {
	height: 45px;
	width: 100vw;
	left: auto;
	top: 100%;
	border-left: none;
	border-bottom: none;
	z-index: -2;
	right: -112px;
}
.ver02 .lines_h02 {
	height: 45px;
	width: 100vw;
	left: calc(100% + 66px);
	top: 100%;
	border-top: none;
	border-right: none;
	border-left: none;
}
.ver02 .lines_h01 .bg_color01 {
	width: 45px;
	height: 40px;
	top: 0;
	right: 0;
	left: auto;
}
.ver02 .lines_v02 .bg_color02 {
	width: 28px;
    height: 84px;
	bottom: 0;
	right: 0;
	top: 0;
	left: 0;
}
.ver03 {
	display: flex;
	justify-content: flex-end;
}
.ver03 .cont {
	padding-left: 35px !important;
	padding-right: 65px !important;
}
.ver03 .lines_v01 {
	border-right: none;
    border-top: none;
    right: -68px;
    height: 296px;
    width: 50px;
    left: auto;
    top: auto;
    bottom: -90px;
}
.ver03 .lines_v02 {
	border-top: none;
    border-right: none;
    border-bottom: none;
    height: 425px;
    width: 5px;
    right: -70px;
    top: 40px;
}
.ver03 .lines_h01 {
	height: 45px;
	width: 50vw;
	left: auto;
	top: 100%;
	border-left: none;
	border-top: none;
	z-index: -2;
	right: -165px;
}
.ver03 .lines_h02 {
	height: 80px;
    width: 100vw;
    left: calc(100% + -68px);
    top: 100%;
    border-right: none;
    border-bottom: none;
}
.ver03 .lines_h02 .bg_color02 {
	width: 83px;
	height: 35px;
	top: 0;
	right: 0;
	left: 0;
}
.ver03 .lines_v01 .bg_color01 {
	width: 47px;
    height: 41px;
	bottom: 0;
	right: 0;
	left: 0;
}
.ver04 .cont {
	padding-left: 135px !important;
	padding-right: 65px !important;
	padding-bottom: 85px;
}
.ver04 .lines_v01 {
	border-left: none;
	border-top: none;
	right: -65px;
	top: -360px;
	height: calc(100% + 450px);
	width: 65px;
	bottom: -90px;
	left: auto;
}
.ver04 .lines_v02 {
	border-right: none;
	border-bottom: none;
	height: calc(100% + 63vh);
	width: 35px;
	right: -65px;
	top: -100px;
}
.ver04 .lines_h01 {
	height: 45px;
	width: 100vw;
	left: auto;
	top: 100%;
	border-left: none;
	border-bottom: none;
	z-index: -2;
	right: -160px;
}
.ver04 .lines_h02 {
	height: 45px;
	width: calc(100% + (100vw - 1215px)/2);
	left: calc(100% + 30px);
	top: 100%;
	border-top: none;
	border-right: none;
}
.ver04 .lines_h01 .bg_color01 {
	width: 90px;
	height: 40px;
	top: 0;
	right: 0;
	left: auto;
}
.ver04 .lines_v01 .bg_color02 {
	width: 28px;
	height: 42px;
	bottom: 0;
	right: 0;
	left: auto;
}
.headline.ver05 .cont {
	max-width: 440px;
	padding-top: 205px;
	padding-bottom: 75px;
}
.ver05 .lines_v01 {
	border-right: none;
	border-top: none;
	right: calc(100% + 15px);
	top: -310px;
	height: calc(100% + 395px);
	width: 80px;
	left: auto;
}
.ver05 .lines_v02 {
	width: 40px;
	border-left: none;
	border-bottom: none;
	top: -115px;
	height: 100vh;
}
.ver05 .lines_h01 {
	border-right: none;
	border-bottom: none;
	left: -190px;
	top: auto;
	bottom: -40px;
	z-index: 1;
}
.ver05 .lines_h02 {
	border-left: none;
	border-top: none;
	border-right: none;
	left: auto;
	width: calc(100% + 100vw);
	bottom: -42px;
	top: auto;
	right: calc(100% + 60px);
}
.ver05 .lines_h01 .bg_color01 {
	width: 90px;
	height: 37px;
	top: 0;
	left: 0;
}
.ver05 .lines_v01 .bg_color02 {
	width: 32px;
	height: 38px;
	bottom: 0;
	left: 0;
}
@media screen and (max-width: 1200px) {
	.headline .cont {
		width: calc(100% - 100px);
		margin-left: auto;
		padding-top: 100px;
		padding-bottom: 100px;
		order: 1;
	}
	.headline.ver05 .cont {
		padding-top: 100px;
		padding-bottom: 100px;
	}
}
@media screen and (max-width: 1024px) {
	.headline .ttl {
    	font-size: 2rem;
		margin: 0 0 10px;
	}
	.headline .ttl_jp {
   		font-size: 1.6rem;
		letter-spacing: 0.01em;
	}
	.headline .txt {
		font-size: 1.2rem;
		line-height: 2.2;
		letter-spacing: 0.01em;
	}
	.headline .cont .c_top { padding-bottom: 20px;}
	.headline .cont .c_bot { padding-top: 30px;}
	.ver04 .cont {
		padding-left: 0!important;
		max-width: 550px;
	}
}
@media screen and (max-width: 767px) {
	.headline .cont .c_bot { padding-top: 20px; }
	.headline .ttl_jp {
   		font-size: 1.4rem;
		letter-spacing: 0.01em;
	}
	.headline .cont {
		width: calc(100% - 20px);
		padding-left: 40px;
		padding-bottom: 60px;
		padding-top: 60px;
		margin-left: auto;
        margin-right: 0;
	}
	.ver01 .lines_v02 {
		width: 20px;
		top: -80px;
		right: calc(100% + 30px);
	}
	.ver01 .lines_v01 {
		right: calc(100% + 28px);
		top: -140px;
		height: calc(100% + 185px);
		width: 42px;
	}
	.ver01 .lines_v01 .bg_color02 {
		width: 20px;
		height: 42px;
	}
	.ver01 .lines_h01 {
		left: -70px;
		bottom: -2px;
	}
	.ver01 .lines_h02 {
		width: 100px;
		bottom: -2px;
		top: auto;
		right: calc(100% + 48px);
	}
	.ver01 .lines_h02 .bg_color01 {
		width: 20px;
		height: 20px;
	}
	.ver02 .cont {
        display: block;
        margin-left: 0;
        margin-right: auto;
		padding-right: 40px !important;
    }
	.ver02 .lines_h01 {
		height: 20px;
		right: -70px;
	}
	.ver02 .lines_v02 {
        width: 42px;
        left: calc(100% + 28px);
        right: auto;
		top: -44px;
    }
	.ver02 .lines_v02 .bg_color02 {
		width: 20px;
		height: 42px;
	}
	.ver02 .lines_h01 .bg_color01 {
		width: 17px;
        height: 18px;
	}
	.ver02 .lines_h02 {
		height: 20px;
		left: calc(100% + 50px);
	}
	.ver02 .lines_v01 {
		width: 42px;
		right: -52px;
		bottom: -80px;
	}
	.ver03 .cont {
		padding-right: 40px !important;
		margin-left: 0;
        margin-right: auto;
	}
	.ver03 .lines_v01 {
		width: 20px;
        left: calc(100% + 105px);
        top: auto;
        bottom: -40px;
        right: auto;
		height: 180px;
	}
	.ver03 .lines_h02 {
		height: 40px;
		width: 100vw;
		left: calc(100% + 73px);
	}
	.ver03 .lines_h02 .bg_color02 {
		width: 30px;
		height: 16px;
	}
	.ver03 .lines_h01 {
    	height: 20px;
        right: auto;
        left: calc(100% - 40px);
	}
	.ver03 .lines_v01 .bg_color01 {
		width: 20px;
		height: 20px;
	}
	.ver03 .lines_v02 {
		right: -130px;
		top: 18px;
	}
	.ver04 .cont {
		padding-left: 0 !important;
		padding-right: 40px !important;
		margin-left: 0;
        margin-right: auto;
	}
	.ver04 .lines_v01 .bg_color02 {
		width: 20px;
		height: 20px;
		bottom: -2px;
		right: -2px;
		left: auto;
	}
	.ver04 .lines_v02 {
		right: -40px;
		top: -40px;
		width: 20px;
	}
	.ver04 .lines_h01 {
		height: 20px;
		width: 100vw;
		left: auto;
		right: -70px;
	}
	.ver04 .lines_h01 .bg_color01 {
		width: 30px;
		height: 20px;
	}
	.ver04 .lines_h02 {
		height: 20px;
		width: 50vw;
		left: calc(100% + 38px);
	}
	.ver04 .lines_v01 {
        right: -40px;
        top: -65px;
        height: calc(100% + 105px);
        width: 40px;
        bottom: auto;
        left: auto;
    }
	.headline.ver05 .cont {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	.ver05 .lines_h01 { 
		left: -70px;
		bottom: -20px;
	}
	.ver05 .lines_h01 .bg_color01 {
		width: 30px;
		height: 20px;
	}
	.ver05 .lines_v01 {
		right: calc(100% + 4px);
		top: auto;
        bottom: -42px;
		height: calc(100% + 395px);
		width: 35px;
		left: auto;
	}
	.ver05 .lines_v01 .bg_color02 {
		width: 18px;
        height: 20px;
	}
	.ver05 .lines_h02 {
		bottom: -21px;
		right: calc(100% + 20px);
	}
	.ver05 .lines_v02 {
    	width: 20px;
		top: -80px;
	}
}

/* */
.fs15{font-size: 15px !important;}