@charset "UTF-8";
/*--------------------------------
reset
--------------------------------*/
html, body, div, p, img, iframe, a, span, blockquote, q, address, cite,
pre, code, em, small, strong, b, i,
header, article, section, nav, figure, figcaption, hgroup, menu, aside, footer, time,
h1, h2, h3, h4, h5, h6,
ul, ol, li, dl, dt, dd,
table, tbody, thead, tfoot, th, tr, td,
form, fieldset, legend, label, select, input, textarea, button {
	margin: 0;
	padding: 0;
	border: 0;
	box-sizing: border-box;
	vertical-align: baseline;
}

header, article, section, nav, figure, figcaption, hgroup, menu, aside, footer {
	display: block;
}

ul li {
	list-style-type: none;
}

a {
	text-decoration: none;
}

img {
	vertical-align: middle;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

select, option, input:not([type=checkbox]):not([type=radio]), textarea, button {
	font-family: inherit;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	outline: none;
}

blockquote::before, blockquote::after, q::before, q::after {
	content: "";
	content: none;
}

[type=submit], [type=button], [type=reset], [type=file], button {
	cursor: pointer;
}

:focus {
	outline: none;
}
sub,sup{
	font-size: 40%;
}

/*--------------------------------
common
--------------------------------*/
html{
	font-size: 62.5%;
}
body {
	margin: 0;
	padding: 0;
	background: #f8f9fa;
	font-family: "a-otf-ryumin-pr6n", serif;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1;
	color: #000;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
}

a {
	color: inherit;
	text-decoration: none;
	transition: all 0.3s ease;
	-webkit-tap-highlight-color: transparent;
}
a:hover {
	opacity: .7;
}

button,
[type=submit],
[type=reset] {
	transition: all 0.3s ease;
	-webkit-tap-highlight-color: transparent;
}

strong {
	color: #5b4e65;
	font-weight: inherit;
}

.vertical-text {
	writing-mode: vertical-rl;
	-webkit-text-orientation: upright;
	text-orientation: upright;
	-webkit-font-feature-settings: normal;
	font-feature-settings: normal;
}

.fit-img {
	width: 100%;
	height: auto;
	vertical-align: middle;
}

.has-max {
	height: auto;
	max-width: 100%;
}

.flex-wrapper {
	display: flex;
	flex-wrap: wrap;
}

.align-item-center {
	align-items: center;
}
.align-item-end {
	align-items: flex-end;
}

.justify-center {
	justify-content: center;
}

.justify-between {
	justify-content: space-between;
}

.justify-end {
	justify-content: flex-end;
}

.img-wrapper {
	position: relative;
}
.img-wrapper .caption {
	position: absolute;
	bottom: 0;
	left: 8px;
	right: 8px;
	z-index: 1;
}

.inline-block {
	display: inline-block;
}

.grid-wrapper {
	display: grid;
}
.svg-symbol{
	display: none;
}
.has-kei{
	display: flex;
	gap: 4px;
	align-items: center;
	justify-content: center;
}
.has-kei::before,
.has-kei::after{
	width: 80px;
	height: 1px;
	content: "";
	background: #8e84664a;
}
@media (max-width: 767px) {
	.has-kei::before,
	.has-kei::after{
		width: 40px;
	}
}

/*--------------------------------
layout
--------------------------------*/
.scroll-disabled {
	height: 100%;
	overflow: hidden;
}

.inner {
	margin: 0 auto;
	width: calc(100% - 64px);
	max-width: 1200px;
}
@media (max-width: 767px) {
	.inner {
		width: calc(100% - 48px);
	}
}

.inner-narrow {
	max-width: 900px;
}

.inner-wide {
	max-width: 1500px;
}

.inner-fit {
	width: 100%;
	max-width: none;
}

.inner-full {
	max-width: none;
}

.general-section {
	position: relative;
	overflow: hidden;
}
.general-section .inner {
	padding: 100px 0;
}
.map .general-section .inner:first-of-type,
.outline .general-section .inner:first-of-type {
	padding-top: 0;
}
@media (max-width: 991px) {
	.general-section .inner {
		padding: 32px 0;
	}
}
.general-section .inner + .inner {
	padding-top: 0;
}
.general-section .inner-min {
	padding: 32px 0;
}
@media (max-width: 991px) {
	.general-section .inner-min {
		padding: 16px 0;
	}
}

.general-parts {
	margin-bottom: 32px;
}

.btn-space {
	margin: 32px 0;
	text-align: center;
}
.btn-space.btn-small {
	margin: 0 auto;
	max-width: 500px;
}
.btn-version01 .general-btn{
	padding: 28px 24px;
	font-size: clamp(1.4rem, 4.1vw, 2.4rem);
}
@media (max-width: 767px) {
	.btn-version01 .general-btn{
		padding: 23px 5px;
	}
}
.has-gap {
	gap: 32px;
}
@media (max-width: 991px) {
	.has-gap {
		gap: 16px;
	}
}

.col-2 {
	width: 50%;
}
.has-gap > .col-2 {
	width: calc(50% - 16px);
}

.col-3 {
	width: calc(100% / 3);
}
.has-gap > .col-3 {
	width: calc(100% / 3 - 22px);
}

.col-4 {
	width: 25%;
}
.has-gap > .col-4 {
	width: calc(25% - 24px);
}

@media (max-width: 991px) {
	.col-2,
	.has-gap > .col-2 {
		width: 100%;
	}
	.col-3,
	.has-gap > .col-3 {
		width: 100%;
	}
	.col-4 {
		width: 50%;
	}
	.has-gap > .col-4 {
		width: calc(50% - 8px);
	}
	.sp-col-2 {
		width: 50%;
	}
	.has-gap > .sp-col-2 {
		width: calc(50% - 8px);
	}
}
/*--------------------------------
component
--------------------------------*/
.primary-heading {
	margin-bottom: 0.8em;
	font-size: clamp(2.2rem, 2.5vw ,4rem);
	font-weight: 400;
	line-height: 1.3;
}

.secondary-heading {
	margin-bottom: 0.8em;
	font-size: clamp(1.8rem, 1.875vw ,3rem);
	font-weight: 400;
	line-height: 1.3;
}

.tertiary-heading {
	margin-bottom: 0.8em;
	font-size: clamp(1.6rem, 1.25vw ,2rem);
	font-weight: 400;
	line-height: 1.3;
}
.page-title {
	padding: 12px 0;
	font-size: 3rem;
	font-weight: 400;
	line-height: 1.2;
}
.lead {
	font-size: 1.8rem;
	line-height: 1.5;
	letter-spacing: .05em;
}
@media (max-width: 991px) {
	.lead {
		font-size: 1.4rem;
	}
}
.note {
	margin-bottom: 1em;
	font-size: 1.6rem;
	line-height: 1.8;
}
@media (max-width: 991px) {
	.note {
		font-size: 1.2rem;
	}
}
.caption {
	margin: 0.4em 0;
	font-size: 1.2rem;
	line-height: 1.5;
}
@media (max-width: 767px) {
	.caption {
		font-size: 1rem;
	}
}

[type=text],
[type=search],
[type=password],
[type=tel],
[type=email],
[type=num],
[type=date],
select,
textarea {
	margin-right: 4px;
	padding: 12px 8px;
	max-width: 100%;
	background: #f2efe7;
	font-size: 1.6rem;
	font-weight: inherit;
	color: inherit;
	line-height: 1.3;
	border: 0;
	vertical-align: middle;
}
[type=text]:last-child,
[type=search]:last-child,
[type=password]:last-child,
[type=tel]:last-child,
[type=email]:last-child,
[type=num]:last-child,
[type=date]:last-child,
select:last-child,
textarea:last-child {
	margin-right: 0;
}
[type=text]:focus,
[type=search]:focus,
[type=password]:focus,
[type=tel]:focus,
[type=email]:focus,
[type=num]:focus,
[type=date]:focus,
select:focus,
textarea:focus {
	background-color: #fff;
}

select {
	padding: 6px 32px 6px 12px;
	background: url(images/select_arrow.png) no-repeat right 8px center #fff;
	background-size: 14px auto;
	text-indent: 0.01px;
	text-overflow: "";
	border: 1px solid #bfbfbf;
	border-radius: 10px;
}

textarea {
	min-height: 100px;
}

.text-150 {
	width: 150px;
}

.text-fit {
	width: 100%;
}

.arrow {
	width: 20px;
	height: 20px;
	display: block;
	background: url(../images/common/plus.svg) no-repeat center center;
	background-size: contain;
	transition: all 0.3s ease;
}

.btn {
	padding: 8px 16px;
	display: inline-block;
	text-align: center;
	vertical-align: middle;
}

.submit-btn {
	padding: 16px;
	min-width: 400px;
	background: transparent;
	color: #888;
	font-size: 1.4rem;
	border: 1px solid;
	border-radius: 30px;
}
@media (max-width: 991px) {
	.submit-btn {
		width: 100%;
		min-width: auto;
	}
}
.submit-btn:disabled {
	opacity: 0.3;
}
.submit-btn:hover:not(:disabled) {
	background: #888;
	color: #fff;
	border-color: #888;
}

.general-btn {
	margin: auto;
	padding: 16px 24px;
	max-width: 800px;
	display: flex;
	position: relative;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 6px;
	position: relative;
	z-index: 1;
	font-size: 2.2rem;
}
.general-btn:hover {
	color: #fff;
	filter: brightness(1.3) saturate(1.2);
}
.general-btn::after{
	position: absolute;
	inset: 4px;
	display: block;
	content: "";
	border: 1px solid rgba(255,255,255,.4);
	transition: .3s ease-out;
}
.general-btn:hover::after{
	inset: -4px;
	border-color: #666;
}
.btn-cap{
	font-size: 1.2rem;
}
@media (max-width: 767px) {
	.general-btn {
		font-size: 1.6rem;
	}
}
.request-btn{
	background: linear-gradient(90deg, #421314,#6F4B26 25%,#B1954F 60%,#EADCBA 95%);
	color: #fff;
}
.reserve-btn{
	background: linear-gradient(90deg, #333,#888 50% , #333);
	color: #fff;
}
.btn-inner{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 4px;
}
.btn-inner img{
	width: 16px;
}

.video-wrapper {
	position: relative;
	padding-top: 56.25%;
	height: 0;
	display: block;
	content: "";
}
.video-wrapper iframe,
.video-wrapper video {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
@media (max-width: 767px) {
	.video-wrapper {
		padding-top: 122.3%;
	}
}

.loading {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
	content: "";
}

.bg-light {
	background: #c6c2b2;
}

.bg-dark {
	background: #384250;
	color: #fff;
}

.bg-gray {
	background: #dce7ef;
}
@keyframes zoomIn2 {
	from {
		opacity: 0;
		transform: scale3d(1.3, 1.3, 1.3);
	}
	50% {
		opacity: 1;
	}
}
.zoomIn2 {
	animation-name: zoomIn2;
}
@keyframes blurIn {
	from {
	  opacity: 0;
	  filter: blur(20px);
	  transform: translate3d(0, 10px, 0) scaleX(1.2) skewX(-20deg);
	}
  
	to {
	  opacity: 1;
	  filter: blur(0);
	  transform: none;
	}
}
.blurIn {
	animation-name: blurIn;
}
@keyframes blurZoomIn {
	from {
		opacity: 0;
		filter: brightness(1.8) blur(20px);
		transform: scale3d(1.1, 1.1, 1.1);
	}
	50% {
		filter: brightness(1) blur(0);
		opacity: 1;
	}
}
.blurZoomIn {
	animation-name: blurZoomIn;
}
.cliping-mask{
	overflow: hidden;
}

/*--------------------------------
header
--------------------------------*/
.new::before {
    content: "new";
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translate(-50%,0);
    font-size: 1.1rem;
    background: #8D2041;
    color: #fff;
    padding: 2px 8px;
    animation: blink 3s linear infinite;
    z-index: 2;
}
.navigation-bar{
	height: 110px;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 5;
	background: url(../images/common/header-bg.webp) no-repeat center center;
	background-size: cover;
	/* transform: translateY(-110px);
	transition: all .3s ease-in-out;
    z-index: 100; */
}
.is-header-visible{
	transform: translateY(0);
}
#top .navigation-bar{
	transform: translateY(-110px);
	transition: all .3s ease-in-out;
    z-index: 100;
}
#top .is-header-visible{
	transform: translateY(0);
}
.header-logo{
	padding-left: 16px;
	width: 100%;
	height: 70px;
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	/* z-index: 1; */
}
.header-logo a{
	z-index: 1;
}
@media screen and (max-width: 1029px){
	.navigation-bar{
		height: 50px;
        z-index: 111;
	}
	.header-logo{
		height: 50px;
        z-index: 112;
	}
    .hamburger{
        z-index: 113;
    }
}
.header-logo .logo{
	width: 230px;
}
@media screen and (max-width: 1029px){
	.global-nav{
		padding-bottom: 60px;
        padding-top: 70px;
		width: 100%;
		height: 100vh;
		position: fixed;
		top: 0px;
		right: 0;
		bottom: 0;
		z-index: 4;
		background: #000;
		visibility: hidden;
		overflow: auto;
		transform: translateX(100%);
		transition: all .3s ease-in-out;
	}
	.is-menu-open .global-nav{
		visibility: visible;
		transform: translateX(0);
	}
	.header-logo .logo{
		width: 200px;
	}
}
.global-nav-inner{
	margin: 0 16px;
	padding: 70px 0 0;
	position: relative;
}
.global-nav-main{
	display: flex;
	justify-content: center;
}
.global-nav-upper{
	display: flex;
	flex-direction: row-reverse;
	position: absolute;
	top: 8px;
	right: 0;
}
@media screen and (max-width: 1029px){
	.global-nav-inner{
		padding: 0;
		padding-bottom: 10px;
	}
	.global-nav-main{
		display: block;
	}
	.global-nav-upper{
		flex-direction: column-reverse;
		position: relative;
	}
	.new::before {
		top: auto;
		left: 24px;
	}
}
.nav-list{
	margin: 0 8px;
}
.global-nav-main .nav-list{
	margin: 0;
	width: 150px;
	border-left: 1px solid #ccc;
}
.global-nav-main .nav-list:last-child{
	border-right: 1px solid #ccc;
}
.gnav-link{
	margin: 0 4px;
	padding: 4px 8px;
	display: inline-block;
	position: relative;
	color: #fff;
	white-space: nowrap;
}
.global-nav-main .gnav-link{
	display: block;
	text-align: center;
}
.active {
	color: #fff;
	background-color: #333;
}
.jp{
	margin-top: 4px;
	padding: 2px 8px;
	position: absolute;
	top: 50%;
	left: 50%;
	display: inline-block;
	background: #eee;
	color: #333;
	white-space: nowrap;
	transform: translate(-50%, -50%);
	transition: all .3s ease-out;
	opacity: 0;
}
@media screen and (max-width: 1029px){
	.nav-list{
		margin: 0;
	}
	.gnav-link{
		padding: 12px 0;
		width: 100%;
		text-align: center;
	}
	.jp{
		padding: 12px 8px;
		width: 100%;
		text-align: center;
	}
	.global-nav-main .nav-list{
		width: auto;
		border: none;
	}
	.global-nav-main .nav-list:last-child{
		border: none;
	}
}
.gnav-link:hover .jp{
	margin-top: 0;
	opacity: 1;
}
.nav-cta-group,
.nav-sub-group{
	display: flex;
	align-items: center;
}
.cta-btn{
	width: 150px;
	height: 36px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
    border: 1px solid #666;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .5);
}
@media screen and (max-width: 1029px){
	.nav-cta-group,
	.nav-sub-group{
		display: block;
	}
	.cta-btn{
		padding: 16px 0;
		width: 100%;
		height: 50px;
		text-align: center;
	}
}
.nav-sub-link{
	font-size: 1.2rem;
	color: #fff;
	transition: all 0.3s ease;
}
.nav-sub-link:hover{
	opacity: .7;
}
.nav-cta-group .nav-list{
	margin: 0 0 0 4px;
}
@media screen and (max-width: 1029px){
	.nav-sub-link{
		padding: 12px 0;
		display: block;
		font-size: 1.4rem;
		text-align: center;
	}
	.nav-cta-group .nav-list{
		margin: 0 0 8px;
	}
}
.hamburger{
	margin-top: 5px;
	width: 50px;
	height: 50px;
	display: none;
	position: absolute;
	right: 0;
	top: 0;
}
.hamburger .btn-label {
    font-size: 1rem;
    line-height: 1;
    color: #fff;
}
.hamburger i,
.hamburger::before,
.hamburger::after{
	width: 32px;
	height: 2px;
	position: absolute;
	left: 0;
	right: 0;
	display: block;
	background: #fff;
	content: "";
}
.hamburger i{
	margin: -1px auto 0;
	top: 50%;
	transition: all .2s ease-in-out;
}
.hamburger::before{
	margin: 0 auto;
	top: 16px;
	transition: all .2s ease-in-out;
}
.hamburger::after{
	margin: 0 9px 0 auto;
	width: 24px;
	bottom: 16px;
	transition: all .2s ease-in-out;
}
.is-menu-open .hamburger i{
	transform: rotate(45deg);
}
.is-menu-open .hamburger::before{
	margin-top: -1px;
	top: 50%;
	transform: rotate(-45deg);
}
.is-menu-open .hamburger::after{
	opacity: 0;
}
@media screen and (max-width: 1029px){
	.hamburger{
		display: flex;
    justify-content: center;
	}
}

/*--------------------------------
sp fixbtn
--------------------------------*/
.fix-btn {
	background-color: #1A0B08;
	position: fixed;
	width: 100%;
	left: 0;
	bottom: 0;
	z-index: 120;
	transform: translateY(80px);
	transition: 0.3s;
  }
  @media screen and (min-width: 768px) {
	.fix-btn {
	  display: none;
	}
  }
  .fix-btn.is-header-visible {
	transform: translateY(0);
	  height: auto;
  }
  .fix-btn ul {
	display: flex;
	height: 60px;
  }
  .fix-btn ul li {
	width: 33%;
	border-right: 1px solid rgba(255,255,255,.4);
  }
  .fix-btn ul li:last-child{
	border-right: none;
  }
  .fix-btn ul li a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	width: 100%;
	height: 100%;
  }
  .fix-btn ul li a span{
	color: #fff;
	font-size: 10px;
  }
  .fix-btn ul li a.none {
	pointer-events: none;
	opacity: 1;
  }
  .fix-btn ul li a.comm {
	position: relative;
		pointer-events: none;
  }
  .fix-btn ul li a.comm::before{
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	background-color: rgba(0,0,0,.6);
  }
  .fix-btn ul li a.comm:after {
	content: "COMING SOON";
	font-family: "Questrial", sans-serif;
	font-size: 3vw;
	line-height: 1;
	width: 100%;
	text-align: center;
	color: #fff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
  }

/*--------------------------------
footer
--------------------------------*/
.contents-nav{
	padding: 0 5vw;
}
.contents-nav .slick-list{
	overflow: visible;
    width: 100%;
}
.contents-nav .col-3{
	margin: 0 max(1.5vw, 16px);
}
.nav-thumb{
	position: relative;
	background: rgba(0,0,0,.1);
}
.nav-title{
	display: grid;
	place-items: center;
	position: absolute;
	inset: 0;
	z-index: 1;
	font-size: 3rem;
	color: #fff;
}
.nav-more{
	display: flex;
	position: absolute;
	right: -24px;
	bottom: 12px;
	z-index: 1;
	color: #fff;
	font-size: 1.8rem;
	transition: .3s ease-out;
}
.nav-more::after{
	width: 60px;
	height: 20px;
	display: block;
	content: "";
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(-45deg) skewX(-45deg);
}
@media screen and (max-width: 767px) {
	.nav-title{
		font-size: 2.4rem;
	}
	.nav-more{
		font-size: 1.4rem;
	}
}
.nav-heading{
	margin-top: 12px;
	font-size: 2rem;
	color: #8e8466;
}
.nav-note{
	margin-top: 8px;
	font-size: 1.4rem;
	letter-spacing: .1em;
	color: #8e8466;
}
.contents-nav-link:hover .fit-img{
	transform: scale(1.2) !important;
	filter: brightness(.8);
}
.contents-nav-link:hover .nav-more{
	bottom: 18px;
	right: -30px;
}
.footer-btn-space{
	padding: 0 16px 32px;
}
.caption-area{
	padding: 32px 0 ;
	border-top: 1px solid #ddd;
	background-color: #fff;
}
.banner-area{
	padding: 70px 0 40px;
	border-top: 1px solid #ddd;
	overflow: hidden;
}
.banner-mutual-container{
	width: 50%;
	margin: 0 auto 70px;
}
@media screen and (max-width: 767px) {
	.banner-mutual-container{
		width: 100%;
		margin-bottom: 45px;
	}
}
.banner-container{
	margin: 0 -12px;
}
.banner-container .slick-list{
	overflow: visible;
}
.banner-container .slick-dots{
	bottom: -32px;
}
.banner-container .slick-dots li{
	width: auto;
	height: auto;
}
.banner-container .slick-dots li button{
	background: #ddd;
	border-radius: 50%;
	width: 8px;
	height: 8px;
}
.banner-container .slick-dots li.slick-active button{
	background: #333;
}
.banner-container .slick-dots li button:before{
	content: none;
}
.banner-container .slick-prev,
.banner-container .slick-next{
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.8);
	width: 40px;
	height: 40px;
	top: 50%;
}
.banner-container .slick-prev{
	left: -10px;
}
.banner-container .slick-next{
	right: -10px;
}
.banner-container .slick-prev:before,.banner-container .slick-next:before{
	color: #fff;
	line-height: .4;
	font-size: 26px;
}
.banner-slide{
	margin: 0 12px;
}
@media screen and (max-width: 1250px){
	.banner-container{
		margin: 0 ;
	}
}
@media screen and (max-width: 767px){
	.banner-area{
		padding: 32px 0;
	}
	.banner-container{
		margin: 0 ;
	}
	.banner-container .slick-prev,
	.banner-container .slick-next{
		border-radius: 50%;
		background: rgba(0, 0, 0, 0.8);
		width: 36px;
		height: 36px;
		top: 50%;
	}
	.banner-container .slick-prev{
		left: -14px;
	}
	.banner-container .slick-next{
		right: -14px;
	}
	.banner-container .slick-prev:before,.banner-container .slick-next:before{
		font-size: 22px;
	}
}

