@charset "UTF-8";

:root {
	--va-value: 200;
	font-size: 16px;
}

html, body {
	-webkit-text-size-adjust: 100%;
}
html {
	overflow-x: hidden;
	scroll-behavior: smooth;
}
body {
	background-color: #ffffff;
}
.jtb-nav-breadcrumb {
	font-family: "Noto Sans JP", sans-serif;
	li {
		font-size: 14px;
		&::before {
			right: -14px;
			line-height: 1.6;
		}
	}
}
main, .royal-staff-header {
	font-family: "Noto Serif JP", serif;
	box-sizing: border-box;
	* {
		box-sizing: border-box;
	}
}
main {
	padding-bottom: 60px;
	background-color: #ffffff;
	font-size: 16px;
	letter-spacing: 0.15em;
	line-height: 1.5;
	img {
		width: 100%;
		max-width: fit-content;
		height: auto;
		vertical-align: top;
	}
	small {
		display: block;
		line-height: 1.2;
		font-size: 14px;
	}
	figure {
		margin: 0;
	}
	picture {
		display: block;
	}
	strong {
		font-weight: 900;
	}
}
@media (max-width: 768px) {
	main {
		font-size: calc(32 / 750 * 100vw);
	}
}


.pos-r {
	position: relative;
}
.btn {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #cc0d21;
	font-family: "Noto Sans JP", sans-serif;
	border-radius: 5px;
	transition: .2s ease-in-out;
}
a.btn {
	color: #ffffff;
}
@media (min-width: 769px) {
	.pc-hide {
		display: none;
	}
	.w-1236 {
		width: 1256px;
		margin-inline: auto;
		padding-inline: 10px;
	}
	.pc-lazy_image-wrap {
		position: relative;
		width: 100%;
		height: 0;
	}
	.pc-lazy_image-wrap {
		position: relative;
		width: 100%;
		height: 0;
	}
	.pc-lazy_image {
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		width: 100%;
		height: auto;
	}
	.btn:hover {
		background-color: #15425e;
	}
	.text-link:hover {
		color: #15425e;
	}
}
@media (max-width: 768px) {
	.sp-hide {
		display: none;
	}
	.w-1236 {
		width: 100%;
		padding-inline: calc(40 / 750 * 100vw);
	}
	.lazy_image-wrap {
		position: relative;
		width: 100%;
		height: 0;
	}
	.lazy_image {
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		width: 100%;
		height: auto;
	}
	.btn {
		width: calc(600 / 750 * 100vw);
		margin-inline: auto;
	}
}



.mv {
	width: 100%;
	height: 650px;
	font-family: "Noto Serif JP", serif;
	overflow: hidden;
}
.mv-slide {
	width: 100%;
	max-width: 1500px;
	min-width: 1256px;
	height: inherit;
	margin-inline: auto;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	margin: 0;
}
.mv-slide-item {
	position: absolute;
	inset: 0;
	margin: 0;
	width: 100%;
	background-size: auto 100%;
	background-position: center;
	transition: opacity 0.8s, transform 0.8s;
	opacity: 0;
	transform: scale(1.05);
	transition: opacity 1s ease, transform 6s ease;
	&.-item1 {
		background-image: url(/stores/royalstaff/images/mv-slide1.jpg)
	}
	&.-item2 {
		background-image: url(/stores/royalstaff/images/mv-slide2.jpg)
	}
	&.-item3 {
		background-image: url(/stores/royalstaff/images/mv-slide3.jpg)
	}
	&.-item4 {
		background-image: url(/stores/royalstaff/images/mv-slide4.jpg)
	}
}
/* 奇数枚：右にはみ出す */
.mv-slide-item:nth-child(odd) {
	transform-origin: right center;
}
/* 偶数枚：左にはみ出す */
.mv-slide-item:nth-child(even) {
	transform-origin: left center;
}
.mv-slide-item.is-active {
	opacity: 1;
	transform: scale(1);
}
@media (min-width: 769px) {
	.mv-title {
		position: relative;
		z-index: 1;
		top: -19px;
		width: 1370px;
		margin-inline: auto;
		color: rgba(255, 255, 255, 0.8);
		font-size: 118px;
		font-weight: 600;
		text-transform: uppercase;
		line-height: 1;
		letter-spacing: calc(80 * 118px / 1000);
	}
}
@media (max-width: 768px) {
	.mv {
		height: calc(850 / 750 * 100vw);
	}
	.mv-title {
		position: relative;
		z-index: 1;
		left: calc(36 / 750 * 100vw);
		top: calc(7 / 750 * 100vw);
		width: calc(266 / 750 * 100vw);
		img {
			width: 100%;
			height: auto;
		}
	}
	.mv-slide {
		max-width: 100%;
		min-width: 100%;
	}
	.mv-slide-item {
		background-size: 100%;
		&.-item1 {
			background-image: url(/stores/royalstaff/images/mv-slide1-sp.jpg)
		}
		&.-item2 {
			background-image: url(/stores/royalstaff/images/mv-slide2-sp.jpg)
		}
		&.-item3 {
			background-image: url(/stores/royalstaff/images/mv-slide3-sp.jpg)
		}
		&.-item4 {
			background-image: url(/stores/royalstaff/images/mv-slide4-sp.jpg)
		}
		&.-item5 {
			background-image: url(/stores/royalstaff/images/mv-slide5-sp.jpg)
		}
	}
}


