/* ---------------------------------------------------
  表示切り替え（PC / SP）
--------------------------------------------------- */
.ipd .pc {
	display: block;
}

.ipd .sp {
	display: none;
}

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

	.ipd .sp {
		display: block;
	}
}

/* ---------------------------------------------------
  汎用リスト
--------------------------------------------------- */
.ipd .list li {
	margin-left: 1em;
	text-indent: -1em;
}

/* 注記リスト（改良版） */
.ipd .note li {
	font-size: min(1.3rem, 1.016vw);
}

.ipd .note li::before {
	content: "※";
}

.ipd .type01 li::before {
	content: "●";
}

.ipd .type02 li {
	text-indent: -1.25em;
}

.ipd .type02 li::before {
	content: "・";
}

@media screen and (max-width: 768px) {
	.ipd .note li {
		font-size: 3.2vw;
	}
}

/* ---------------------------------------------------
  ボタンリンク
--------------------------------------------------- */
.ipd .link-button {
	background: linear-gradient(90deg, rgba(22, 193, 68, 1) 0%, rgba(9, 111, 72, 1) 100%);
	color: rgb(var(--wht));
	font-weight: 600;
	text-decoration: none;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}

@media screen and (max-width: 768px) {}

/* ---------------------------------------------------
  フェードイン
--------------------------------------------------- */
.ipd .fadeBlock {
	opacity: 0;
	transition: all 1s;
}

.ipd .fadeBlock.fadeIn {
	opacity: 1;
}

.ipd .fadeBottom {
	transform: translateY(25px);
}

.ipd .fadeBottom.fadeIn {
	transform: translateY(0);
}


.ipd .object.fadeBlock {
	opacity: 0;
	transition: all 2s;
}

.ipd .object.fadeBlock.fadeIn {
	opacity: 1;
}

.ipd .object.fadeBottom {
	transform: translateY(200px);
}

.ipd .object.fadeBottom.fadeIn {
	transform: translateY(0);
}

/* ---------------------------------------------------
  object
--------------------------------------------------- */
.ipd .object {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	z-index: -1;
}

/* ---------------------------------------------------
  accordion
--------------------------------------------------- */
.accordion {
	margin-top: min(1.5rem, 1.172vw);
	font-size: min(1.9rem, 1.484vw);
}

.accordion__trigger {
	position: relative;
}

.accordion__trigger span {
	padding-right: min(2.5rem, 1.953vw);
	border-bottom: solid 1px rgb(var(--wht));
	position: relative;
	display: inline-block;
	cursor: pointer;
}

.accordion__trigger span::before,
.accordion__trigger span::after {
	background-color: rgb(var(--wht));
	width: min(1.5rem, 1.172vw);
	height: 2px;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	transition: all 0.5s ease 0s;
	content: "";
}

.accordion__trigger span::after {
	transform: translateY(-50%) rotate(90deg);
}

.accordion__trigger.is-open span::after {
	opacity: 0;
}

.accordion__panel {
	padding: min(1.5rem, 1.172vw) min(5rem, 3.906vw) 0 0;
	display: none;
}

.accordion__panel .list li .note {
	margin-left: 1em;
	font-size: min(1.3rem, 1.016vw);
	text-indent: -1em;
}

.accordion__panel .list li .note::before {
	content: "※";
}

@media screen and (max-width: 768px) {
	.accordion {
		margin: 4vw 4vw 0;
		font-size: 4vw;
	}

	.accordion__trigger span {
		padding-right: 6.4vw;
		padding-bottom: 1.6vw;
		font-size: 4.267vw;
		display: block;
	}

	.accordion__trigger span::before,
	.accordion__trigger span::after {
		width: 4vw;
	}

	.accordion__panel {
		padding: 4vw 0 0 0;
	}

	.accordion__panel .list li .note {
		font-size: 3.2vw;
	}
}