.footer-wrapper{
	padding: 32px 0 0;
	border-top: 1px solid #ddd;
	background: #fff;
}
.footer-wrapper .flex-wrapper{
	justify-content: center;
	gap: 60px;
	flex-wrap: wrap;
}
.footer-inner-tel{
	margin-bottom: 16px;
}
@media screen and (max-width: 767px){
	.footer-wrapper{
		padding-bottom: 0;
	}
	.footer-inner-tel{
        width: 100%;
		margin-bottom: 20px;
	}
	.footer-wrapper .flex-wrapper{
		gap: 0;
	}
}
.tel-upper{
	margin-bottom: 8px;
	font-size: 1.6rem;
}
.tel-wrap{
	display: flex;
	align-items: baseline;
	gap: 8px;
	flex-wrap: wrap;
	font-style: normal;
}
.tel-wrap svg{
	margin-top: 4px;
	width: 50px;
}
.tel-num{
    display: block;
	font-size: 4.6rem;
	letter-spacing: .04em;
}
.tel-num:hover{
	color: #000;
}
.salon-info{
	margin-top: 7px;
	line-height: 1.3;
}
@media screen and (max-width: 767px){
	.tel-upper{
		font-size: 1.4rem;
		text-align: center;
	}
	.tel-wrap{
		justify-content: center;
	}
	.tel-num{
		font-size: 3rem;
	}
	.salon-info{
		margin: 8px auto;
		line-height: 1.3;
		text-align: center;
		font-size: 1.2rem;
	}
}
.footer-inner-logo{
	margin: 0 -16px;
	display: flex;
	align-items: flex-end;
}

