/*-------------------------------------------------------------
top-common-ha
-------------------------------------------------------------*/
.top-aruaru-ha-contents-inner {
	counter-increment: head-number;
}
.top-aruaru-ha-section02 {
	position: relative;
	padding-bottom: 350px;
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-section02 {
		padding-bottom: 0;
	}
}

.top-aruaru-ha-img04 {
	width: 300px;
	position: absolute;
	bottom: 0;
	right: 50%;
	transform: translateX(50%);
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-img04 {
		width: 350px;
		right: 0;
		transform: translateX(0);
	}
}

.top-aruaru-ha-img04 img {
	aspect-ratio: 350/495;
}

.top-aruaru-ha-img-wrap {
	display: flex;
	flex-direction: column;
	gap: 20px;
	margin-top: 20px;
}
@media screen and (min-width: 1080px) {
	.top-aruaru-ha-img-wrap {
		flex-direction: row-reverse;
		justify-content: space-between;
		margin-top: 30px;
	}
}

.top-aruaru-ha-img-wrap02 {
	display: flex;
	flex-direction: column-reverse;
}

@media screen and (min-width: 768px) {
	.top-aruaru-ha-img-wrap02 {
		flex-direction: row-reverse;
		justify-content: space-between;
	}
}

@media screen and (min-width: 1080px) {
	.top-aruaru-ha-img {
		max-width: 500px;
	}
}

.top-aruaru-ha-img img {
	aspect-ratio: 16/9;
	object-fit: cover;
}

@media screen and (min-width: 1080px) {
	.top-aruaru-ha-img img {
		aspect-ratio: 500/375;
	}
}

.top-aruaru-ha-img02 {
	max-width: 300px;
	margin-inline: auto;
}
@media screen and (min-width: 1080px) {
	.top-aruaru-ha-img02 {
		max-width: 350px;
		margin: 0;
	}
}

.top-aruaru-ha-img02 img {
	aspect-ratio: 350/495;
	object-fit: contain;
}

.top-aruaru-ha-head {
	display: flex;
	align-items: center;
	font-size: 18px;
	font-weight: 500;
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-head {
		font-size: 20px;
	}
}

.top-aruaru-ha-contents-inner .top-aruaru-ha-head::before {
	content: counter(head-number);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--color-bg-base);
	border-radius: 100vh;
	font-size: 16px;
	width: 25px;
	height: 25px;
	flex-shrink: 0;
}

.top-aruaru-ha-wrap {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

@media screen and (min-width: 768px) {
	.top-aruaru-ha-box {
		max-width: 400px;
	}
}

.top-aruaru-ha-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.top-aruaru-ha-list-item {
	font-size: 18px;
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: 8px;
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-list-item {
		font-size: 20px;
	}
}

.top-aruaru-ha-list-item--check::before {
	content: '';
	width: 24px;
	height: 19px;
	background-image: url(../img/icon-check.svg);
	background-repeat: no-repeat;
	background-size: contain;
}

.top-aruaru-ha-list-item--triangle::before {
	content: '';
	width: 24px;
	height: 19px;
	background-image: url(../img/icon-triangle.svg);
	background-repeat: no-repeat;
	background-size: contain;
}

.top-aruaru-ha-section02-head-wrap {
	display: flex;
	align-items: center;
	gap: 12px;
}

.top-aruaru-ha-section02-head {
	font-size: 20px;
	font-weight: 500;
}

.top-aruaru-ha-arrow {
	background-color: var(--color-bg-base);
	display: grid;
	place-items: center;
	width: 25px;
	height: 25px;
	border-radius: 100vh;
}

.top-aruaru-ha-arrow img {
	width: 18px;
	height: 18px;
}

.top-aruaru-ha-flow-item {
	counter-increment: flow-number;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding-left: 16px;
}

@media screen and (min-width: 768px) {
	.top-aruaru-ha-flow-item {
		flex-direction: row;
		gap: 40px;
		padding-left: 24px;
	}
}

.top-aruaru-ha-flow-item:not(:last-child) {
	border-bottom: 1px solid var(--color-bg-primary);
	padding-bottom: 32px;
}

.top-aruaru-ha-flow-item:not(:first-child) {
	padding-top: 32px;
}

.top-aruaru-ha-flow-step {
	color: var(--color-font-primary);
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0;
	line-height: normal;
	display: flex;
	flex-direction: column;
}

@media screen and (min-width: 768px) {
	.top-aruaru-ha-flow-step {
		font-size: 28px;
		align-items: center;
	}
}

.top-aruaru-ha-flow-item .top-aruaru-ha-flow-step::after {
	content: '0' counter(flow-number);
	font-size: 36px;
	letter-spacing: 0.1em;
}

@media screen and (min-width: 768px) {
	.top-aruaru-ha-flow-item .top-aruaru-ha-flow-step::after {
		font-size: 56px;
	}
}

.top-aruaru-ha-flow-text-wrap {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.top-aruaru-ha-flow-head {
	font-size: 20px;
	font-weight: 500;
	line-height: normal;
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-flow-head {
		font-size: 24px;
	}
}

.top-aruaru-ha-flow-wrap {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.top-aruaru-ha-cta {
	width: 100%;
	max-width: 960px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 30px;
	margin-inline: auto;
}

@media screen and (min-width: 768px) {
	.top-aruaru-ha-cta {
		flex-direction: row;
		justify-content: space-between;
	}
}

.top-aruaru-ha-cta-item {
	background-color: var(--color-bg-ocher);
	border-radius: 15px;
	width: 100%;
	max-width: 480px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 24px 20px;
}

.top-aruaru-ha-cta-item .top-common-text-style {
	font-size: 18px;
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-cta-item .top-common-text-style {
		font-size: 22px;
	}
}

.top-aruaru-ha-cta-text {
	text-align: center;
	line-height: 1.6;
}
@media screen and (min-width: 768px) {
	.top-aruaru-ha-cta-text {
		font-size: 14px;
		line-height: 1.6;
}
}

.top-aruaru-ha-button {
	width: 100%;
	max-width: 320px;
	display: grid;
	place-items: center;
	border: 1px solid var(--color-bg-base);
	border-radius: 8px;
	padding: 12px;
	margin-inline: auto;
	transition: all 0.3s;
}
@media screen and (min-width: 500px) {
	.top-aruaru-ha-button {
		margin: 0;
	}
}

.top-aruaru-ha-button:hover {
	background-color: var(--color-bg-base);
	color: var(--color-font-white);
}

.top-aruaru-ha-link {
	width: 100%;
	max-width: 260px;
	display: grid;
	place-items: center;
	color: var(--color-font-white);
	background-color: var(--color-bg-base);
	border: 1px solid var(--color-bg-base);
	border-radius: 8px;
	padding: 12px;
	margin: 10px 0;
	transition: all 0.3s;
}

.top-aruaru-ha-link:hover {
	color: var(--color-font-base);
	background-color: var(--color-bg-white);
}
