@charset "utf-8";
/*==================================================================
	Import setting
===================================================================*/
@import url("import/reset.css");
@import url("import/util.css");
@import url('https://fonts.googleapis.com/css2?family=Italiana&family=Noto+Serif+JP:wght@200..900&family=Shippori+Mincho&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Infant:ital,wght@0,300..700;1,300..700&display=swap');
.cormorant {font-family: "Cormorant Infant", serif;}
/*==================================================================
	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: #333333;
	font-size: 14px;
	line-height: 1.71;
	letter-spacing: 0.1em;
	font-family: "Noto Serif JP", serif;
}
.italiana { font-family: "Italiana", sans-serif;  }
.mincho { font-family: "Shippori Mincho", serif;}
.blue { color:#2c3340; }
.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;}
.btns .btn_viewmore .btn {
	width: 140px;
	height: 30px;
	letter-spacing: 0.1em;
	padding: 5px;
	padding-right: 30px;
}
.btns .btn_viewmore .btn .arrow {
    border-radius: 30px;
    width: 30px;
    height: 30px;
}
.btns .btn_viewmore .btn:after {
	height: 30px;
	border-radius: 30px;
}
.btns .btn_viewmore .btn .letter { font-size: 1.2rem;}
.btns li { overflow: hidden;}
.btns li + li { margin-left: 15px;}
@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 {
		background: -o-linear-gradient(320deg, rgba(14, 12, 8, 1) 0%, rgba(78, 88, 105, 1) 35%, rgba(14, 12, 8, 1) 100%);
		background: linear-gradient(130deg, rgba(14, 12, 8, 1) 0%, rgba(78, 88, 105, 1) 35%, rgba(14, 12, 8, 1) 100%);
		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 { background: transparent;}
	#btn-hambeger .txt {
		font-size: 1.2rem;
		line-height: 1;
		letter-spacing: 0.1em;
		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(30deg);
		margin-bottom: 0;
		position: absolute;
		top: 55%;
		left: 25%;
		width: 50%;
	}
	#btn-hambeger.active .lines span:nth-child(3) {
		transform: rotate(-30deg);
		margin-top: 2px;
		position: absolute;
		top: 55%;
		left: 25%;
		width: 50%;
	}
}
@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: 22px;
		max-width: 300px;
		margin-top: 0 !important;
	}
	header .title .clio.sp {
		display: block !important;
		margin: 0 auto 15px auto;
		width: auto;
		height: 25px;
	}
	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); 
		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;
		border: 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 {
		box-sizing: border-box;
		border: none;
	}
	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;
	transition: opacity 1s;
	opacity: 0;
	background: #2c3340;
}
.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: 600px;
	margin: auto;
}
.global-navi .block02 .links li {
	width: calc(100%/3);
	padding-bottom: 0;
	margin-bottom: 60px;
	position: relative;
}
.global-navi .block02 .links li.select span.en{
	letter-spacing: -0.05em;
}
.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: "Italiana", sans-serif;
	display: none;
	position: absolute;
	font-size: 1.3rem;
	color: #fff;
	transform: translateY(-50%);
	padding: 3px 8px 0;
	top: -8px;
	margin-top: 0;
	letter-spacing: 0.01em;
	line-height: 1.25;
	color: #98dfe2;
}
.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;
	letter-spacing: 0.1em;
	opacity: 0;
	transition: all 0.5s;
}
.global-navi .block02 .links a span.en { opacity: 1; font-size: 1.8rem;}
.global-navi .block02 .links a span.ja { opacity: 0; font-size: 1.7rem;}
.global-navi .block02 .links li.on a,
.global-navi .block02 .links a:hover { 
	color: #47b9d7;
}
.global-navi .block02 .links a:hover .en,
.global-navi .block02 .links li.on a .en { opacity: 0;}

.global-navi .block02 .links a:hover .ja,
.global-navi .block02 .links li.on a .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: 600px;
	margin-left: auto;
	margin-right: auto;
	margin: 7.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 .contact {
	display: flex;
	margin-top: 45px;
}
/* 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;
	color: #47b9d7;
	font-size: 110%;
} */
/*.global-navi .links a::after {
    content: "";
    display: none;
    position: absolute;
	left: -30px;
	top: 50%;
	height: 0px;
	background: #fff;
	width: 20px;
	transition: all 0.5s;
	top: 14px;
}
.global-navi .links li.on a::after, .global-navi .links li a:hover:after {
    display: block;
	height: 1px;
	transition: all 0.5s;
}*/