.footer-logo{
	margin: 0 16px;
	font-size: 1rem;
}
@media screen and (min-width: 1251px){
	.footer-inner-logo{
		margin: 0;
		flex-wrap: wrap;
		width: 600px;
		justify-content: center;
		gap: 30px;
	}
	.footer-logo{
		margin: 0;
	}
	.footer-logo:nth-of-type(2){
		margin-bottom: 6px;
	}
	.footer-logo:nth-of-type(3){
		margin-bottom: 16px;
	}
}

@media screen and (max-width: 767px){
	.footer-inner-logo{
		flex-wrap: wrap;
		align-items: flex-start;
		margin-left: 18vw;
	}
	.footer-logo{
		margin-top: 16px;
	}
}
.logo-label{
	margin-bottom: 12px;
	white-space: nowrap;
}
.footer-logo:nth-of-type(2) .logo-label{
	margin-bottom: 18px;
}
.footer-logo:nth-of-type(3) .logo-label{
	margin-bottom: 10px;
}
.footer-copyright{
	margin-top: 40px;
	padding: 10px 0;
	text-align: center;
	font-size: 1.2rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Hiragino Sans", "Noto Sans CJK JP", "Yu Gothic", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Sans Emoji";
    font-weight: 300;
	background: url(../images/common/cr-bg.webp) no-repeat center center;
	background-size: cover;
	color: #fff;
}
@media screen and (max-width: 767px){
	.logo-label,
	.footer-logo:nth-of-type(2) .logo-label,
	.footer-logo:nth-of-type(3) .logo-label{
		margin-bottom: 6px;
	}
	.footer-copyright{
		font-size: 1rem;
		background: url(../images/common/cr-bg-sp.webp) no-repeat center center;
	}
}