.nav-container {
	position: sticky;
	top: 0;
	z-index: 3;
	margin-top: 15px;
	margin-bottom: 85px;
	backdrop-filter: blur(10px);
	background: rgba(255, 255, 255, .5);
	transition: all 0.15s linear;
}
.nav-container.sticky-active {
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	.nav-link {
		border: none;
	}
}
.nav-list {
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(4, 1fr);
}
.nav-link {
	position: relative;
	display: flex;
	align-items: center;
	height: 70px;
	padding-left: 20px;
	font-size: 18px;
	font-weight: 600;
	border-bottom: 1px solid #5D5C5C;
	transition: .2s ease-in-out;
}
a.nav-link {
	color: #5D5C5C;
}
._arrow {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-9px);
	width: 20px;
	height: 9px;
	transition: .2s ease-in-out;
}
._arrow::before,
._arrow::after {
	content: "";
	position: absolute;
	bottom: 0;
	width: 13px;
	height: 1px;
	background: #a1a0a0;
	/* 線の色 */
}
._arrow::before {
	left: -1px;
	transform: rotate(35deg);
	transform-origin: left bottom;
}
._arrow::after {
	right: -1px;
	transform: rotate(-35deg);
	transform-origin: right bottom;
}

.header-info {
	align-items: center;
	width: 785px;
	height: 415px;
	background-color: rgba(255, 255, 255, 0.8);
	background-image: url(/stores/royalstaff/images/frame-header-info.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: auto;
	font-size: 18px;
	text-align: center;
	line-height: 2;
}
.header-info-title {
	display: block;
	width: auto;
	padding-top: 28px;
	padding-bottom: 12px;
	background: url(/stores/royalstaff/images/bg-header-title.png) no-repeat center bottom / 275px;
	color: #1e495d;
	font-size: 40px;
	font-family: "Zen Old Mincho", serif;
	font-weight: bold;
	letter-spacing: calc(40 * 40px / 1000);
}
.header-info-title-sub {
	margin-top: 20px;
	color: #777777;
	font-size: 24px;
	font-weight: 600;
}
.header-info-text {
	margin-top: 13px;
	color: #5d5d5d;
	font-size: 18px;
	font-weight: 600;
	letter-spacing: 0.13em;
}
@media (min-width: 769px) {
	h1 {
		width: 1370px;
	}
	.header-info-container {
		position: absolute;
		top: -470px;
		left: 0;
		right: 0;
		width: 1320px;
		margin-inline: auto;
		padding-inline: 10px;
	}
	.nav-link[href="#introduction"] {
		letter-spacing: 0.1em;
		span:not(._arrow) {
			position: relative;
			left: -20px;
		}
	}
	.nav-link:hover {
		color: #15425e;
		border-color: #15425e;
		._arrow {
			transform: translateY(-7px);
		}
		._arrow::before, ._arrow::after {
			background: #15425e;

		}
	}
}
@media (max-width: 768px) {
	.nav-container {
		margin-bottom: 20px;
	}
	.nav-list {
		gap: calc(50 / 750 * 100vw);
		;
		padding: 0 calc(60 / 750 * 100vw);
		grid-template-columns: repeat(2, 1fr);
		._arrow {
			display: none;
		}
	}
	.nav-container.sticky-active {
		.nav-list {
			gap: calc(5 / 750 * 100vw) calc(50 / 750 * 100vw);
		}
	}
	.nav-link {
		position: relative;
		justify-content: center;
		height: calc(105 / 750 * 100vw);
		text-align: center;
		font-size: calc(32 / 750 * 100vw);
		padding-left: 0;
		line-height: 1.25;
		letter-spacing: -0.03vw;
		span {
			position: relative;
			left: -2vw;
		}
		&::after {
			content: "";
			position: absolute;
			right: 0;
			width: calc(18 / 750 * 100vw);
			height: calc(9 / 750 * 100vw);
			margin-right: 5px;
			background: #aaaaaa;
			clip-path: polygon(0 0, 50% 100%, 100% 0);
		}
	}

	.header-info {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		align-items: center;
		width: 100%;
		height: calc(1142 / 750 * 100vw);
		background-image: url(/stores/royalstaff/images/frame-header-info-sp.png), url(/stores/royalstaff/images/bg-header-info-sp.jpg);
		background-repeat: no-repeat, no-repeat;
		background-position: center, center;
		background-size: calc(643 / 750 * 100vw), 100%;
	}
	.header-info-title {
		margin-top: -5vw;
		padding-bottom: calc(40 / 750 * 100vw);
		padding-top: 0;
		font-size: calc(40 / 750 * 100vw);
		background-size: calc(444 / 750 * 100vw);
		position: relative;
	}
	.header-info-title-sub {
		position: relative;
		z-index: 1;
		left: calc(45 / 750 * 100vw);
		color: #ffffff;
		font-size: calc(36 / 750 * 100vw);
	}
	.header-info-text {
		margin-top: calc(40 / 750 * 100vw);
		font-size: calc(32 / 750 * 100vw);
		line-height: 2.3;
	}
}


section {
	scroll-margin-top: 30px;
	padding: 85px 0;
	figcaption {
		font-size: 14px;
		text-align: right;
		letter-spacing: 0.1em;
	}
	p {
		text-align: justify;
	}
}
.title-lv2 {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 21px;
	margin-bottom: 75px;
	padding-left: 35px;
	span {
		display: block;
		line-height: 1.2;
	}
	&::before {
		content: "";
		position: absolute;
		left: 7px;
		top: 0;
		z-index: 1;
		display: inline-block;
		width: 3px;
		height: 100%;
		background-color: #777777;
	}
}
.title-lv2-jp {
	position: relative;
	z-index: 1;
	display: flex !important;
	flex-direction: column;
	justify-content: space-between;
	gap: 5px;
	height: inherit;
	color: #000000;
	font-size: 48px;
	font-weight: 600;
	letter-spacing: 0.07em;
}
.title-lv2-en {
	position: relative;
	z-index: 1;
	padding-left: 10px;
	padding-bottom: 10px;
	color: #777777;
	font-size: 18px;
	font-weight: 600;
	text-transform: uppercase;
}
.title-lv2-en-lg {
	position: absolute;
	top: 7px;
	right: -70px;
	display: block;
	color: #e8e7e4;
	font-size: 118px;
	font-weight: 600;
	letter-spacing: calc(120 * 118px / 1000);
}
.title-lv3 {
	margin-bottom: 35px;
	font-size: 30px;
	font-weight: 600;
	line-height: 1.33;
}
@media (max-width: 768px) {
	.title-lv2-en-lg {
		top: 12px;
		right: -70px;
		font-size: calc(118 / 750 * 100vw);
	}
}
@media (max-width: 768px) {
	section {
		scroll-margin-top: 110px;
		padding: 65px 0;
		figcaption {
			font-size: calc(28 / 750 * 100vw);
		}
	}
	.title-lv2 {
		gap: 10px;
		height: auto;
		padding-left: calc(25 / 750 * 100vw);
		margin-bottom: 35px;
		&::before {
			left: 0;
			width: 2px;
		}
		span {
			line-height: 1.2;
		}
	}
	.title-lv2-jp {
		font-size: calc(50 / 750 * 100vw);
		white-space: nowrap;
		._line2 {
			margin-top: 10px;
			font-size: calc(42 / 750 * 100vw);
		}
	}
	.title-lv2-en {
		padding-left: 0;
		padding-bottom: 1vw;
		font-size: calc(32 / 750 * 100vw);
	}
	.title-lv2-en-lg {
		top: -8vw;
		right: calc(-40 / 750 * 100vw);
		font-size: calc(84 / 750 * 100vw);
		white-space: nowrap;
		letter-spacing: 1vw;
	}
	.title-lv3 {
		margin-bottom: 35px;
		font-size: calc(40 / 750 * 100vw);
		letter-spacing: 0.8vw;
	}
}


/* royal-staff
--------------------------------------------------*/
.staff-profile+.staff-profile {
	margin-top: 200px;
}
.royal-staff-text {
	position: relative;
	z-index: 2;
	font-weight: 600;
	line-height: 2;
	letter-spacing: 0.07em;
}
.royal-staff-list {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-between;
	margin-top: 50px;
	padding: 0 35px 70px 35px;
	&::after {
		content: "";
		position: absolute;
		z-index: -1;
		bottom: 0;
		right: 0;
		width: 100vw;
		margin: 0 calc(50% - 50vw);
		height: 440px;
		background-color: #f0efed;
	}
}
.royal-staff-item {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 298px;
	height: 338px;
	padding-top: 40px;
	background: url(/stores/royalstaff/images/bg-royal-staff-item.png) no-repeat center / 100%;
	color: #1e495d;
	font-size: 22px;
	font-weight: 700;
	text-align: center;
	text-shadow: 2px 2px 10px #ffffff,
		-2px 2px 10px #ffffff,
		2px -2px 10px #ffffff,
		-2px -2px 10px #ffffff;
}
.royal-staff-item:nth-child(3) {
	letter-spacing: 0.1em;
}
@media (min-width: 769px) {
	.royal-staff {
		.title-lv2 {
			gap: 8px;
		}
		.title-lv2-en {
			position: relative;
			left: -12px;
			padding-bottom: 0;
		}
	}
	.royal-staff-text {
		padding-left: 44px;
		font-size: 26px;
		position: relative;
		&::before {
			display: none;
		}
	}
}
@media (max-width: 768px) {
	.royal-staff {
		.logo-royal-staff {
			width: calc(320 / 750 * 100vw);
		}
	}
	.royal-staff-text {
		padding-left: 0;
		line-height: 1.625;
	}
	.royal-staff-list {
		flex-direction: column;
		align-items: center;
		gap: calc(80 / 750 * 100vw);
		padding: 0 0 15px;
		&::after {
			top: calc(-40 / 750 * 100vw);
			height: 103%;
		}
	}
	.royal-staff-item {
		width: calc(621 / 750 * 100vw);
		height: auto;
		padding-top: calc(80 / 750 * 100vw);
		background-size: auto 100%;
		font-size: calc(36 / 750 * 100vw);
		aspect-ratio: 1 / 1;
	}
}

/* introduction
--------------------------------------------------*/
.introduction-lead {
	margin-top: 30px;
	font-size: 20px;
	text-align: center;
	line-height: 1.8;
}
.area-tabs-nav {
	margin-top: 75px;
}
.area-panels {
	margin-top: 115px;
}
.area-tabs {
	display: flex;
	justify-content: space-between;
	li {
		width: auto;
	}
	button {
		padding: 0;
		color: #000000;
		font-size: 27px;

		font-weight: 600;
		font-family: "Noto Serif JP", serif;
		background-color: transparent;
		border: none;
		cursor: pointer;
		letter-spacing: 0.2em;
		transition: .2s ease-in-out;
		&::after {
			content: "";
			opacity: 0;
			display: block;
			width: 100%;
			height: 30px;
			background: url(/stores/royalstaff/images/area-tab-hover-image.png) no-repeat center center / auto;
			transform: translate(-8px, 8px);
			transition: .2s ease-in-out;
		}
	}
}

.staff-profile {
	position: relative;
}
.staff-profile-image {
	position: absolute;
	left: 25px;
	top: 0;
	width: 250px;
	height: 250px;
	img {
		border-radius: 50%;
	}
}
.staff-profile-header {
	margin-left: 312px;
	font-weight: 600;
}
.staff-profile-name {
	display: block;
	width: fit-content;
	font-size: 40px;
	letter-spacing: calc(200 * 40px / 1000);
}
.staff-profile-resvLink-wrap {
	small {
		margin-top: 5px;
	}
}
.staff-profile-shop {
	margin-top: 20px;
	dt {
		margin-bottom: 0px;
		font-size: 18px;
		font-weight: 700;
	}
	dd {
		font-size: 22px;
		font-weight: 700;
	}
}
.staff-profile-text {
	font-size: 18px;
}
.staff-profile-info-list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px 50px;
	margin-top: 50px;
	dt {
		margin-bottom: 10px;
		color: #1e495d;
		font-size: 18px;
		font-family: "Noto Sans JP", sans-serif;
		font-weight: 700;
	}
	dd {
		line-height: 1.6;
		font-weight: 600;
	}
	.qual, .genre, .travExp {
		display: grid;
		gap: 5px;
	}
}
.staff-profile-gallery {
	display: flex;
	margin-top: 100px;
	gap: 12px;
	height: 323px;
	>* {
		flex: 1;
	}
}
.staff-profile-gallery-image-wrap {
	padding-bottom: calc(506 / 675 * 100%);
}
@media (min-width: 769px) {
	.area-tabs {
		button:hover {
			color: #0f86be;
			&::after {
				opacity: 1;
				transform: translate(0);
			}
		}
	}
	.area-tabs {
		[aria-selected="true"] {
			color: #0f86be;
			&::after {
				opacity: 1;
				transform: translate(0);
			}
		}
	}
	.introduction {
		padding-bottom: 200px;
	}
	.staff-profile-resvLink-wrap {
		margin-top: 30px;
		margin-left: 312px;
	}
	.staff-profile-resvLink {
		width: 392px;
		height: 60px;
	}
	.staff-profile-shop {
		margin-left: 312px;
	}
	.staff-profile-text, .staff-profile-info {
		width: 1138px;
		margin-inline: auto;
	}
	.staff-profile-text {
		margin-top: 35px;
	}
	.staff-profile-info-item {
		width: calc(100% / 3 - 34px);
	}
	.staff-profile-name:hover, .staff-profile-shopLink:hover {
		color: #0f86be;
	}
}
@media (max-width: 768px) {
	.introduction-lead {
		padding-inline: 10px;
		font-size: calc(30 / 750 * 100vw);
		text-align: left;
		line-height: 1.6;
	}
	.area-tabs-nav {
		margin-top: 40px;
	}
	.area-tabs {
		flex-wrap: wrap;
		gap: 2px;
		margin-top: 2px;
		li {
			width: calc(50% - 1px);
		}
		li:last-of-type {
			width: 100%;
		}
		button {
			position: relative;
			display: flex;
			align-items: center;
			justify-content: center;
			flex-direction: column;
			width: 100%;
			height: calc(80 / 750 * 100vw);
			background-color: #f0efed;
			font-size: calc(36 / 750 * 100vw);
			text-align: center;
			&::after {
				display: none;
			}
		}
		[aria-selected="true"] {
			background-color: #ffffff;
			color: #0f86be;
			&::after {
				opacity: 1;
				display: block;
				width: calc(33 / 750 * 100vw);
				height: calc(4 / 750 * 100vw);
				margin-inline: auto;
				border-radius: 50%;
				background-color: #0f86be;
				transform: translate(0);
			}
		}
	}
	.area-panels {
		margin-top: 40px;
	}
	.staff-profile+.staff-profile {
		margin-top: 40px;
	}
	.staff-profile-image {
		width: calc(260 / 750 * 100vw);
		left: 0;
	}
	.staff-profile-header {
		display: flex;
		align-items: center;
		height: calc(260 / 750 * 100vw);
		margin-left: calc(290 / 750 * 100vw);
	}
	.staff-profile-name {
		font-size: calc(50 / 750 * 100vw);
	}
	.staff-profile-resvLink-wrap {
		width: calc(600 / 750 * 100vw);
		margin: calc(40 / 750 * 100vw) auto 0;
	}
	.staff-profile-resvLink {
		height: calc(100 / 750 * 100vw);
	}
	.staff-profile-shop {
		width: calc(600 / 750 * 100vw);
		margin-inline: auto;
		dt {
			font-size: calc(32 / 750 * 100vw);
		}
		dd {
			font-size: calc(36 / 750 * 100vw);
		}
	}
	.staff-profile-text {
		margin-top: 30px;
		font-size: calc(34 / 750 * 100vw);
	}
	.staff-profile-info {
		gap: 30px 50px;
		dt {
			margin-bottom: 5px;
			font-size: calc(36 / 750 * 100vw);
			;
		}
		dd {
			line-height: 1.5;
		}
	}
	.staff-profile-gallery {
		margin-top: 50px;
	}
}

