/**
 * lightning_copyright_before 用：カスタムフッター（全ページ共通）
 */

.custom-site-footer {
	width: 100%;
	background-color: #333;
	color: #fff;
	padding: 56px 0 24px;
}

.custom-site-footer__inner {
	max-width: 1120px;
	margin: 0 auto;
}

.custom-site-footer__main {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	gap: 24px;
	margin-bottom: 56px;
}

.custom-site-footer__contact {
	flex: 0 1 auto;
}

.custom-site-footer__contact p {
	margin: 0;
	font-size: 14px;
	line-height: 1.5;
	color: #fff;
}

.custom-site-footer__contact p:last-child {
	margin-bottom: 0;
}

.custom-site-footer__links {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 24px;
}

.custom-site-footer__link-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 24px;
}

.custom-site-footer__link {
	color: #fff;
	text-decoration: none;
	font-size: 0.9375rem;
}

.custom-site-footer__link:hover {
	color: #fff;
	opacity: 0.7;
}

.custom-site-footer__link--external {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
}

.custom-site-footer__icon-external {
	display: inline-flex;
	width: 1em;
	height: 1em;
}

.custom-site-footer__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	padding: 8px 16px;
	background-color: #6c6c6c;
	color: #fff;
	text-decoration: none;
	font-size: 14px;
	border-radius: 4px;
}

.custom-site-footer__btn:hover {
	background-color: #555;
	color: #fff;
}

.custom-site-footer__btn-icon {
	display: inline-flex;
	width: 1em;
	height: 1em;
}

.custom-site-footer__copyright {
	margin: 0;
	text-align: center;
	font-size: 13px;
	color: #fff;
}

@media (max-width: 767px) {
	.custom-site-footer__main {
		flex-direction: column;
		align-items: center;
		justify-content: center;
		text-align: center;
		margin-bottom: 32px;
	}

	.custom-site-footer__links {
		align-items: flex-start;
	}
}