/*--------------------------------
top
--------------------------------*/
.mv{
	height: calc(100vh - 80px);
	position: relative;
	overflow: hidden;
	transition: height 1s ease-out 2s, filter 3s ease-in-out;
}
@media screen and (max-width: 1120px){
	.mv{
		height: calc(100vh - 110px);
	}
}
.is-loading .mv{
	height: 100vh;
	filter: brightness(.4) saturate(1.5);
}
.main-copy{
	position: absolute;
	top: calc(50vh - 45px);
	left: 0;
	right: 0;
	color: #fff;
	transform: translateY(-50%);
	opacity: 1;
	filter: blur(0);
	transition: 1s ease-out 1s;
	text-shadow: 0 0 12px rgba(0, 0, 0, .4);
}
@media screen and (max-width: 767px){
	.mv,
	.is-loading .mv{
		height: calc(50vh + 40px);
	}
	.main-copy{
		top: calc(50%);
	}
}
.is-loading .main-copy{
	opacity: 0;
	filter: blur(10px);
}
.main-copy.is-hidden{
	opacity: 0;
	filter: blur(10px);
	transition-delay: 0s;
}
.main-copy-large{
	margin-bottom: 8px;
	font-size: max(6vw, 5rem);
	font-weight: 500;
	letter-spacing: .3em;
	text-indent: .3em;
}
.main-copy-lead{
	margin-bottom: 24px;
	font-size: max(1.4vw, 1.8rem);
}
.main-copy-cap{
	font-size: max(1.6vw, 2rem);
	text-indent: .4em;
	letter-spacing: .4em;
}
.sub-copy{
	position: absolute;
	top: calc(50vh - 45px);
	left: 0;
	right: 0;
	color: #fff;
	font-size: max(1.6vw, 2rem);
	text-indent: .2em;
	text-align: center;
	line-height: 2;
	letter-spacing: .4em;
	text-shadow: 0 0 12px rgba(0, 0, 0, .4);
	transform: translateY(-50%);
}
.slider-mv {
	position: absolute;
	inset: 0;
	z-index: 3;
	opacity: 0;
	transition: opacity 2s ease-out;
	overflow: hidden;
}

