@charset "utf-8";

:root {
	--color-bg: #fff;
	--wcalc-window-side-width: calc((100vw - var(--scrollbar-width) - 1440px) / 2); 
}

.PageHeader {
	background-image: url(../img/facilities/kv.webp);
}


.PageHeader__ttl-outer::before {
	background-image: var(--round-out-corner-RB-wt);
}

.PageHeader__ttl-outer::after {
	background-image: var(--round-out-corner-LB-wt);
}

.PageHeader__ttl-outer .in-corner::before {
	background-image: var(--round-in-corner-LB-wt);
}

.PageHeader__ttl-outer .in-corner::after {
	background-image: var(--round-in-corner-RB-wt);
}

.no-webp .PageHeader {
	background-image: url(../img/facilities/kv.jpg);
}

/* -------------------------------- */

.anchor-offset {
	margin-top: 0px !important;
	padding-top: 80px !important;
}

#floor-guide,
#follow-up-salon,
#access {
	width: 100%;
	max-width: 100%;
}

.section-inner {
	display: flex;
	position: relative;
}

.section-header {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	width: 60px;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	writing-mode: vertical-rl;
	position: absolute;
	top: 0;
	left: 0;
}

.section-header__ttl {
	line-height: 60px;
	margin: 0;
}

.section-header__subttl {
	line-height: 1;
	margin-top: 20px;
}

.section-body {
	width: 100%;
	margin: 0;
}

.FloorGuide__outer {
	position: relative;
	padding: 60px 0;
}

.FloorGuide__outer:before {
	position: absolute;
	content: '';
	width: calc(100% - 60px);
	height: 100%;
	background-color: rgba(255,255,255,1);
	border-top: 1px solid rgba(0,0,0,.2);
	top: 0;
	right: 0;
	z-index: -1;
}

.FloorGuide__outer + .FloorGuide__outer {
	margin-top: 80px;
}

#FloorGuide .FloorGuide__outer:first-child {
	padding-bottom: 0;
}

.FloorGuide__outline + .FloorGuide__outline {
	margin-top: 70px;
}


.contents {
	box-sizing: border-box;
}

.contents + .contents {
	margin-top: 60px;
}

.txt-contents {

}

.contents > * {
	width: calc(100% - 60px);
	margin-left: auto !important;
	padding-right: 30px;
	box-sizing: border-box;
}

.contents__ttl {
	margin-top: 0;
	font-size: 2rem;
	text-align: right;
}

.contents__txt {
	margin-top: 40px;
}

.FloorList {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 85%;
}

.FloorList__item {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	box-sizing: border-box;
}

.FloorList__num {
	position: relative;
	width: 45px;
	padding: 10px 0;
	font-size: 2rem;
	line-height: 1;
	opacity: 0.25;
}

.FloorList__num:before {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	left: 0;
	bottom: 0;
	border-style: solid;
	border-color: transparent rgba(255,255,255,1) rgba(255,255,255,1) transparent;
	border-width: 0 0 35px 45px;
}
/*
.FloorList__num:after {
	position: absolute;
	content: '';
	width: 55px;
	height: 0.7px;
	background-color: rgba(0,0,0,0.7);
	left: 0;
	bottom: 0;
	transform: rotate(-37deg);
	transform-origin: bottom left;
}
*/
.FloorList__num span {
	font-size: 3rem;
	font-weight: 200;
}

.FloorList__des {
	display: flex;
	justify-content: space-between;
	flex-direction: column;
	width: calc(100% - 80px);
	min-height: 90px;
	padding: 10px 30px 10px 0;
	box-sizing: border-box;
	border-bottom: 1px solid rgba(0,0,0,.1);
}

.FloorList__des > *:first-child {
	margin-top: 0;
}

.FloorList__des .icon-list {
	list-style: none;
	padding: 0;
	display: flex;
	justify-content: flex-end;
}

.FloorList__des .icon-list li + li {
	margin-left: 15px;
}

.Facilities__figure {
	margin: 0;
}

.Facilities__figure .carousel__container {
	margin-top: 0;
}

