body {
	background-color: #0B233D;
}

footer.footer  {
	padding-top: 0;
}

footer.footer .footer__icons {
	display: none;
}

@keyframes fadeInUp {
	0% {
			opacity: 0;
			transform: translateY(20px);
	}
	100% {
			opacity: 1;
			transform: translateY(0);
	}
}

.page-membership .membership-section {
	position: relative;
	display: flex;
	color: #fff;
	margin-top: -81px;
	width: 100%;
	min-height: 900px;
	height: 100vh;
}

.membership-title {
	font-family: "dnp-shuei-gothic-gin-std", sans-serif;
  font-optical-sizing: auto;
	writing-mode: vertical-lr;
	letter-spacing: 0.1em;
	font-size: 16px;
	font-weight: 600;
	position: absolute;
	top: 50%;
	right: 36px;
	transform: translateY(-50%);
}

.page-membership .membership-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 1000px;
	margin: 0 auto;
	gap: 115px;
	opacity: 0;
	animation: fadeInUp 1s ease-out forwards 0.5s;
}

.page-membership .membership-visual {
	text-align: center;
}

.page-membership .membership-visual-image {
	position: relative;;
}

.page-membership .membership-visual-image::after {
	content: "";
	display: block;
	width: 104px;
	height: 104px;
	position: absolute;
	bottom: -12px;
	right: -38px;
	background:  url(../../img/membership/app_icon.png) no-repeat center;
	background-size: 100% auto
}

.page-membership .membership-visual__img {
	max-width: 266px;
	height: auto;
}

.membership-visual__caption {
	color: #fff;
	font-size: 10px;
	line-height: 16.74px;
	text-align: center;
	margin-top: 22px;
	opacity: 0.6;
}

.page-membership .membership-content {
	max-width: 500px;
}

.page-membership .membership-heading {
	margin-bottom: 24px;
	font-size: 28px;
	line-height: 1.53571429;
	letter-spacing: 0.11em;
	text-align: center;
	vertical-align: middle;
}

.page-membership .membership-paragraph__text {
	text-align: center;
	font-size: 14px;
	line-height: 1.8;
	letter-spacing: 0.11em;
	text-align: center;
	vertical-align: middle;
	margin-bottom: 16px;
}

.page-membership .membership-sns {
	text-align: center;
	margin-top: 40px;
}

.page-membership .membership-sns__text {
	font-size: 12px;
	margin-bottom: 16px;
}

.page-membership .membership-sns__icons {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
}

.page-membership .membership-sns__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	overflow: hidden;
	font-size: 26px;
	transition: 0.3s ease-in-out;
}

.page-membership .membership-sns__icon:hover {
	opacity: 0.7;
}

.page-membership .membership-sns__icon.icon-instagram {
	color: #000000;
	background-color: #ffffff;
}

.page-membership .membership-sns__icon.icon-x {
	color: #ffffff;
	background-color: #000000;
}

.page-membership .membership-link {
	margin-top: 36px;
	text-align: center;
}

.page-membership .membership-link__text {
	display: inline-block;
	color: #fff;
	font-size: 12px;
	padding-top: 36px;
	border-top: 1px solid rgba(255,255,255,0.3);
}

.page-membership .membership-link__anchor {
	text-decoration: underline;
}

.page-membership .membership-link__anchor:hover {
	text-decoration: none;
}

.membership-sns--pc {
	display: block;
}

.membership-sns--sp {
	display: none;
}

.sp-only {
	display: none;
}

@media screen and (max-width: 900px) {
	.pc-only {
		display: none;
	}

	.sp-only {
			display: block;
	}

	.membership-title {
		display: none;
	}

	.page-membership .membership-section { 
			min-height: 100vh;
			height: auto;
			margin-top: 0;
	}

	.page-membership .membership-inner {
			flex-direction: column;
			gap: 28px;
			padding: 128px 20px 8px 20px;
	}
	
	.page-membership .membership-visual {
			order: 2;
	}

	.page-membership .membership-visual-image::after {
		width: 72px;
		height: 72px;
		right: -13px;
		bottom: -10px;
	}

	.page-membership .membership-visual__img {
			max-width: 207px;
	}

	.page-membership .membership-content {
			order: 1;
			max-width: 100%;
	}

	.page-membership .membership-heading {
			font-size: 20px;
	}

	.page-membership .membership-paragraph__text {
			font-size: 12px;
			margin-bottom: 12px;
	}

	.page-membership .membership-sns {
			margin-top: 51px
	}

	.membership-sns--pc {
		display: none;
	}

	.membership-sns--sp {
			display: block;
	}

	.page-membership .membership-sns__icons {
			gap: 24px;
	}

	.page-membership .membership-sns__icon {
			width: 36px;
			height: 36px;
			font-size: 20px;
	}

	.page-membership .membership-link {
		margin-top: 30px;
	}

	.page-membership .membership-link__text {
			padding-top: 30px;
	}

	.page-membership .membership-visual__caption {
			margin-top: 80px;
	}

}