.slick-item-mv figure {
	margin: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.slick-item-mv figure img.first {
	width: 100%;
	height: auto;
}
.slick-item-mv figure img.first {
	animation: slideDown 6s ease-out forwards;
}
@keyframes slideDown {
	from {
		transform: translateY(-20%);
	}
	to {
		transform: translateY(-60%);
	}
}
@media screen and (max-width: 1720px){
	@keyframes slideDown {
		from {
			transform: translateY(-30%);
		}
		to {
			transform: translateY(-60%);
		}
	}
}
@media screen and (max-width: 1024px){
	@keyframes slideDown {
		from {
			transform: translateY(0);
		}
		to {
			transform: translateY(-10%);
		}
	}
}
@media screen and (max-width: 840px){
	@keyframes slideDown {
		from {
			transform: translateY(0);
		}
		to {
			transform: translateY(-2%);
		}
	}
}
@media screen and (max-width: 767px){
	@keyframes slideDown {
		from {
			transform: translateY(0);
		}
		to {
			transform: translateY(-22%);
		}
	}
}

.slick-item-mv figure img.second {
	width: 100%;
	transform: scale(1.2);
	transition: transform 6s ease-out;
}
.slick-item-mv.is-second figure img.second {
	transform: scale(1); 
}
@media screen and (min-width: 768px){
	.mv-slide .caption,
	.slider-mv .caption{
		bottom: 80px;
	}
	.mv-slide-version01 .caption{
		bottom: 80px;
	}
}
@media screen and (max-width: 1120px){
	.mv-slide .caption,
	.slider-mv .caption{
		bottom: 110px;
	}
}
@media screen and (max-width: 767px){
	.mv-slide .caption,
	.slider-mv .caption{
		bottom: 0;
	}
}
.object-fit{
	width: 100%;
	height: 100vh;
	object-fit: cover;
}
.mv-slide{
	position: absolute;
	inset: 0;
	opacity: 1;
	transition: 2.2s ease-in 3s;
}
@media screen and (max-width: 767px){
	.sub-copy{
		top: calc(50%);
	}
	.object-fit{
		height: calc(50vh + 40px);
	}
}
.is-loading .mv-slide{
	opacity: 0;
}
.home .main-container{
	padding: 100px 0;
	overflow: hidden;
}
.main-container{
	margin-top: 110px;
}
#top .main-container{
	margin-top: 0;
}

