@charset "utf-8";

main .ttl {
	margin-top: 5rem;
}

/* anchor */
main .anchor {
	margin-top: 6rem;
}
main .anchor ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 2rem 1.66%;
}
main .anchor ul li {
	width: 27.5%;
	border: solid 0.2rem var(--mainColor);
	border-radius: 1.5rem;
}
main .anchor ul li a {
	padding: 1.9rem 0.8rem;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1.37;
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 700;
	font-style: normal;
	text-align: center;
	position: relative;
}
main .anchor ul li a::before,
main .anchor ul li a::after {
	display: block;
	content: '';
	width: 0.3rem;
	height: 1.2rem;
	background-color: var(--mainColor);
	border-radius: 0.2rem;
	position: absolute;
	top: calc(50% - 0.6rem);
	right: 2rem;
	transform-origin: center 92%;
}
main .anchor ul li a::before {
	transform: rotate(45deg);
}
main .anchor ul li a::after {
	transform: rotate(-45deg);
}
@media (max-width: 768px) {
	main .anchor {
		margin-top: 5rem;
	}
	main .anchor ul {
		justify-content: flex-start;
		flex-wrap: wrap;
		gap: 2.2rem 3.1%;
	}
	main .anchor ul li {
		width: 48.4%;
		height: 9.4rem;
		border-width: 0.3rem;
		border-radius: 2.5rem;
	}
	main .anchor ul li a {
		padding: 1.5rem;
		font-size: 2.4rem;
	}
	main .anchor ul li a::before,
	main .anchor ul li a::after {
		width: 0.4rem;
		height: 1.6rem;
		top: calc(50% - 0.8rem);
		right: 2.8rem;
	}
}

/*  */
main .services {
	margin-top: 5rem;
	padding: 6rem 0;
	font-weight: 400;
	line-height: 1.68;
	position: relative;
}
main .services::before {
	display: block;
	content: '';
	width: calc(100% - 5rem);
	height: 100%;
	border-radius: 0 4rem 4rem 0;
	background-color: var(--subColor);
	position: absolute;
	top: 0;
	right: 5rem;
	z-index: -1;
}
@media (max-width: 1360px) {
	main .services::before {
		width: 100%;
		right: 0;
	}
}
@media (max-width: 768px) {
	main .services {
		padding: 5rem 0;
		line-height: 1.5;
	}
}

/* box */
main .services .box {
	padding: 5rem 7rem;
	background-color: var(--whiteColor);
	border-radius: 3rem;
}
main .services .box + .box {
	margin-top: 5rem;
}
main .services h2 {
	font-size: 3.4rem;
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 700;
	font-style: normal;
	text-align: center;
}
main .services h3 {
	font-size: 2.6rem;
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 700;
	font-style: normal;
	text-align: center;
}
main .services .lead {
	margin-top: 2rem;
	text-align: center;
}
@media (max-width: 768px) {
	main .services .box {
		padding: 5rem 4rem 6.5rem;
	}
	main .services h2 {
		font-size: 3.8rem;
	}
	main .services h3 {
		font-size: 3.2rem;
	}
	main .services .lead {
		font-size: 2.6rem;
	}
}

/* scroll */
@media (max-width: 767px) {
	main .services .scroll {
		overflow: auto;
		word-wrap: break-word
	}
	main .services .scroll .tbl {
		margin-bottom: 3rem;
		width: 110rem;
	}
	main .services .scroll .tbl dl dt {
		width: 20rem;
	}
	main .services .scroll .tbl dl dd {
		word-wrap: break-word
	}
	main .services .scroll .tbl dl dd:nth-child(2) {
		width: 30rem;
	}
	main .services .scroll .tbl dl dd:nth-child(3) {
		width: 60rem;
	}
	.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
		height: 1.4rem;
	}
	.simplebar-scrollbar::before {
		background: var(--mainColor);
	}
	.simplebar-track.simplebar-horizontal {
		height: 2.4rem;
	}
	.simplebar-track {
		background: var(--subColor);
	}
	.simplebar-scrollbar.simplebar-visible::before {
		opacity: 1;
	}
	.simplebar-content-wrapper::-webkit-scrollbar { /*-- iOSでデフォルトのスクロールバーを非表示 --*/
		display: none;
		-webkit-appearance: none;
	}
}

