@charset "UTF-8";

/* Googleフォント用 */
.outfit-custom {
	font-family: "Outfit", sans-serif;
	font-weight: 400;
	font-style: normal;
}

/* base */
.architectureType2018 #wrap #mainArea {
	margin-bottom: 0;
	background: #f6f1ed;
}
#wrap #mainArea {
	font-size: 2.4rem;
	font-family: "Zen Kaku Gothic New", sans-serif; /* Googleフォント */
	font-weight: 500;
	font-style: normal;
	line-height: 2;
	color: #202422;
}
#pageTop {
	display: none !important;
}

/* sustainaPayColor */
.sustainaPayColor01 {
	color: #009328;
}

/* sustainaPayAccBlock */
.sustainaPayAccBlock01 > .blockInner {
	border-radius: 56px;
	border: solid 1px #202422;
}
.sustainaPayAccBlock01 > .blockInner > .blockTitle {
	padding: 21px 30px;
	background: transparent;
	border-bottom: solid 1px #202422;
	font-size: 3.2rem;
	line-height: 2.4;
}
.sustainaPayAccBlock01 > .blockInner > .blockTitle .ttl {
	transition: 0.4s;
}
.sustainaPayAccBlock01 > .blockInner > .blockTitle:hover .ttl {
	opacity: 0.5;
}
#wrap .sustainaPayAccBlock01 .jsAccSwitch > *::after {
	content: "" !important;
	display: block;
	width: 36px;
	height: 36px;
	transform: translateY(-50%);
	margin-top: 0;
	background-image: url(/kojin/visa_debit/sustaina_pay/specialty/common/images/common_ico_minus.png);
	background-repeat: no-repeat;
	background-size: cover;
}
#wrap .sustainaPayAccBlock01 .jsAccSwitch[aria-selected="false"] > *::after {
	background-image: url(/kojin/visa_debit/sustaina_pay/specialty/common/images/common_ico_plus.png);
}
.sustainaPayAccBlock01 > .blockInner > .blockDetail {
	background: transparent;
}

/* sustainaPayBtn */
.sustainaPayBtn01 {
	display: inline-block;
	position: relative;
	padding: 22px 30px;
	background: #009328;
	border-radius: 500px;
	font-weight: 700;
	line-height: 1.5;
	color: #fff;
	transition: background-color 0.4s;
	box-sizing: border-box;
}
.sustainaPayBtn01:visited {
	color: #fff;
}
.sustainaPayBtn01:hover {
	background: #202422;
	color: #fff;
}
.sustainaPayBtn01 > span {
	display: inline-block;
}
.sustainaPayBtn01[class*="sustainaPayBtnArrow"] > span {
	padding: 0 40px;
}
.sustainaPayBtn01[class*="sustainaPayBtnArrow"] > span::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background-repeat: no-repeat;
	background-size: cover;
	transition: transform 0.4s;
}
.sustainaPayBtn01.sustainaPayBtnArrowRight01 > span::after {
	right: 30px;
	width: 36px;
	height: 28px;
	background-image: url(/kojin/visa_debit/sustaina_pay/specialty/common/images/common_arrow_01.png);
}
.sustainaPayBtn01.sustainaPayBtnArrowRight01:hover > span::after {
	transform: translateX(4px) translateY(-50%);
}

/* sustainaPayTextLink */
.sustainaPayTextLink01 {
	display: inline-block;
	position: relative;
	font-size: 2rem;
	line-height: 1.8;
	color: #009328 !important;
}
.sustainaPayTextLink01 > span {
	display: inline-block;
	position: relative;
}
.sustainaPayTextLink01 > span::before {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 2px;
	background: #009328;
	transform: scaleX(1);
	transform-origin: right;
	transition: transform 0.4s;
}
.sustainaPayTextLink01:hover > span::before {
	transform: scaleX(0);
}

/* sustainaPayLinkArrow */
*[class*="sustainaPayLinkArrow"] {
	padding-right: 30px;
}
*[class*="sustainaPayLinkArrow"]::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	background-repeat: no-repeat;
	background-size: cover;
	transition: transform 0.4s;
}
.sustainaPayLinkArrowRight01::after {
	background-image: url(/kojin/visa_debit/sustaina_pay/specialty/common/images/common_arrow_02.png);
}
.sustainaPayLinkArrowRight01:hover::after {
	transform: translateX(4px) translateY(-50%);
}