.loading-slide {
	position: absolute;
	inset: 0;
	z-index: 4;
	opacity: 1;
	transition: opacity 2s ease;
}
.loading-slide.is-fadeout {
	opacity: 0;
	pointer-events: none;
}
.loading-slide figure img {
	transform: scale(1.2);
	transition: transform 8s ease-out;
}
.loading-slide.is-zoom figure img {
	transform: scale(1); 
}

@media screen and (max-width: 767px){
	.home .main-container{
		padding: 12px 0 32px;
	}
	.main-container{
		margin-top: 50px;
	}
}
.huge-heading{
	margin-bottom: .4em;
	font-size: clamp(2.5rem, 3.125vw, 5rem);
	font-weight: 500;
	letter-spacing: .1em;
}
.property-lead{
	margin-bottom: 0;
}
.property-lead .caption{
	margin-top: -4px;
}
.access-line{
	margin-bottom: 64px;
}
.bg-texture{
	background: url(../images/common/texture.jpg);
	background-size: 150px;
}
.kodo-box-wrap.secondary-heading{
	font-size: clamp(2rem, 2.875vw, 4rem);
}
.kodo-box{
	border: 1px solid #8e8466;
	color: #8e8466;
	padding: .4em 1.6em;
	position: relative;
}
.kodo-box::after {
    position: absolute;
    inset: 4px;
    display: block;
    content: "";
    border: 1px solid #8e8466;
    transition: .3s ease-out;
}
.presentation{
	margin: 0 auto;
	padding: 4px;
	max-width: 650px;
	width: calc(100% - 48px);
	background: #953636;
	font-size: 4.6rem;
	letter-spacing: .075em;
	position: relative;
}
.presentation:before, 
.presentation:after {
    content: "";
    width: 42px;
    height: 42px;
    position: absolute;
}
.presentation-inner{
	padding: .2em 0 .3em;
	display: block;
	border: 1px solid #b0a891;
}
.presentation .large-text{
	color: #d6ccb0;
}
.presentation .gold-text{
	color: #d6ccb0;
}
@media screen and (min-width: 768px) and (max-width: 992px){
	.presentation{
		margin-bottom: 68px;
		font-size: 3.6rem;
	}
	.presentation-inner{
		padding: .3em 0 .4em;
	}
}
@media screen and (max-width: 767px){
	.access-line,
	.usp{
		margin-right: auto;
		margin-left: auto;
		width: 85%;
	}
	.presentation{
		margin-top: 16px;
		font-size: 2.2rem;
		max-width: 300px;
	}
	.presentation-inner{
		padding: .3em 0 .4em;
	}
	.presentation + .caption{
			margin-bottom: .6em;
	}
}
.home .kodo-area .inner{
	padding-bottom: 10px;
}
.home .inner.top-btn-inner{
	margin-top: -20px;
	padding: 0 0 80px;
}
.home .vr-login-area{
	margin-top: clamp(38px, 4vw, 60px);
	color: #8e8466;
}
.home .vr-login-area .primary-heading{
	font-size: clamp(2rem, 2vw, 2.8rem);
}
.home .vr-login-area.inner{
	padding: 0;
	padding-bottom: 20px;
}
.home .vr-login-btn{
	padding: 28px 24px;
    font-size: clamp(1.4rem, 4.1vw, 2.4rem);
	color: #fff;
    background: linear-gradient(to right, #5a4a2f, #b19763);
}
.home .vr-login-text{
	margin-top: 16px;
	font-size: clamp(1.2rem, 1.2vw, 1.6rem);
	line-height: 1.5;
}
@media screen and (max-width: 767px){
	.home .vr-login-area .primary-heading{
		font-size: 4.8vw;
	}
	.home .vr-login-btn{
		padding: 22px 24px;
		font-size: 1.6rem;
	}
	.home .vr-login-area .inner{
		padding-bottom: 0;
	}
}

/*--------------------------------
login(VR)
--------------------------------*/
#login{
	overflow: hidden;
}
.login .login-wrap{
	width: 100%;
	height: 100vh;
	position: relative;
	background: #272727;
}
.login .login-area{
	position: absolute;
	top: 45%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 680px;
	margin: 0 auto;
	overflow: hidden;
}
.login .sub-text{
	/* font-size: (1.4rem, 3vw ,1.6rem); */
	font-size: 1.6rem;
	line-height: 1.5;
	margin-bottom: 5%;
}
.login .login-box{
	padding: 7%;
	background : #c6c2b2;
	border-radius: 16px;
	margin: 15% auto 0;
}
.login-box form{
	display: flex;
	gap: 0 3px;
	flex-wrap: nowrap;
}
.login-box input[type="password"] {
	flex: 1;
	padding: 12px;
	font-size: 16px;
	border: 1px solid #ccc;
	border-radius: 6px;
}
.login-box button {
	padding: 0 20px;
	font-size: 16px;
	background: #1c2a4e;
	background: #7a3a3a;
	background: #3a4a5a;
	color: #fff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: 0.3s;
}
button:hover {
	opacity: .8;
}
.login-box input[type="password"],
.login-box button {
	height: 44px;
}
.login-box #message{
	margin-top: 1.5%;
}
.login-box .caption{
	margin-top: 3%;
}
.login-page-btn.btn-version01 .general-btn{
	margin: 40px auto 0;
	max-width: 400px;
	font-size: clamp(1rem, 3.6vw, 2rem);
}
@media screen and (max-width: 767px){
	.login .login-wrap{
		height: auto;
		position: static;
	}
	#login{
		overflow: visible;
	}
	.login .login-area{
		position: static;
		transform: none;
		width: 90%;
		margin-top: 110px;
		margin-bottom: 70px;
	}
	.login .sub-text{
		font-size: 1.6rem;
		line-height: 1.5;
		margin-bottom: 5%;
	}
	.login .sub-text{
		/* font-size: (1.4rem, 3vw ,1.6rem); */
		font-size: 3.5vw;
		margin-bottom: 7%;
	}
	.login .login-box{
		margin: 12% auto 0;
	}
	.login-box input[type="password"] {
		width :70%;
		padding: 12px;
		font-size: 3.6vw;
	}
	.login-box button {
		padding: 0 15px;
		font-size: 3.5vw;
	}
	.login-box #message{
		font-size: 12px;
	}
	.login-box .caption{
		margin-top: 6%;
	}
}


