@charset "UTF-8";

.mv {
	height: 100vh;
	position: relative;
	overflow: hidden;
	z-index: 1;
}

.mv:after {
	width: 100%;
	height: 100%;
	background: linear-gradient(200deg, rgba(10, 14, 18, 0.62), rgba(10, 14, 18, 0.18) 45%, rgba(10, 14, 18, 0));
	position: absolute;
	content: "";
	top: 0;
	left: 0;
	z-index: 0;
}

.mv__shade {
	pointer-events: none;
	opacity: 0;
	background: rgba(0, 0, 0, 0.42);
	position: absolute;
	z-index: 2;
	inset: 0;
}

.mv__splide,
.mv__splide .splide__track,
.mv__splide .splide__list {
	height: 100%;
}

.mv__splide {
	position: relative;
	z-index: 0;
}

.slide-bg {
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: cover;
	position: absolute;
	will-change: transform;
	transform: translateZ(0);
	inset: 0;
}

/* zoom-in */
@keyframes mvZoomIn {
	from {
		transform: scale(1.06) translate3d(0, 0, 0);
	}

	to {
		transform: scale(1.14) translate3d(0, -1.2%, 0);
	}
}

/* 左 → 右 */
@keyframes mvPanLR {
	from {
		transform: scale(1.1) translate3d(-4%, 0, 0);
	}

	to {
		transform: scale(1.1) translate3d(4%, 0, 0);
	}
}

/* 右 → 左 */
@keyframes mvPanRL {
	from {
		transform: scale(1.1) translate3d(4%, 0, 0);
	}

	to {
		transform: scale(1.1) translate3d(-4%, 0, 0);
	}
}

/* zoom-out */
@keyframes mvZoomOut {
	from {
		transform: scale(1.14) translate3d(0, -1%, 0);
	}

	to {
		transform: scale(1.06) translate3d(0, 0, 0);
	}
}

.mv__splide .splide__slide.is-active,
.mv__splide .splide__slide.is-visible {
	opacity: 1;
}

.mv__logo {
	width: 400px;
	position: absolute;
	top: 14vh;
	left: 50%;
	text-align: center;
	z-index: 1;
	transform: translateX(-50%);
}

.mv__logo a {
	display: block;
}

.mv__logo img {
	filter: drop-shadow(0 24px 24px rgba(12, 34, 47, 0.4));
}

.decor01 {
	width: calc(1820px / 4);
	position: absolute;
	right: -40px;
	bottom: 0px;
	z-index: 1;
}

.decor02 {
	width: calc(1410px / 4);
	position: absolute;
	bottom: 0px;
	left: -40px;
	z-index: 1;
}

.hero {
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
}

.story {
	text-align: center;
}

.story__inner {
	padding: 24vh 0;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}

.story__title {
	font-size: 40px;
	font-weight: 600;
	text-shadow: 0 0 16px rgba(0, 0, 0, 0.5);
	letter-spacing: 0.1em;
}

.story__catch {
	margin: 16px 0 0;
	font-size: 20px;
	font-weight: 800;
	letter-spacing: 0.2em;
}

.story__more {
	margin: 4vh 0 0;
	text-shadow: 0 0 16px rgba(0, 0, 0, 0.5);
}

.story__text {
	margin: 4vh 0 0;
	font-size: 16px;
	font-weight: 500;
	line-height: 3.2;
	letter-spacing: 0.2em;
}

/*================================================================
# bath
================================================================ */
.bath {
	padding: 0 0 160px;
}

/*================================================================
# room
================================================================ */
.room .scene__bg img {
	object-position: center bottom;
}

/*================================================================
# living
================================================================ */
.living {
	width: 100%;
}

.living__inner {
	margin: 0 auto;
	padding: 120px 80px 0;
}

.living__main {
	width: 100%;
	background-color: var(--black);
}

.living__main .living__main-img {
	width: 100%;
	height: 62rem;
	opacity: 0.7;
	border-radius: 8px 8px 0 0;
	display: block;
	object-fit: cover;
}

.living .decor04 {
	width: 100%;
	max-width: 1440px;
	margin: auto;
	opacity: 0.85;
	position: absolute;
	right: 0;
	bottom: -36px;
	left: 0;
	z-index: 9;
}