/* info */
main .services .info h3 {
	margin-top: 4rem;
}
main .services .info .tbl {
	margin-top: 4rem;
	border-bottom: solid 1px var(--grayColor);
}
main .services .info .tbl > div {
	display: flex;
	width: 100%;
	border-top: solid 1px var(--grayColor);
}
main .services .info .tbl > div:first-child {
	background-color: #f5f5f5;
	font-weight: 700;
}
main .services .info .tbl p {
	flex-shrink: 0;
	padding: 2rem;
	width: 50%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: center;
}
main .services .info .tbl p + p {
	border-left: solid 1px var(--grayColor);
}
main .services .info .tbl > div:nth-child(3) p {
	width: 100%;
}
@media (max-width: 768px) {
	main .services .info h3 {
		margin-top: 6rem;
	}
	main .services .info .tbl {
		border-width: 0.2rem;
	}
	main .services .info .tbl > div {
		border-width: 0.2rem;
	}
	main .services .info .tbl p {
		padding: 2.2rem 2rem;
		font-size: 2.6rem;
	}
	main .services .info .tbl p + p {
		border-width: 0.2rem;
	}
	main .services .info .tbl > div:nth-child(3) p {
		text-align: left;
	}
}

/* brand */
main .services .brand .tbl {
	margin-top: 5rem;
	border-bottom: solid 1px var(--grayColor);
}
main .services .brand dl {
	display: flex;
	width: 100%;
	border-top: solid 1px var(--grayColor);
}
main .services .brand dl dt {
	flex-shrink: 0;
	padding: 2rem;
	width: 17%;
	background-color: #f5f5f5;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-weight: 700;
}
main .services .brand dl dd {
	flex-shrink: 0;
	padding: 2rem;
	width: 83%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
main .services .brand dl dd.card p {
	width: 53.3rem;
}
main .services .brand dl dd.emoney p {
	width: 65.9rem;
}
main .services .brand dl dd.code p {
	width: 64.4rem;
}
main .services .brand .note {
	margin-top: 2.5rem;
	padding-left: 1em;
	text-indent: -1em;
	font-size: 1.4rem;
}
@media (max-width: 768px) {
	main .services .brand .tbl {
		border-width: 0.2rem;
	}
	main .services .brand dl {
		border-width: 0.2rem;
		flex-direction: column;
	}
	main .services .brand dl dt {
		padding: 2.5rem 2rem;
		width: 100%;
		font-size: 2.6rem;
	}
	main .services .brand dl dd {
		padding: 3.2rem 2rem;
		width: 100%;
		font-size: 2.6rem;
		text-align: center;
	}
	main .services .brand dl dd.card p {
		width: 94%;
	}
	main .services .brand dl dd.emoney p {
		width: 100%;
	}
	main .services .brand dl dd.code p {
		width: 100%;
	}
	main .services .brand .note {
		margin-top: 2rem;
		font-size: 2.3rem;
	}
}

/* restroom */
main .services .restroom h3 {
	margin-top: 4rem;
}
main .services .restroom .tbl {
	margin-top: 4rem;
	border-bottom: solid 1px var(--grayColor);
}
main .services .restroom dl {
	display: flex;
	width: 100%;
	border-top: solid 1px var(--grayColor);
}
main .services .restroom dl:first-child {
	background-color: #f5f5f5;
	font-weight: 700;
	text-align: center;
}
main .services .restroom dl dt {
	flex-shrink: 0;
	padding: 2rem;
	width: 18.86%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-weight: 700;
}
main .services .restroom dl dd {
	flex-shrink: 0;
	padding: 2rem;
	width: 40.56%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-left: solid 1px var(--grayColor);
}
main .services .restroom dl dd p + p {
	margin-top: 1rem;
}
main .services .restroom dl dd p.linkTxt02 {
	margin-top: 0.5rem;
}
@media (max-width: 768px) {
	main .services .restroom h3 {
		margin-top: 6rem;
	}
	main .services .restroom .tbl {
		border-width: 0.2rem;
	}
	main .services .restroom dl {
		border-width: 0.2rem;
	}
	main .services .restroom dl dt {
		padding: 2.2rem 2rem;
		width: 27.86%;
		font-size: 2.6rem;
	}
	main .services .restroom dl dd {
		padding: 2.2rem 2rem;
		width: 36.06%;
		font-size: 2.6rem;
		border-width: 0.2rem;
	}
	main .services .restroom dl dd p + p {
		margin-top: 1.5rem;
	}
}

/* rental */
main .services .rental h3 {
	margin-top: 4rem;
}
main .services .rental .tbl {
	margin-top: 4rem;
	border-bottom: solid 1px var(--grayColor);
}
main .services .rental dl {
	display: flex;
	width: 100%;
	border-top: solid 1px var(--grayColor);
}
main .services .rental dl:first-child {
	background-color: #f5f5f5;
	font-weight: 700;
	text-align: center;
}
main .services .rental dl dt {
	flex-shrink: 0;
	padding: 2rem;
	width: 18.86%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-weight: 700;
}
main .services .rental dl dd {
	flex-shrink: 0;
	padding: 2rem;
	width: 40.56%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-left: solid 1px var(--grayColor);
}
main .services .rental dl dd p + p {
	margin-top: 1rem;
}
main .services .rental dl dd p.linkTxt02 {
	margin-top: 0.5rem;
}
main .services .rental .note {
	margin-top: 0.5rem;
	font-size: 1.4rem;
}
@media (max-width: 768px) {
	main .services .rental h3 {
		margin-top: 6rem;
	}
	main .services .rental .tbl {
		border-width: 0.2rem;
	}
	main .services .rental dl {
		border-width: 0.2rem;
	}
	main .services .rental dl dt {
		padding: 2.2rem 2rem;
		width: 27.86%;
		font-size: 2.6rem;
	}
	main .services .rental dl dd {
		padding: 2.2rem 2rem;
		width: 36.06%;
		font-size: 2.6rem;
		border-width: 0.2rem;
	}
	main .services .rental dl dd p + p {
		margin-top: 1.5rem;
	}
	main .services .rental .note {
		margin-top: 1rem;
		font-size: 2.3rem;
	}
}

/* kids */
main .services .kids h3 {
	margin-top: 4rem;
}
main .services .kids .tbl {
	margin-top: 4rem;
	border-bottom: solid 1px var(--grayColor);
}
main .services .kids dl {
	display: flex;
	width: 100%;
	border-top: solid 1px var(--grayColor);
}
main .services .kids dl dt {
	flex-shrink: 0;
	padding: 2rem;
	width: 18.86%;
	background-color: #f5f5f5;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-weight: 700;
}
main .services .kids dl dd {
	flex-shrink: 0;
	padding: 2rem;
	width: 81.13%;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
@media (max-width: 768px) {
	main .services .kids h3 {
		margin-top: 6rem;
	}
	main .services .kids .tbl {
		border-width: 0.2rem;
	}
	main .services .info dl {
		border-width: 0.2rem;
	}
	main .services .kids dl dt {
		padding: 2.2rem 2rem;
		width: 27.86%;
		font-size: 2.6rem;
	}
	main .services .kids dl dd {
		padding: 2.2rem 2rem;
		width: 72.13%;
		font-size: 2.6rem;
	}
}

/* facilities */
main .services .facilities h3 {
	margin-top: 4rem;
}
main .services .facilities .tbl {
	margin-top: 4rem;
	border-bottom: solid 1px var(--grayColor);
}
main .services .facilities dl {
	display: flex;
	width: 100%;
	border-top: solid 1px var(--grayColor);
}
main .services .facilities dl:first-child {
	background-color: #f5f5f5;
	font-weight: 700;
	text-align: center;
}
main .services .facilities dl dt {
	flex-shrink: 0;
	padding: 2rem;
	width: 18.86%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-weight: 700;
}
main .services .facilities dl dd {
	flex-shrink: 0;
	padding: 2rem;
	width: 40.56%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-left: solid 1px var(--grayColor);
}
main .services .facilities dl dd p.linkTxt02 {
	margin-top: 0.5rem;
}
@media (max-width: 768px) {
	main .services .facilities h3 {
		margin-top: 6rem;
	}
	main .services .facilities .tbl {
		border-width: 0.2rem;
	}
	main .services .facilities dl {
		border-width: 0.2rem;
	}
	main .services .facilities dl dt {
		padding: 2.2rem 2rem;
		width: 27.86%;
		font-size: 2.6rem;
	}
	main .services .facilities dl dd {
		padding: 2.2rem 2rem;
		width: 36.06%;
		font-size: 2.6rem;
		border-width: 0.2rem;
	}
}

/* before Open */
main .services .box .tbl .csOpen {
	padding: 1.5rem 2rem 2.5rem;
	position: relative;
}
main .services .box .tbl .csOpen::before {
	display: block;
	content: '2024年9月オープン';
	font-size: 1.2rem;
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 700;
	font-style: normal;
	color: #e84558;
	position: absolute;
	bottom: 0.6rem;
	left: calc(50% - 4.5em);
}
@media (max-width: 768px) {
	main .services .box .tbl .csOpen {
		padding: 0.8rem 2rem 3.2rem;
	}
	main .services .box .tbl .csOpen::before {
		font-size: 1.8rem;
		line-height: 1;
		bottom: 1.2rem;
	}
}