[class$="-content"] {
	p {
		letter-spacing: 0.1em;
		text-align: justify;
	}
}

/* consult
--------------------------------------------------*/
.consult {
	background-color: #f0efed;
	.title-lv2-en-lg {
		top: -88px;
		left: -54px;
		right: auto;
		color: #ffffff;
	}
}
.consult-content {
	display: flex;
	gap: 30px;
}
@media (min-width: 769px) {
	.consult-image {
		flex: 0 0 300px;
	}
}
@media (max-width: 768px) {
	.consult {
		.title-lv2-en-lg {
			top: -9vw;
			left: -5.5vw;
		}
	}
	.consult-content {
		display: block;
	}
	.consult-text {
		font-size: calc(32 / 750 * 100vw) !important;
	}
	.consult-image {
		width: calc(550 / 750 * 100vw);
		margin-inline: auto;
	}
	.consult-image-wrap {
		padding-bottom: calc(468 / 550 * 100%);
	}
}

/* reviews
--------------------------------------------------*/
.reviews-content {
	display: grid;
	gap: 60px 14px;
}

.reviews-staff-image {
	figure {
		display: flex;
		align-items: center;
		flex-direction: column;
	}
}

@media (min-width: 769px) {
	.reviews-desc-wrap {
		display: flex;
		align-items: flex-start;
		gap: 35px;
	}
	.reviews-staff-image {
		flex: 0 0 170px;
		margin-left: 10px;
		img {
			border-radius: 10px 10px 0 0;
		}
	}
	.reviews-images {
		display: flex;
		justify-content: space-between;
		gap: 50px;
	}
	.reviews-staff-image-caption {
		position: relative;
		font-family: "Noto Sans JP", serif;
		text-align: center;
		._line1 {
			display: block;
			width: 171px;
			margin-inline: auto;
			margin-top: -11px;
			padding: 2px;
			border-radius: 0 0 5px 5px;
			background-color: #16415e;
			color: #ffffff;
			font-size: 12px;

			font-weight: 500;
		}
		._line2 {
			white-space: nowrap;
			letter-spacing: 0.1em;
			font-weight: 700;
		}
	}
}
@media (max-width: 768px) {
	.reviews-content {
		gap: 40px;
	}
	.reviews-staff-image {
		width: calc(550 / 750 * 100vw);
		margin-inline: auto;
		figure {
			flex-direction: row;
			gap: 20px;
			img {
				width: calc(188 / 750 * 100vw);
				border-radius: 50%;
			}
		}
	}
	.reviews-staff-image-caption {
		font-size: calc(36 / 750 * 100vw);
		text-align: left;
		._line1 {
			display: none;
		}
	}
	.reviews-text {
		font-size: calc(32 / 750 * 100vw);
	}
	.reviews-images {
		width: calc(550 / 750 * 100vw);
		margin-inline: auto;
		figure:nth-child(2), figure:nth-child(3) {
			display: none;
		}
	}
}