/* ----------------------------------------
 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: #2c3340;
		font-size: 1rem;
		font-family: "Italiana", sans-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: #2c3340;
}
.site-footer .infoes .infoes-base {
	position: relative;
	min-height: 70px;
}
.site-footer .infoes .base {
	border-top: 1px solid #fff;
	position: relative;
	padding: 25px 0 15px;
	left: 0;
	bottom: 0;
	width: 100%;
}
.site-footer .infoes .base.fixed {
	position: fixed;
	z-index: 99;
	padding: 25px 0 15px;
	background: #2c3340;
	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: 195px; */
}
.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;
}
.infoes .site-footer .links li:first-child { margin-bottom: 0px;}
.site-footer .links a { color: #47b9d7;}
.site-footer .contact {
	margin-bottom: 0;
    padding: 0 0 0;
    float: left;
    width: 38%;
    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 .infoes img { max-width: 190px;}
}
@media screen and (min-width: 1001px) {
	.site-footer .contact .number span.pc { display: inline-block !important;}
	.site-footer .infoes .infoes-base .inner { display: flex;}
	.site-footer .links {
        order: 1;
        position: relative;
        top: 10px;
    }
	.site-footer .btns {
		order: 2;
		flex: 1;
        display: flex;
        justify-content: flex-end;
		align-items: center;
	}
	.site-footer .btns.clearfix:after { display: none;}
}
.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;
}
.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;
	}
	.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: #2c3340;
		font-size: 1rem;
		font-family: "Italiana", sans-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 ;
	}
	.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: 30px;
}
footer .ftrCompanyLink .companyLink img {
	height: 40px;
}
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;
		position: relative;
	}
	footer .ftrCopy { text-align: center;}
	footer .ftrCompanyLink .companyLink li + li {
		padding: 20px 0 0;
	}
	footer .ftrCompanyLink .companyLink li + li::before {
		content: "";
		height: 1px;
		background-color: #E1E1E1;
		width: calc(100% + 20px);
		position: absolute;
		top: 0;
		left: -10px;
	}
}
/* ?եå??`??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: #ffffff;}
.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: #323232;
	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_cap02 {
	position: absolute;
	bottom: 40px;
	right: 80px;
	z-index: 20;
	color: #fff !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%); }
	}
	.pic_cap02 {
		position: absolute;
		bottom: 20px;
		right: 20px;
	}
}

.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;
}
.btn_viewmore .btn {
    color: #2c3340;
    display: inline-block;
    width: 220px;
    height: 50px;
    padding: 15px;
    border-radius: 50px;
    background: #e6e6e6;
    text-align: center;
    padding-right: 50px;
    position: relative;
    overflow: hidden;
}
.btn_viewmore .btn .letter {
    font-size: 1.4rem;
    display: inline-block;
    position: relative;
    overflow: hidden;
    z-index: 10;
}
.btn_viewmore .btn .letter span {
    display: block;
    transition: transform .75s cubic-bezier(.19,1,.22,1);
    position: relative;
}
.btn_viewmore .btn .letter span:nth-child(1) { animation: textRollOvera .75s cubic-bezier(.19,1,.22,1) forwards;}
.btn_viewmore .btn:hover .letter span:nth-child(1) { animation: textRollOverb .75s cubic-bezier(.19,1,.22,1) forwards;}
.btn_viewmore .btn .letter span:nth-child(2) {
    color: #fff;
    height: 100%;
    position: absolute;
    width: 100%;
    top: 100%;
    left: 0;
    opacity: 0;
}
.btn_viewmore .btn:hover .letter span:nth-child(2) { 
    transition-delay: 0.15s;
    transform: translateY(-100%);
    opacity: 1;
}
.btn_viewmore .btn .arrow {
    border-radius: 50px;
    display: inline-block;
    width: 50px;
    height: 50px;
    background: #4b94aa url(../imgs/icon_arrow_w.png) no-repeat center center / 40% auto;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
}
.btn_viewmore .btn:after {
    content: "";
    border-radius: 50px;
    width: 0;
    height: 50px;
    background: #4b94aa;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 0;
    transition: all 1s cubic-bezier(.19,1,.22,1);
}
.btn_viewmore .btn:hover { opacity: 1;}
.btn_viewmore .btn:hover:after { width: 100%;}
@keyframes textRollOvera {
    0% {
        transform:translateY(100%)
    }
    to {
        transform:translateY(0)
    }
}
@keyframes textRollOverb {
    0% {
        transform:translateY(0)
    }
    to {
        transform:translateY(-100%)
    }
}
@media screen and (max-width: 1024px) {
    .btn_viewmore .btn {
        width: 180px;
        height: 40px;
        padding: 10px 5px;
        padding-right: 40px;
    }
    .btn_viewmore .btn .arrow {
        border-radius: 50%;
        width: 40px;
        height: 40px;
    }
    .btn_viewmore .btn .letter { font-size: 1.2rem;}
	.btn_viewmore .btn:after { height: 40px;}
}
/* 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;}

.unlink {
	opacity: 0.8;
	pointer-events: none;
}
.fadesplit_b {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.fadesplit_b .is_sup {
	font-size: 70%;
	letter-spacing: 0;
}
.ani_fadesplit > span {
	display: inline-block;
	-webkit-filter: blur(10px);
	filter: blur(10px);
	opacity: 0;
	-webkit-transform: rotateY(-60deg) translateX(10px) scale(1.1);
	transform: rotateY(-60deg) translateX(10px) scale(1.1);
	-webkit-transition: opacity 1.4s ease,-webkit-filter 1.4s ease,-webkit-transform 1.6s cubic-bezier(.215,.61,.355,1);
	transition: opacity 1.4s ease,filter 1.4s ease,transform 1.6s cubic-bezier(.215,.61,.355,1),-webkit-filter 1.4s ease,-webkit-transform 1.6s cubic-bezier(.215,.61,.355,1);
}
.on.ani_fadesplit > span,
.on .ani_fadesplit > span {
	-webkit-filter: blur(0);
	filter: blur(0);
	opacity: 1;
	-webkit-transform: rotateY(0) translateX(0) scale(1);
	transform: rotateY(0) translateX(0) scale(1);
}
#main_page {
	background-color: #f2f5fa;
	height: 300px;
	padding-bottom: 50px;
}
#main_page .main_wrap {
	background-color: #2c3340;
	position: relative;
	margin-left: 258px;
	height: 100%;
	display: flex;
	align-items: center;
	opacity: 0;
    visibility: hidden;
    transition: all 0.3s linear;
    position: relative;
}
.loaded #main_page .main_wrap {
    opacity: 1;
    visibility: visible;
}
#main_page .main_wrap::before {
	content: "";
	background: url(../imgs/main_icon.png) no-repeat top left/ auto 100%;
	width: 100%;
    height: 100%;
    display: block;
    position: absolute;
}
#main_page .main_head {
	display: flex;
	margin-left: 90px;
	position: relative;
	z-index: 2;
}
#main_page .ttl {
	font-size: 1.3rem;
	letter-spacing: 0.1em;
	color: #fff;
	line-height: 1.3;
}
#main_page .ttl .en {
	font-size: 616%;
	letter-spacing: 0.06em;
	color: #47b9d7;
	display: block;
}
#main_page .ttl .jp {
	display: block;
	text-align: right;
	transition: all 0.5s linear;
    filter: blur(10px);
    opacity: 0;
}
.loaded #main_page .ttl .jp {
    opacity: 0.8;
    filter: blur(0);
    transition-delay: 1.8s;
}
@media only screen and (max-width: 1000px) {
	#main_page { padding-bottom: 30px;}
	#main_page .main_wrap { margin-left: 12vw;}
	#main_page .main_head { margin-left: 30px;}
	#main_page .ttl {
		font-size: 1.2rem;
		text-align: center;
	}
	#main_page .ttl .en { font-size: 4.2rem;}
}
@media only screen and (max-width: 767px) {
	#main_page { height: 200px;}
	#main_page .main_head {
		margin-left: 0;
		margin-left: -6vw;
		display: block;
		width: 100%;
	}
	#main_page .ttl .en { font-size: 3.8rem;}
	#main_page .ttl .jp { text-align: center;}
}
.bg01 {
    background: #2c3340;
	color: #fff;
    position: relative;
}
.bg01::before {
    content: "";
    background: url(../imgs/bg01.png) no-repeat top left/ contain;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 37.5%;
    height: 100%;
    mix-blend-mode: luminosity;
}
.bg02 {
    background: #f2f5fa;
    position: relative;
}
.bg02::before {
    content: "";
    background: url(../imgs/bg02.png) no-repeat top right/ contain;
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    width: 39%;
    height: 100%;
    mix-blend-mode: difference;
}
.bg02.bg02_left::before {
    background: url(../imgs/bg02_left.png) no-repeat top left/ contain;
    left: 0;
	right: auto;
}