/* sustainaPayTextMarker */
.sustainaPayTextMarker01 {
	padding-bottom: 2px;
	background: linear-gradient(transparent 60%, #dbefce 60%);
}

/* sustainaPayShareTtl */
.sustainaPayShareTtl01 {
	margin-bottom: 30px;
	font-size: 2rem;
	font-weight: 600;
	text-align: center;
}

/* sustainaPayShareList */
.sustainaPayShareList01 {
	display: flex;
	align-items: center;
	justify-content: center;
}
.sustainaPayShareList01 .listItem:nth-child(n+2) {
	margin-left: 40px;
}
.sustainaPayShareList01 .listItem > a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 88px;
	height: 88px;
	background: #fff;
	border-radius: 50%;
	box-sizing: border-box;
}
.sustainaPayShareList01 .listItem > a > img {
	width: 35px;
	transition: 0.4s;
}
.sustainaPayShareList01 .listItem > a:hover > img {
	opacity: 0.5;
}

/* sustainaPayPageTop */
#sustainaPayPageTop {
	line-height: 1;
	text-align: right;
}
#sustainaPayPageTop > a,
#sustainaPayPageTop > a::before {
	width: 152px;
	height: 78px;
	background-repeat: no-repeat;
	background-size: cover;
}
#sustainaPayPageTop > a {
	display: inline-block;
	position: relative;
	vertical-align: bottom;
	margin-right: 52px;
	background-image: url(/kojin/visa_debit/sustaina_pay/specialty/common/images/common_page_top_01_off.png);
	text-align: left;
	text-indent: -9999px;
	overflow: hidden;
}
#sustainaPayPageTop > a::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-image: url(/kojin/visa_debit/sustaina_pay/specialty/common/images/common_page_top_01_on.png);
	opacity: 0;
	transition: opacity 0.4s;
}
#sustainaPayPageTop > a:hover::before {
	opacity: 1;
}

/* js */
.jsSustainaPayFade {
	opacity: 0;
	transition: 1s;
}
.jsSustainaPayFade.fadeIn {
	opacity: 1;
	transform: translateY(0);
}
.jsSustainaPayFade:not(.fadeIn) {
	transform: translateY(40px);
}

@media screen and (max-width: 767px) {
	/* base */
	#wrap #mainArea {
		font-size: 1.6rem;
		line-height: 2.2;
	}
	#wrap #mainArea main {
		padding: 0 24px 65px;
	}

	/* sustainaPayAccBlock */
	.sustainaPayAccBlock01 > .blockInner {
		border-radius: 8px;
	}
	.sustainaPayAccBlock01 > .blockInner > .blockTitle {
		padding: 30px 15px !important;
		font-size: 2rem;
		line-height: 1.7;
	}
	.sustainaPayAccBlock01 > .blockInner > .blockTitle:hover .ttl {
		opacity: 1;
	}

	/* sustainaPayBtn */
	.sustainaPayBtn01 {
		padding: 19px 20px;
		border-radius: 358px;
		font-size: 1.8rem;
	}
	.sustainaPayBtn01:hover {
		background: #009328;
	}
	.sustainaPayBtn01[class*="sustainaPayBtnArrow"] > span {
		padding: 0 30px;
	}
	.sustainaPayBtn01.sustainaPayBtnArrowRight01 > span::after {
		right: 18px;
		width: 27px;
		height: 22px;
	}
	.sustainaPayBtn01.sustainaPayBtnArrowRight01:hover > span::after {
		transform: translateX(0) translateY(-50%);
	}

	/* sustainaPayTextLink */
	.sustainaPayTextLink01 {
		font-size: 1.4rem;
	}
	.sustainaPayTextLink01:hover > span::before {
		transform: scaleX(1);
	}

	/* sustainaPayLinkArrow */
	*[class*="sustainaPayLinkArrow"] {
		padding-right: 20px;
	}
	*[class*="sustainaPayLinkArrow"]::after {
		width: 16px;
		height: 16px;
	}
	.sustainaPayLinkArrowRight01:hover::after {
		transform: translateX(0) translateY(-50%);
	}

	/* sustainaPayShareTtl */
	.sustainaPayShareTtl01 {
		margin-bottom: 20px;
		line-height: 2;
	}

	/* sustainaPayShareList */
	.sustainaPayShareList01 .listItem:nth-child(n+2) {
		margin-left: 24px;
	}
	.sustainaPayShareList01 .listItem > a:hover > img {
		opacity: 1;
	}

	/* sustainaPayPageTop */
	#sustainaPayPageTop > a {
		margin-right: 24px;
		width: 80px;
		height: 41px;
	}
	#sustainaPayPageTop > a::before {
		content: none;
	}
}