.staff-list-link {
	position: relative;
	margin-inline: auto;
	padding-left: 35px;
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	border-top-left-radius: 27px;
	border-bottom-left-radius: 27px;
	text-align: center;
	&::before {
		content: "";
		position: absolute;
		inset: 0;
		left: 3px;
		width: 47px;
		height: 100%;
		background: url(/stores/royalstaff/images/logo-royal-staff-circle.png) no-repeat left center / 100%;
	}
	&::after {
		content: "";
		position: absolute;
		right: 16px;
		width: 11px;
		height: 11px;
		border-top: solid 2px #ffffff;
		border-right: solid 2px #ffffff;
		transform: rotate(45deg);
	}
}
@media (min-width: 769px) {
	.staff-list-link {
		position: relative;
		width: 352px;
		height: 53px;
	}
}
@media (max-width: 768px) {
	.staff-list-link {
		height: calc(100 / 750 * 100vw);
		padding-left: calc(50 / 750 * 100vw);
		border-top-left-radius: calc(50 / 750 * 100vw);
		border-bottom-left-radius: calc(50 / 750 * 100vw);
		font-size: calc(36 / 750 * 100vw);
		line-height: 1.14;
		&::before {
			left: 1vw;
			width: calc(88 / 750 * 100vw);
		}
	}
}