.living__main-ttl {
	width: 100%;
	margin: 12px 0 40px;
	position: absolute;
	top: 50%;
	left: 50%;
	font-size: 40px;
	font-weight: 700;
	line-height: 1.2;
	text-shadow: 0 0 16px rgba(0, 0, 0, 0.5);
	text-align: center;
	letter-spacing: 0.02em;
	transform: translate(-50%, -50%);
}

.living__text {
	margin: 44px 0 0;
	text-align: center;
}

.living__lead {
	margin: 64px 0 0;
	font-size: 14px;
	font-weight: 600;
	line-height: 2.2;
	letter-spacing: 0.04em;
}

.living__lead+.living__lead {
	margin: 18px 0 0;
}

.living__splide {
	width: 100%;
	margin: 48px 0 0;
	position: relative;
}

.living__splide .splide__track {
	padding: 0 0 24px;
	overflow: visible;
}

.living-card {
	border-radius: 8px;
	overflow: hidden;
}

.living-card img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 1.618 / 1;
}

.living__splide .splide__arrow {
	width: 56px;
	height: 56px;
	opacity: 1;
	border: 1px solid var(--white);
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.45);
	top: calc(50% - 18px);
	transition: 0.3s;
	backdrop-filter: blur(10px);
}

.living__splide .splide__arrow--prev {
	left: 8rem;
}

.living__splide .splide__arrow--next {
	right: 8rem;
}

.living__splide .splide__arrow:hover {
	border: 1px solid rgba(255, 255, 255, 0.35);
	background: rgba(0, 0, 0, 0.6);
	transform: translateY(-50%) scale(1.06);
}

.living__splide .splide__arrow svg {
	fill: var(--white);
}

.living__splide .splide__pagination {
	margin: 0;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
}

.living__splide .splide__pagination__page {
	width: 8px;
	height: 8px;
	opacity: 1;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.25);
	transition: 0.3s;
}

.living__splide .splide__pagination__page.is-active {
	background: rgba(255, 255, 255, 0.9);
	transform: scale(1.2);
}

/*================================================================
# tour
================================================================ */
.tour {
	max-width: 1600px;
	margin: 100px auto 0;
}

.tour__ttl-en {
	font-size: 13px;
	font-weight: 600;
	text-align: center;
	letter-spacing: 0.08em;
}

.tour__ttl {
	margin: 0;
	position: relative;
	font-size: 28px;
	font-weight: 600;
	text-align: center;
	letter-spacing: 0.04em;
}

.tour__ttl:after {
	width: 28px;
	height: 1px;
	margin: 18px auto 0;
	background: var(--gray03);
	content: "";
	display: block;
}

.tour__grid {
	margin: 44px 0 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 26px;
}

.tour-card {
	border-radius: 8px;
	background: #000;
	box-shadow: 0 22px 60px rgba(0, 0, 0, 0.12);
	position: relative;
	display: block;
	overflow: hidden;
	text-decoration: none;
}

.tour-card__media {
	width: 100%;
	position: relative;
	aspect-ratio: 3 / 4;
}

.tour-card__media img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	transition: transform 0.6s;
	transform: scale(1.02);
}

.tour-card__media:after {
	width: 100%;
	height: 100%;
	opacity: 0.9;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.48));
	position: absolute;
	content: "";
	top: 0;
	left: 0;
	transition: opacity 0.35s;
}

.tour-card__overlay {
	width: 100%;
	padding: 40px 22px 0 22px;
	position: absolute;
	top: 0;
	left: 0;
}

.tour-card__sub {
	font-size: 14px;
	font-weight: 600;
	line-height: 2.2;
	text-shadow: 0 0 16px rgba(0, 0, 0, 0.5);
	text-align: center;
	letter-spacing: 0.04em;
}

.tour-card__main {
	margin: 8px 0 0;
	font-size: clamp(32px, calc(22.857px + 0.8929vw), 40px);
	font-weight: 700;
	line-height: 1.2;
	text-shadow: 0 0 16px rgba(0, 0, 0, 0.5);
	text-align: center;
	letter-spacing: 0.02em;
}

.tour-card:hover {
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.16);
	transform: translateY(-6px);
}

.tour-card:hover .tour-card__media img {
	transform: scale(1.08);
}

.tour-card:hover .tour-card__media:after {
	opacity: 1;
}

.tour-card:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.8);
	outline-offset: 4px;
}