/* -----------------------------------------------
= main
----------------------------------------------- */
.main {
	background: url(../../img/message/index-bg-sp.jpg) repeat-y 50% 0 / 100% auto;
}
@media print, screen and (min-width: 768px) {/* PC */
.main {
	background: url(../../img/message/index-bg-pc.jpg) repeat-y 50% 0 / 100% auto;
}
}/* @media */
/* -----------------------------------------------
= kv
----------------------------------------------- */
.kv {
	padding: 18px 13px 73px;
}
.kv h1 {
	display: table;
	position: relative;
	margin: 0 auto -.5em;
	padding-left: .6em;
	text-indent: -.6em;
	color: var(--red);
	font-size: calc(5rem / 1.6);
	font-weight: 700;
	line-height: calc(60 / 50);
	text-shadow:
		1px 1px 0 #ffec6c, -1px -1px 0 #ffec6c, 
		-1px 1px 0 #ffec6c, 1px -1px 0 #ffec6c,
		1px 0 0 #ffec6c, -1px  0 0 #ffec6c,
		0 1px 0 #ffec6c, 0 -1px 0 #ffec6c;
}
.kv img {
	border-radius: 24px;
}
.kv p {
	margin-top: 10px;
}
.kv p span span {
	display: inline-block;
	margin-top: 6px;
	padding: 1px 5px;
	color: #fff;
	background: var(--red);
	border-radius: 4px;
	font-size: calc(1.4rem / 1.6);
	font-weight: 700;
}
@media print, screen and (min-width: 768px) {/* PC */
.kv {
	position: relative;
	z-index: 1;
	max-width: 1500px;
	min-height: 950px;
	margin-inline: auto;
	padding: 70px 30px 176px;
	box-sizing: border-box;
}
.kv h1 {
	display: block;
	margin: 190px 0 0;
	font-size: calc(10rem / 1.6);
}
.kv img {
	position: absolute;
	top: 70px;
	right: 80px;
	z-index: -1;
	width: min(1160px, calc(1160 / 1500 * 100vw));
	height: 704px;
	object-fit: cover;
}
.kv p {
	margin: 50px 0 0 70px;
}
.kv p > span {
	display: inline-block;
	margin-top: 10px;
	padding: 3px 15px;
	color: #fff;
	background: var(--red);
	border-radius: 8px;
}
.kv p span span {
	display: inline;
	margin-top: 0;
	padding: 0;
	background: transparent;
	font-size: calc(2.2rem / 1.6);
}
}/* @media */
/* -----------------------------------------------
= faq
----------------------------------------------- */
.faq {
	padding: 0 23px 40px;
}
.faq + .faq {
	padding-top: 60px;
}
.faq .title {
	position: relative;
	margin-bottom: 50px;
	padding: 30px 5px 55px 35px;
	color: var(--red);
	background: linear-gradient(90deg,#ffff57,#ff5082);
	border-radius: 60px;
}
.faq .title::before {
	content: "";
	position: absolute;
	inset: 8px;
	background: #fff5d3;
	border-radius: 54px;
}
.faq .title::after {
	content: "";
	position: absolute;
	right: 17px;
	bottom: -2px;
	width: 87px;
	height: 10px;
	background: linear-gradient(90deg,#ffff57,#ff5082);
	border-radius: 5px;
	transform: rotate(45deg);
}
.faq .title img {
	position: absolute;
	z-index: 1;
	top: -22px;
	right: 22px;
	width: 86px;
}
.faq .title .num {
	position: relative;
	z-index: 1;
	margin-bottom: 5px;
	font-family: "Montserrat", sans-serif;
	font-size: calc(3rem / 1.6);
	letter-spacing: .04em;
}
.faq .title h2 {
	position: relative;
	z-index: 1;
	font-size: calc(1.6rem / 1.6);
	font-weight: 700;
}
.faq .answer {
	margin-bottom: 20px;
}
.faq .answer > img {
	display: block;
	position: relative;
	z-index: 1;
	width: 86px;
	margin: -35px auto -30px;
}
.faq .item:has(+ img) {
	padding-bottom: 40px;
}
.faq .item {
	padding: 10px 15px 15px 20px;
	background: #fff;
	border-radius: 20px;
	box-shadow: 0 0 3px rgba(0,0,0,.25);
}
.faq .item + .item {
	margin-top: 20px;
}
.faq .item .num {
	margin-bottom: 10px;
	font-family: "Montserrat", sans-serif;
	font-size: calc(1.2rem / 1.6);
	letter-spacing: .04em;
}
.faq .item .num span {
	margin-left: 5px;
	color: var(--red);
	font-weight: 700;
}
.faq .item h3 {
	margin-bottom: 10px;
	color: var(--red);
	font-size: calc(1.4rem / 1.6);
	font-weight: 700;
}
.faq .item img {
	display: block;
	width: 35px;
	margin: 10px;
}
.faq .item .text {
	font-size: calc(1.3rem / 1.6);
	line-height: calc(20 / 13);
}
.faq .item .text span {
	display: grid;
	place-content: center;
	float: left;
	width: 1.7em;
	height: 1.7em;
	margin: 4px 8px 0 0;
	color: #fff;
	background: #f14954;
	border-radius: 4px;
	font-size: calc(1.8rem / 1.6);
}
.faq .img-set img {
	display: block;
	max-width: 300px;
	margin-inline: auto;
	border-radius: 20px;
}
.faq .img-set img + img {
	margin-top: 14px;
}
@media print, screen and (min-width: 768px) {/* PC */
.faq {
	max-width: 1340px;
	margin-inline: auto;
	padding: 0 30px 200px;
}
.faq + .faq {
	padding-top: 0;
}
.faq .title {
	margin-bottom: 84px;
	padding: 75px 40px 105px 85px;
	border-radius: 120px;
}
.faq .title::before {
	inset: 16px;
	border-radius: 108px;
}
.faq .title::after {
	right: 36px;
	bottom: -2px;
	width: 174px;
	height: 20px;
	border-radius: 10px;
}
.faq .title img {
	top: -50px;
	right: 44px;
	width: 172px;
}
.faq .title .num {
	margin-bottom: 10px;
	font-size: calc(6rem / 1.6);
}
.faq .title h2 {
	font-size: calc(3.2rem / 1.6);
}
.faq .answer > img {
	width: 172px;
	margin: -60px auto -52px;
}
.faq .item:has(+ img) {
	padding-bottom: 80px;
}
.faq .answer {
	margin-bottom: 60px;
}
.faq .item {
	padding: 20px 40px 60px;
	border-radius: 40px;
	box-shadow: 0 0 6px rgba(0,0,0,.25);
}
.faq .item + .item {
	margin-top: 54px;
}
.faq .item .num {
	margin-bottom: 20px;
	font-size: calc(2rem / 1.6);
}
.faq .item h3 {
	margin-bottom: 15px;
	font-size: calc(2rem / 1.6);
}
.faq .item img {
	width: 46px;
	margin: 10px 30px;
}
.faq .item .text {
	font-size: calc(1.6rem / 1.6);
	line-height: calc(28 / 16);
}
.faq .item .text span {
	width: 1.5em;
	height: 1.5em;
	margin: 6px 8px 0 0;
	border-radius: 8px;
	font-size: calc(2.8rem / 1.6);
}
.faq .img-set {
	max-width: 600px;
	margin-inline: auto;
}
.faq .img-set-inner {
	position: sticky;
	top: 80px;
}
.faq .img-set img {
	max-width: 600px;
	margin-inline: 0;
	border-radius: 40px;
}
.faq .img-set img + img {
	margin-top: 30px;
}
.faq.type01 .img-set {
	order: 1;
}
.faq.type01 .text-set {
	order: 2;
}
}/* @media */
@media print, screen and (min-width: 1023px) {/* PC */
.faq {
	display: flex;
	gap: 0 70px;
}
.faq .text-set {
	flex: 1;
}
.faq .img-set {
	width: calc(600 / 1340 * 100%);
}
.faq .answer {
	margin-bottom: 0;
}
}/* @media */
/* -----------------------------------------------
= other
----------------------------------------------- */
.other {
	padding-top: 37px;
}
@media print, screen and (min-width: 768px) {/* PC */
.other {
	padding-top: 84px;
}
}/* @media */