/* .splide
-----------------------------------------------------*/
.splide {
	position: relative;
}
.splide__slide {
	transition: opacity 0.2s ease-in-out !important;
}
.splide__arrow {
	/* position: absolute;
  z-index: 1; */
	position: absolute;
	z-index: 1;
	display: flex;
	align-items: flex-start;
	height: 100%;
	width: 50px;
	padding: 0;
	border: none;
	background: transparent;
	cursor: pointer;
	transition: .2s ease-in-out;
	&::before {
		content: "";
		position: relative;
		top: 105px;
		display: block;
		width: 100%;
		height: auto;
		aspect-ratio: 1 / 1;
		background: url(/stores/royalstaff/images/slide-arrow.png) no-repeat center center / 100%;
		border-radius: 50%;
		transition: .2s ease-in-out;
	}
	svg {
		display: none;
	}
}
.splide__arrow--prev {
	left: 0;
}
.splide__arrow--next {
	right: 0;
	&::before {
		transform: scale(-1, 1);
	}
}
.splide__pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 50px;
	gap: 25px;
}
.splide__pagination__page {
	border: none;
	width: 10px;
	height: 10px;
	background-color: #d5d5d5;
	border-radius: 9999px;
	padding: 0;
	cursor: pointer;
	transition: .2s ease-in-out;
}
.splide__pagination__page.is-active {
	background-color: #5d5d5d;
}
.splide.is-single .splide__arrows,
.splide.is-single .splide__pagination {
	display: none !important;
	pointer-events: none;
	visibility: hidden;
	/* optional */
}