/*--------------------------------
map
--------------------------------*/

.map_btns_btn {
	margin: 40px auto 0;
	display: block;
	width: calc(50% - 15px);
	background: #000;
	color: #fff;
	height: 3em;
	text-align: center;
	border: 1px solid #000;
	font-weight: 400;
	font-size: 14px;
	line-height: 3;
	font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN W3', 'Noto Serif JP', serif;
	transition: 0.5s;
}
@media screen and (max-width: 767px){
	.map-section{
		margin-top: 60px;
	}
	.map_btns_btn {
		margin: 32px auto 0;
		display: block;
		width: calc(50% - 15px);
		background: #000;
		color: #fff;
		height: 3em;
		text-align: center;
		border: 1px solid #000;
		font-weight: 400;
		font-size: 14px;
		line-height: 3;
		font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN W3', 'Noto Serif JP', serif;
		transition: 0.5s;
	}
}
.map-heading em{
	font-style: normal;
}
.map-wrap{
	margin: 0 auto;
	max-width: 1000px;
	overflow: hidden;
}
.map .text-large{
	font-size:clamp(1.6rem, 4.4vw ,4.4rem);
}
@media print{
	.map .navigation-bar,
	.map .banner-area,
	.map .page-footer-area,
	.map .fix-btn,
	.map .bg-light,
	.map .btn-space,
	.map .map_btns_btn,
	.map .pc-fix,
	.map footer{
		display: none;
	}
}