/* Floor guide */

#floor-guide .FloorGuide__outer:first-child {
	padding-bottom: 0;
}

/* Floor des */

.Floor__des .Floor_num {
	margin-top: 0;
	font-size: 2rem;
	opacity: 0.25;
	line-height: 1;
}

.Floor__des .Floor_num::first-letter {
	font-size: 5rem;
	font-weight: 200;
}

.Floor__des .contents__ttl {
	margin-top: 1em;
	text-align: left;
	font-feature-settings: "palt";
}

.Floor__des .swiper {
	width: 100%;
	padding-bottom: 0;
}

.slide__body {
	padding-left: 30px;
}

.slide__read {
	font-size: 1.2rem;
}

.swiper__btns-inner {
	justify-content: flex-start;
}

.swiper__btns {
	display: none;
}

.swiper-button-next,
.swiper-button-prev {
	transform: translateX(-7px);
}


/* follow-up-salon */

#follow-up-salon .-gallery .swiper-slide {
	width: 100% !important;
	margin: 0;
}

#follow-up-salon .-gallery .slide__img img {
	border-radius: 0;
}


/* access */

#access .contents__ttl {
	text-align: left;
}

.access-tr-table {
	margin-top: 40px;
}

.access-tr__item {
	
}

.access-tr__item + .access-tr__item {
	margin-top: 40px;
}

.access-tr__lbl {
	display: flex;
	align-items: center;
	font-weight: bold;
}

.access-tr__lbl .icon-list {
	margin: 0;
	margin-left: 15px;
	padding: 0;
	list-style: none;
	display: flex;
	align-items: center;
}

.access-tr__lbl .icon-list li {

}

.access-tr__lbl .icon-list li + li {
	margin-left: 10px;
}

.access-tr__des {
	margin-left: 0;
	margin-top: 1em;
}

.map-contents {
	display: none;
}

/* ie only */

.msie .section-header__ttl-inner {
	transform: scaleX(1);
}

@media all and (min-width: 768px) {
	.section-header {
		width: 100px;
	}

	.FloorGuide__outer:before {
		width: calc(100% - 100px);
	}

	.contents > * {
		width: calc(100% - 100px);
	}

	.contents__ttl {
		text-align: left;
	}

	/* Floor des */

	.slide__read {
		font-size: 1.2rem;
		width: 50%;
		font-feature-settings: "palt";
		text-align: justify;
	}

	/* access */

	#access .txt-contents .Conversion__link {
		width: calc(100% - 70px);
	}
}