.accordion {
	>p {
		max-height: 312px;
		overflow-y: hidden;
		transition: max-height 1s ease;
	}
}
.accordion.open {
	>p {
		max-height: 1500px;
	}
}
.btn-more-wrap {
	position: relative;
	text-align: right;
	&::after {
		content: '';
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 180px;
		pointer-events: none;
	}
}
.btn-more {
	display: inline-flex;
	align-items: baseline;
	margin-top: 30px;
	border: none;
	background: transparent;
	color: #5d5d5d;
	font-size: 17px;
	font-weight: 500;
	cursor: pointer;
	position: relative;
	z-index: 1;
	font-family: "Noto Serif JP", serif;
	&::after {
		content: "";
		display: inline-block;
		width: 12px;
		height: 10px;
		margin-left: 3px;
		background: #5d5d5d;
		clip-path: polygon(0 0, 50% 100%, 100% 0);
	}
}
.accordion.open {
	.btn-more-wrap .btn-more {
		&::after {
			clip-path: polygon(0% 100%, 50% 0%, 100% 100%);
		}
	}
}

.consult-slide-container {
	.btn-more-wrap {
		&::after {
			background: linear-gradient(to top,
					rgba(240, 239, 237, 1) 30%,
					rgba(240, 239, 237, 0) 100%
				);
			pointer-events: none;
		}
	}
}
.reviews-slide-container {
	.splide__arrow {
		&::before {
			border: 1px solid #9a9a9a;
		}
	}
	.btn-more-wrap {
		&::after {
			background: linear-gradient(to top,
					rgba(255, 255, 255, 1) 20%,
					rgba(255, 255, 255, 0) 100%
				);
			pointer-events: none;
		}
	}
}
.accordion.open {
	.btn-more-wrap::after {
		background: transparent
	}
}
@media (min-width: 769px) {
	.splide__track {
		width: 1005px;
		margin-inline: auto;
	}
	.splide__arrow--prev:hover {
		&::before {
			transform: translateX(-3px);
		}
	}
	.splide__arrow--next:hover {
		&::before {
			transform: scale(-1, 1) translateX(-3px);
		}
	}
	.splide__pagination__page:hover {
		background-color: #5d5d5d;
	}
	[data-pc-accordion="false"] {
		max-height: initial;
		.btn-more-wrap {
			display: none;
		}
	}
	.btn-more-wrap:hover {
		.btn-more {
			&::after {
				background: #15425e;
				transform: translateY(1px);
			}
		}
	}
	.accordion.open {
		.btn-more-wrap:hover {
			.btn-more {
				&::after {
					background: #15425e;
					transform: translateY(-1px);
				}
			}
		}
	}
}
@media (max-width: 768px) {
	.has-slide {
		padding-bottom: 85px;
	}
	.splide__arrow {
		width: calc(57 / 750 * 100vw);
	}
	.splide__arrow--prev {
		left: -3vw;
	}
	.splide__arrow--next {
		right: -3vw;
	}
	.splide__pagination {
		gap: 30px;
		margin-top: 40px;
	}
	.splide__pagination__page {
		width: calc(30 / 750 * 100vw);
		height: calc(30 / 750 * 100vw);
	}
	.splide {
		.title-lv3 {
			padding-top: calc(110 / 750 * 100vw);
		}
	}
	.consult-slide-container {
		.splide__arrow {
			&::before {
				position: relative;
				top: calc(520 / 750 * 100vw)
			}
		}
	}
	.reviews-slide-container {
		.splide__arrow {
			&::before {
				position: relative;
				top: calc(205 / 750 * 100vw)
			}
		}
	}
	.accordion {
		>p {
			max-height: calc(520 / 750 * 100vw)
		}
	}
}

/* ページトップへ戻る
----------------------------------------------- */
.btn-pagetop {
	border: none;
	opacity: 0;
	position: fixed;
	bottom: 30px;
	right: 30px;
	z-index: 1;
	width: 60px;
	height: 60px;
	padding-top: 5px;
	background-color: rgba(22, 65, 94, .4);
	color: #ffffff;
	font-size: 14px;
	cursor: pointer;
	z-index: 8;
	transform: translateY(10px);
	transition: .2s ease-in-out;
}
.btn-pagetop::before {
	content: "";
	display: block;
	width: 12px;
	height: 12px;
	margin: auto;
	border-top: solid 1px #ffffff;
	border-right: solid 1px #ffffff;
	transform: rotate(-45deg);
	transition: .3s ease-in-out;
}
.btn-pagetop.is-visible {
	opacity: 1;
	transform: translateY(0);
}
@media (min-width: 769px) {
	.btn-pagetop:hover {
		background-color: rgba(22, 65, 94, .6);
	}
	.btn-pagetop:hover::before {
		position: relative;
		top: -1px;
	}
}
@media (max-width: 768px) {
	.btn-pagetop {
		bottom: 15px;
		right: calc(30 / 750 * 100vw);
	}
}