/*--------------------------------
outline
--------------------------------*/
.outline .general-section .inner{
	max-width: 1000px;
}
.outline-table-wrap{
	margin: 0 auto;
	max-width: 1000px;
}
.outline-table{
	margin-bottom: 40px;
	width: 100%;
	line-height: 1.6;
}
.outline-table caption{
	margin-bottom: 15px;
	padding-bottom: 10px;
	font-size: 2.3rem;
	font-weight: 400;
	border-bottom: 3px double #bbb;
	letter-spacing: 4px;
}
.outline-table.hensai tr:first-of-type{
	border-top: 1px solid #777;
}
.outline-table th,
.outline-table td{
	padding: 10px 0;
	border-bottom: 1px solid #777;
	word-break: break-word;
}
.outline-table th{
	width: 280px;
	font-weight: 400;
	text-align: left;
}
.is-table-top-border{
	border-top: 1px solid #777;
}
.label-wrapper{
	margin-top: -20px;
	margin-bottom: 80px;
	align-items: flex-start;
}
.label-box{
	margin: 8px 16px 8px 0;
	padding: 8px 0;
	width: 100px;
	font-size: 2rem;
	border: 1px solid;
	text-align: center;
}
.label-note{
	width: 100%;
	font-size: 1.4rem;
	line-height: 1.6;
}
.layout-caption{
	margin: -30px 0 0 32px;
	display: flex;
	align-items: center;
}
.layout-caption img{
	width: 19px;
	height: 19px;
	margin-right: 5px;
}
@media screen and (max-width: 767px){
	.outline-table caption{
		padding-bottom: 4px;
		font-size: 1.6rem;
	}
	.outline-table.hensai tr:first-of-type{
		border-top: none;
	}
	.outline-table th,
	.outline-table td{
		width: 100%;
		display: block;
	}
	.outline-table th{
		padding: 0 0 4px;
		font-size: 1.3rem;
		font-weight: 600;
	}
	.outline-table td{
		padding: 8px 0 16px;
		font-size: 1.2rem;
		border-bottom: none;
	}
	.is-table-top-border{
		border-top: none;
	}
	.label-wrapper{
		margin-bottom: 52px;
		display: block;
	}
	.label-note{
		font-size: 1.2rem;
	}
	.layout-caption{
		margin: -30px 0 0 20px;
	}
	.header-margin {
		margin-top: 50px;
	}
}
.page-title-wrap {
    padding: 52px 0;
    text-align: center;
}
.map-wrapper{
	margin: 20px auto 0;
	max-width: 1000px;
}
.map-wrapper + .primary-lead{
	margin-top: 80px;
}
.map_btns_btn {
	margin: 40px auto 0;
	display: block;
	width: calc(50% - 15px);
	background: #000;
	color: #fff;
	height: 3em;
	text-align: center;
	border: 1px solid #000;
	font-weight: 400;
	font-size: 14px;
	line-height: 3;
	font-family: 'Yu Mincho', 'YuMincho', 'Hiragino Mincho ProN W3', 'Noto Serif JP', serif;
	transition: 0.5s;
}
@media screen and (max-width: 767px){
	.map-wrapper + .primary-lead{
		margin-top: 30px;
	}
	.map-wrapper{
		margin-top: 10px;
	}
	.map .page-title-wrap{
		padding-bottom: 30px;
	}
	.map_btns_btn {
		margin-top: 20px;
	}
}
@media print { 
	.map header,.map footer{
		display: none;
	}
	.map .entry-section{
		display: none;
	}
	.map .banner-area{
		display: none;
	}
	.map_btns_btn{
		display: none;
	}
	.map .page-title-wrap{
		display: none;
	}
	.map .header-margin {
    margin-top: 0;
	}
	.map .caption-wrapper {
    padding:0;
	}
	.map-wrapper + .primary-lead{
		margin-top: 10px;
	}
	.map .fix-btn{
		display: none;
	}
}

/*--------------------------------
state
--------------------------------*/
.is-none {
	display: none;
}

.disabled {
	opacity: 0.1;
	cursor: default;
	pointer-events: none;
}

.unscrollable {
	height: 100%;
	overflow: hidden;
}

.coming-soon {
	opacity: 0.8;
	pointer-events: none;
}

.none {
	opacity: 0.5;
	cursor: default;
	pointer-events: none;
}

.no-link {
	cursor: default;
	pointer-events: none;
}

.is-fv {
	opacity: 0;
	animation-fill-mode: both;
}

.is-light {
	color: #fff;
}

.is-dark {
	color: #231815;
}

.gray-text {
	color: #555;
}

.is-key {
	color: #8e8466;
}

.is-strong {
	color: #5b4e65;
}

.is-shadow {
	text-shadow: 0 0 1px rgba(0, 0, 0, 0.8), 0 0 4px rgba(0, 0, 0, 0.4);
}

.is-alert {
	color: #ff1c1c;
}

.text-center {
	text-align: center;
}

.text-right {
	text-align: right;
}

.text-left {
	text-align: left;
}

.small-text {
	font-size: 70%;
}

.large-text {
	font-size: 150%;
}

.is-semi-bold {
	font-weight: 500;
}
.is-thin {
	font-weight: 300;
}
.is-bold {
	font-weight: 700;
}

.line-wide {
	line-height: 2;
}
.line-super-wide {
	line-height: 4;
}
.font-nomal{
	font-style: normal;
}
@media (max-width: 767px) {
	.line-super-wide {
		line-height: 3;
	}
}
.letter-wide{
	letter-spacing: .2em;
}
.en-font {
	font-family: "scotch-display", sans-serif;
}
.en-font2{
	font-family: "Cinzel", serif;
}
.ja-font{
	font-family: "fot-tsukuaoldmin-pr6n", sans-serif;
}
.is-dummy{
	transform: rotateY(180deg);
}

@media (min-width: 992px) {
	.pc-none {
		display: none;
	}
}
@media (max-width: 991px) {
	.sp-none {
		display: none;
	}
}
@media (max-width: 767px) {
	.mobile-none {
		display: none;
	}
}
@media (min-width: 768px) {
	.tab-none {
		display: none;
	}
}
/* Hides from IE-mac \*/
.clearfix {
	display: block;
}

/* End hide from IE-mac */

/*# sourceMappingURL=style.css.map */