@media all and (min-width: 1280px) {
	.SectionIndexSection__list {
		font-size: 1.6rem;
	}
	
	.SectionIndexSection__list li + li {
		margin-left: 50px;
	}

	#floor-guide,
	#follow-up-salon,
	#access {
		width: calc(100% - 160px);
		max-width: 1440px;
	}

	.anchor-offset {
		padding-top: 120px !important;
	}
	
	.section-inner {
		justify-content: flex-end;
	}

	.section-header {
		position: sticky;
		top: 50px;
		right: auto;
		left: 0;
		align-items: flex-start;
		justify-content: center;
		flex-direction: column;
		width: var(--wcalc10-1);
		height: fit-content;
		margin: 0 auto 0 0;
		transition: top 0.2s ease-in-out;
	}

	.scroll-up .section-header {
		top: 130px;
	}

	.section-header__ttl {
		margin: 0;
	}

	.section-header__subttl {
		margin: 0;
	}

	.section-body {
		width: var(--wcalc10-9);
	}

	.FloorGuide__outer {
		padding: 100px 0;
	}

	.FloorGuide__outer:before {
		width: calc(100% + (var(--wcalc-window-side-width)));
		min-width: calc(100% + 80px);
		right: auto;
		left: 0;
	}

	.FloorGuide__outline {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	.FloorGuide__outline + .FloorGuide__outline {
		margin-top: 110px;
		padding-top: 0;
	}

	.contents {
		width: var(--wcalc9-3);
		padding: 0;
	}

	.contents + .contents {
		margin-top: 0;
	}

	.txt-contents {
		width: var(--wcalc9-4);
	}

	.contents > * {
		width: 100%;
		padding: 0;
	}

	.contents__ttl {
		font-size: 2.2rem;
	}

	.contents__txt {
		margin-top: 60px;
	}


	/* floor-guide */

	.FloorList__des {
		flex-direction: row;
		min-height: 90px;
		padding: 15px 30px 15px 0;
	}

	.FloorList__num {
		font-size: 2.4rem;
	}

	.FloorList__num span {
		font-size: 4rem;
	}

	.FloorList__num:before {
		left: -5px;
		bottom: -10px;
	}

	.FloorList__num:after {
		width: 75px;
		left: -5px;
		bottom: -10px;
	}

	.carousel-contents {
		width: 100%;
		margin-top: 110px !important;
		margin-right: -80px;
	}

	.Facilities__figure {
		width: calc(100% + 80px);
		min-width: 100%;
	}

	/* Floor des */

	#floor-guide .img-contents {
		/* margin-right: calc((var(--wcalc-window-side-width)) * -1);
		width: calc((var(--wcalc9-5)) + (var(--wcalc-window-side-width))); */
		margin-right: -80px;
		width: calc((var(--wcalc9-5)) + 80px);
	}

	#floor-guide .-gallery.swiper-container {
	}

	.Floor__des .Floor_num {
		font-size: 6rem;
	}

	.Floor__des .Floor_num::first-letter {
		font-size: 10rem;
	}

	.Floor__des .contents__txt {
		margin-top: 140px;
		width: 100%;
		max-width: 380px;
	}

	.Floor__des .swiper {
		margin: 0;
		padding: 0 0 40px;
	}

	.-gallery .swiper-slide {
		width: calc(100% - (var(--wcalc-window-side-width)));
		margin: 0 40px 0 0;
	}

	.slide__body {
		padding-left: 0;
	}

	.swiper__btns {
		display: flex;
		align-items: flex-end;
	}


	/* follow-up-salon */
	
	#follow-up-salon .FloorGuide__outline {
		flex-direction: column;
		position: relative;
	}

	#follow-up-salon .txt-contents {
		width: calc( var(--wcalc9-4) - ( var(--wcalc9-1) / 2 ));
	}

	#follow-up-salon .img-contents {
		position: absolute;
		top: 30px;
		right: 0;
	}


	/* access */

	#access .FloorGuide__outline + .FloorGuide__outline {
		margin-top: 160px;
	}

	#access .txt-contents {
		width: calc( var(--wcalc9-4) - ( var(--wcalc9-1) / 2 ));
	}

	#access .txt-contents .Conversion__link {
		width: 100%;
	}

	.map-contents {
		display: block;
	}

	.maps {
		height: 450px;
	}

	.Conversion__link .btn {
		padding: 20px;
	}
	
}

@media all and (min-width: 1600px) {
	.carousel-contents {
		margin-right: calc((var(--wcalc-window-side-width)) * -1);
	}

	.Facilities__figure {
		width: calc(100% + (var(--wcalc-window-side-width)));
	}

	#floor-guide .img-contents {
		margin-right: calc((var(--wcalc-window-side-width)) * -1);
		width: calc((var(--wcalc9-5)) + (var(--wcalc-window-side-width)));
	}
}


.swiper-pagination-bullet {
	width: 20px;
	height: 20px;
	text-align: center;
	line-height: 20px;
	font-size: 12px;
	color: rgba(0,0,0,.2);
	background: none;
	opacity: 1;
	position: relative;
}

.swiper-pagination-bullet + .swiper-pagination-bullet {
	margin-left: 20px;
}

.swiper-pagination-bullet + .swiper-pagination-bullet:before {
	position: absolute;
	content: '/';
	color: rgba(0,0,0,.2);
	top: 0;
	left: -6px;
}

.swiper-pagination {
	text-align: left;
}

.swiper-pagination-bullet-active {
	color: rgba(0,0,0,1);
}
