@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

body {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.6;
	letter-spacing: .05em;
	color: #FD4B46;
	background: #fff;
}

img {
	width: 100%;
	display: block;
}

h2,
h3 {
	line-height: 1.2;
}

.wrapper {
	min-width: 1200px;
	overflow: hidden;
}

.inner {
	max-width: 1200px;
	width: calc(100% - 35px);
	margin: 0 auto;
}

a {
	transition: all .6s;
}

a:hover {
	opacity: .8;
}

.fade-up {
	opacity: 0;
	transform: translateY(50px);
	transition: all 0.8s ease;
}

.fade-up.show {
	opacity: 1;
	transform: translateY(0);
}

.poppins {
	font-family: "Poppins", sans-serif;
	font-weight: 500;
}

.sp {
	display: none !important;
}

header {
	position: absolute;
	top: 10px;
	left: 0;
	width: 100%;
	padding: 20px 0;
	z-index: 10;
}

.header-inner {
	position: relative;
	max-width: 1200px;
	width: calc(100% - 35px);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.header-logo {
	width: 225px;
}

.cta-btn {
	max-width: 610px;
	margin: 0 auto;
	text-align: center;
}

.header-btn {
	width: 350px;
	margin: 0;
	position: fixed;
	right: 7.5%;
	top: 17.5px;
}

.cta-btn a {
	background: #3AC827;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 22.5px 10px;
	width: 100%;
	text-align: center;
	border-radius: 50px;
}

.cta-btn a p {
	font-size: 34px;
	color: #fff;
}

header .cta-btn a p {
	font-size: 22px;
}

.cta-btn a img {
	width: 45px;
	margin-left: 15px;
}

.cta-btn p.cta-top-txt {
	text-align: center;
	font-size: 24px;
	color: #fff;
	padding-bottom: 10px;
	display: inline-block;
	position: relative;
}

.cta-btn p.cta-top-txt::before {
	position: absolute;
	content: "";
	width: 35px;
	height: 2px;
	background: #fff;
	transform: rotate(60deg);
	bottom: 25px;
	left: -35px;
}

.cta-btn p.cta-top-txt::after {
	position: absolute;
	content: "";
	width: 30px;
	height: 2px;
	background: #fff;
	transform: rotate(-60deg);
	bottom: 25px;
	right: -27.5px;
}

.cta-btn p.cta-top-txt span {
	color: #FFF600;
}

.cta {
	padding: 85px 0;
	background-image: url(../img/cta_bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.cta-top {
	max-width: 650px;
	width: 100%;
	margin: 0 auto 55px;
}

.cta-top ul {
	display: flex;
	justify-content: space-between;
}

.cta-top ul li {
	width: 275px;
	background: #fff;
	font-size: 36px;
	text-align: center;
	line-height: 1.4;
	padding: 10px 5px 15px;
	position: relative;
}

.cta-top ul li::before {
	content: "";
	width: calc(100% - 10px);
	height: calc(100% - 10px);
	border: 1px solid #FD4B46;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
}

.cta-top ul li small {
	font-size: 26px;
	display: block;
}

.worry {
	padding-top: 120px;
}

.cmn-title {
	text-align: center;
	margin-bottom: 80px;
}

.cmn-title h2 {
	display: inline-block;
	font-size: 46px;
	color: #FD4B46;
	position: relative;
}

.cmn-title h2::before {
	content: "";
	width: 185px;
	height: 2px;
	background: #FD4B46;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	bottom: -20px;
}

.worry .cmn-title h2 {
	color: #C52824;
}

.worry .cmn-title h2::before {
	background: #C52824;
}

.reason {
	padding: 110px 0 120px;
}

.reason .cmn-title h2::before {
	display: none;
}

.reason .cmn-title h2 span {
	color: #F57C00;
	font-size: 52px;
	position: relative;
}

.reason .cmn-title h2 span::before {
	right: 0;
	bottom: -5px;
	width: 100%;
	background: #F57C00;
	position: absolute;
	content: "";
	height: 2px;
}

.reason-list ol {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0px 40px;
}

.reason-list ol li {
	padding: 45px 15px;
	border: 2px solid #FD4B46;
	border-radius: 10px;
	position: relative;
}

.reason-list-box-num p {
	position: absolute;
	display: block;
	background: #fff;
	text-align: center;
	width: 155px;
	top: -25px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	font-size: 30px;
}

.reason-list-box-num p::before {
	position: absolute;
	content: "";
	width: 35px;
	height: 2px;
	background: #FD4B46;
	transform: rotate(60deg);
	bottom: 25px;
	left: -12.5px;
}

.reason-list-box-num p::after {
	position: absolute;
	content: "";
	width: 30px;
	height: 2px;
	background: #FD4B46;
	transform: rotate(-60deg);
	bottom: 25px;
	right: -9.5px;
}

.reason-list-box-img {
	margin-bottom: 15px;
}

.reason-list-box-txt-title {
	margin-bottom: 10px;
	border-bottom: 2px dashed #FD4B46;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-bottom: 10px;
}

.reason-list-box-txt-title img {
	width: auto;
	height: 45px;
}

.reason-list-box-txt-title h3 {
	font-size: 26px;
	line-height: 1.1;
	color: #F57C00;
	width: calc(100% - 50px);
}

.reason-list-box-txt-title h3 small {
	font-size: 12px;
	color: #F57C00;
	display: block;
}

.reason-list-box-txt-txt p {
	font-size: 16px;
}

.voice {
	background-image: url(../img/voice_bg.webp);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center bottom;
	padding: 120px 0 25vw;
}

.voice-title {
	max-width: 625px;
	margin: 0 auto 55px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.voice-title img {
	width: 135px;
}

.voice-title h2 {
	width: calc(100% - 160px);
	font-size: 44px;
	color: #fff;
	line-height: 1.4;
}

.voice-swiper {
	max-width: 630px;
	margin: 0 auto;
	position: relative;
}

.swiper-button-prev,
.swiper-button-next {
	position: absolute;
	width: 50px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	z-index: 1;
	cursor: pointer;
}

.swiper-button-prev {
	left: -25px;
}

.swiper-button-next {
	right: -25px;
}

.swiper-button-prev::after,
.swiper-button-next::after {
	display: none;
}

.swiper-pagination {
	position: relative;
	z-index: 5;
	margin: 25px auto 80px;
}

.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 10px;
}

.swiper-pagination-bullet {
	width: 20px;
	height: 20px;
	background: #D4D4D4;
	opacity: 1;
}

.swiper-pagination-bullet-active {
	background: #9F9F9F;
}

.q-cont {
	padding: 75px 0;
}

.q-cont-title {
	margin-bottom: 30px;
	text-align: center;
}

.q-cont-title h2 {
	padding: 10px 20px;
	background: #FD4B46;
	text-align: center;
	font-size: 44px;
	color: #fff;
	display: block;
	max-width: 580px;
	margin: 0 auto 20px;
	border-radius: 10px;
}

.q-cont-title h3 {
	color: #FD4B46;
	font-size: 44px;
	position: relative;
	display: inline-block;
}

.q-cont-title h3::before {
	content: "";
	width: 75px;
	height: 4px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	left: -90px;
	position: absolute;
	background: #FD4B46;
}

.q-cont-title h3::after {
	content: "";
	width: 75px;
	height: 4px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	right: -90px;
	position: absolute;
	background: #FD4B46;
}

.q-cont-num {
	max-width: 410px;
	margin: 0 auto 40px;
}

.q-cont-num ul li {
	display: flex;
	align-items: center;
}

.q-cont-num ul li:nth-child(1) {
	margin-bottom: 10px;
}

.q-cont-num ul li img {
	width: 27.5px;
	margin-right: 10px;
}

.q-cont-num ul li p {
	font-size: 26px;
}

.q-cont-num ul li span {
	font-size: 50px;
	color: #F57C00;
	line-height: 1;
}

.q-cont-num ul li span small {
	font-size: 30px;
}

.q-cont-list {
	max-width: 1060px;
	width: 100%;
	margin: 0 auto;
}

.q-cont-list ol {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0px 25px;
	margin-bottom: 17.5px;
}

.q-cont-list p {
	font-size: 14px;
}

.quality {
	padding: 75px 0;
}

.quality .cmn-title h2 {
	position: relative;
	z-index: 2;
}

.quality .cmn-title h2::before {
	display: none;
}

.quality .cmn-title h2 img {
	width: 95px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	position: absolute;
}

.quality-list ol {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0px 20px;
}

.quality-list-img {
	margin-bottom: 30px;
}

.quality-list-txt h3 {
	display: block;
	margin-bottom: 25px;
}

.quality-list-txt p {
	font-size: 14px;
	font-weight: 700;
	line-height: 1.8;
}

.lineup {
	padding: 75px 0 120px;
}

.lineup .cmn-title {
	margin-bottom: 145px;
	position: relative;
}

.lineup .cmn-title h2 {
	position: relative;
}

.lineup .cmn-title img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	width: 85%;
}

.lineup-list ul {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 37.5px;
}

.lineup-list-img {
	margin-bottom: 12.5px;
}

.lineup-list-txt h3 {
	text-align: center;
	font-size: 18px;
	padding-bottom: 15px;
	border-bottom: 1px dashed #FD4B46;
}

.lineup-list .txt {
	display: none;
	transition: all .5s ease;
}

.lineup-list .txt small {
	display: block;
	padding-top: 10px;
}

.toggle-btn {
	position: relative;
	display: inline-block;
	cursor: pointer;
	font-size: 14px;
	color: #FD4B46;
	margin-top: 10px;
	background: none;
	border: none;
	padding-right: 30px;
	width: 100%;
}

.toggle-btn::after {
	content: "";
	position: absolute;
	right: 32.5%;
	top: 45%;
	width: 9px;
	height: 9px;
	transform: translateY(-50%) rotate(45deg);
	border-right: 2px solid #FD4B46;
	border-bottom: 2px solid #FD4B46;
	transition: transform .3s;
}

/* 開いたときのスタイル */
.accordion-open .txt {
	display: block;
	padding-top: 15px;
	font-size: 14px;
}

.accordion-open .toggle-btn::after {
	transform: translateY(-50%) rotate(-135deg);
	top: 65%;
}

.price {
	padding: 120px 0;
	background-image: url(../img/price_bg.webp);
	background-position: center bottom;
	background-size: cover;
	background-repeat: no-repeat;
}

.price-flex {
	display: flex;
	justify-content: space-between;
	max-width: 780px;
	margin: 0 auto;
}

.price-flex-cont {
	width: 45%;
}

.price-flex-cont-title {
	width: 85%;
	margin: 0 auto 25px;
	background: #FD4B46;
	border-radius: 10px;
}

.price-flex-cont-title h3 {
	text-align: center;
	font-size: 34px;
	color: #fff;
	padding: 5px 0;
}

.price-flex-cont-num .flex {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

.price-flex-cont-num-txt.left {
	display: flex;
	align-items: flex-end;
}

.price-flex-cont-num-txt.left p {
	color: #F57C00;
	font-size: 26px;
}

.price-flex-cont-num-txt.left span {
	color: #F57C00;
	font-size: 50px;
	line-height: 1;
}

.price-flex-cont-num-txt.center p {
	font-size: 44px;
	line-height: 1;
	position: relative;
	top: -6.5px;
	left: -2.5px;
}

.price-flex-cont-num-txt.right p {
	font-size: 26px;
	line-height: 1;
	text-align: center;
}

.price-flex-cont-num-txt.right span {
	font-size: 18px;
	line-height: 1;
	text-align: center;
}

.price-flex-cont-caution {
	margin-top: 5px;
}

.price-flex-cont-caution p {
	font-size: 18px;
}

.price-flex-cont-txt {
	padding-top: 17.5px;
	margin-top: 17.5px;
	border-top: 2px dotted #FD4B46;
}

.price-flex-cont-txt p {
	font-size: 16px;
	text-align: center;
	line-height: 1.6;
}

.bene-poi {
	padding: 120px 0;
}

.bp-conts {
	display: flex;
	justify-content: space-between;
}

.bp-cont {
	width: 48%;
	border: 2px solid #FD4B46;
	border-radius: 20px;
}

.bp-cont-inner {
	padding: 45px 50px;
}

.bp-cont-title {
	margin-bottom: 15px;
	padding-bottom: 12.5px;
	position: relative;
}

.bp-cont-title h2 {
	font-size: 32px;
	text-align: center;
}

.bp-cont-title::before {
	content: "";
	bottom: 0;
	width: 175px;
	height: 2px;
	background: #FD4B46;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	position: absolute;
}

.bp-cont-txt {
	margin-bottom: 20px;
	text-align: center;
}

.bp-cont-txt p {
	font-size: 22px;
	color: #F57C00;
}

.bp-cont-txt p span {
	font-size: 36px;
	line-height: 1;
}

.bp-cont-img {
	margin-bottom: 20px;
}

.bp-point-cont.point {
	margin-bottom: 25px;
}

.bp-point-cont-title h3 {
	font-size: 20px;
	padding: 5px 15px;
	border-radius: 10px;
	color: #fff;
	display: inline-block;
	background: #FD4B46;
	border: 2px solid #FD4B46;
	margin-bottom: 12.5px;
}

.caution .bp-point-cont-title h3 {
	background: initial;
	color: #FD4B46;
}

.bp-point-cont-list ul li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 10px;
}

.bp-point-cont-list ul li img {
	width: 20px;
}

.bp-point-cont-list ul li span {
	width: 15px;
	height: 15px;
	border-radius: 2.5px;
	background: #FD4B46;
}

.bp-point-cont-list ul li p {
	font-size: 16px;
	line-height: 1.7;
	width: calc(100% - 30px);
}

.media {
	background: #FD4B46;
	padding: 120px 0;
}

.media .cmn-title h2 {
	color: #fff;
}

.media .cmn-title h2::before {
	background: #fff;
}

.media .cmn-title h2 span {
	color: #FFF600;
}

.media-list ul {
	display: flex;
	justify-content: space-between;
}

.media-list ul li {
	width: 48%;
}

.media-list-img {
	margin-bottom: 20px;
}

.media-list-txt-title {
	padding-bottom: 10px;
	margin-bottom: 15px;
	border-bottom: 1px dotted #fff;
}

.media-list-txt-title p {
	font-size: 18px;
	padding-bottom: 5px;
	color: #fff;
}

.media-list-txt-title h3 {
	font-size: 26px;
	color: #FFF600;
}

.media-list-txt-txt p {
	font-size: 16px;
	color: #fff;
	line-height: 1.7;
}

.faq {
	padding: 120px 0 140px;
	background: #F4F4F4;
}

.faq-title {
	max-width: 500px;
	width: 100%;
	margin: 0 auto 45px;
}

.acc-wrap {
	margin-bottom: 30px;
	background: #fff;
	border-radius: 10px;
}

.acc-wrap:last-child {
	margin-bottom: 0;
}

.acc-header {
	width: 100%;
	cursor: pointer;
	position: relative;
	padding: 22.5px 40px;
	background: #ffff;
	border-radius: 10px;
	border: none;
	outline: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	transition: all .5s;
}

.active .acc-header {
	border-radius: 10px 10px 0 0;
}

.acc-header span {
	font-size: 36px;
	font-weight: 700;
	color: #FD4B46;
	line-height: 1;
	display: block;
}

.acc-header h3 {
	color: #FD4B46;
	font-size: 22px;
	padding-right: 60px;
	width: calc(100% - 50px);
}

.acc-header::before,
.acc-header::after {
	content: '';
	position: absolute;
	right: 35px;
	top: 50%;
	width: 25px;
	height: 3px;
	background: #FD4B46;
	transition: all 0.3s ease;
	transform: translateY(-50%);
}

.acc-header::after {
	transform: translateY(-50%) rotate(90deg);
}

.active .acc-header::after {
	transform: translateY(-50%) rotate(0deg);
	opacity: 0;
}

.active .acc-header::before {
	transform: translateY(-50%) rotate(0deg);
}

.acc-cont {
	border-top: 2px solid #FD4B46;
	display: none;
	align-items: center;
	padding: 20px 40px;
	align-items: center;
	justify-content: space-between;
	transition: all .5s;
}

.active .acc-cont {
	display: flex;
}

.acc-cont span {
	border-radius: 50%;
	color: #F57C00;
	font-size: 36px;
	display: block;
	font-weight: 700;
	line-height: 1;
}

.acc-cont p {
	font-size: 16px;
	padding-right: 50px;
	text-align: left;
	width: calc(100% - 50px);
	line-height: 1.9;
}

footer {
	background: #FD4B46;
	padding: 90px 0 30px;
}

.footer-logo {
	max-width: 425px;
	width: 100%;
	margin: 0 auto 55px;
}

footer ul {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 40px;
}

footer ul li a {
	font-size: 16px;
	padding: 0 20px;
	color: #fff;
}

footer .copy {
	font-size: 12px;
	color: #fff;
	text-align: center;
}

@media screen and (max-width: 1500px) {
	header {
		padding: 15px 0;
	}

	.header-logo {
		width: 200px;
	}

	.header-btn {
		width: 250px;
	}

	.cta-btn a {
		padding: 15px 10px;
	}

	header .cta-btn a p {
		font-size: 16px;
	}
}

@media screen and (max-width: 1200px) {
	.header-btn {
		right: 15px;
	}
}

@media screen and (max-width: 834px) {
	.sp {
		display: block !important;
	}

	.pc {
		display: none !important;
	}

	.wrapper {
		min-width: auto;
		overflow: hidden;
	}

	.inner {
		max-width: 100%;
		width: calc(100% - 35px);
	}

	.fixed-cont {
		position: fixed;
		bottom: -1px;
		max-width: 500px;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		opacity: 0;
		transition: all .6s;
		width: 100%;
		z-index: 5;
	}

	.fixed-cont.active {
		opacity: 1;
	}

	header {
		padding: 25px 0;
	}

	.header-logo {
		width: 100px;
	}

	.cta {
		padding: 35px 0;
		background-image: url(../img/cta_bg_sp.webp);
	}

	.cta-top {
		max-width: 282px;
		margin: 0 auto 40px;
	}

	.cta-top ul li {
		width: 132px;
		font-size: 20px;
		padding: 10px 5px 12.5px;
	}

	.cta-top ul li::before {
		width: calc(100% - 7.5px);
		height: calc(100% - 7.5px);
	}

	.cta-top ul li small {
		font-size: 16px;
	}

	.cta-btn {
		max-width: 260px;
	}

	.cta-btn p.cta-top-txt {
		font-size: 14px;
		padding-bottom: 5px;
	}

	.cta-btn a p {
		font-size: 16px;
	}

	.cta-btn a img {
		width: 20px;
		margin-left: 7.5px;
	}

	.cta-btn p.cta-top-txt::after {
		width: 20px;
		transform: rotate(-60deg);
		bottom: 15.5px;
		right: -14.5px;
	}

	.cta-btn p.cta-top-txt::before {
		width: 20px;
		bottom: 15.5px;
		left: -20px;
	}

	.worry {
		padding-top: 60px;
	}

	.cmn-title {
		margin-bottom: 50px;
	}

	.cmn-title h2 {
		display: inline-block;
		font-size: 26px;
	}

	.cmn-title h2::before {
		width: 80px;
		height: 1px;
		bottom: -15px;
	}

	.reason {
		padding: 50px 0;
	}

	.reason .cmn-title h2 {
		font-size: 20px;
	}

	.reason .cmn-title h2 span {
		font-size: 26px;
	}

	.reason-list ol {
		display: block;
		max-width: 500px;
		margin: 0 auto;
	}

	.reason-list ol li {
		padding: 25px 30px 35px;
		margin-bottom: 40px;
	}

	.reason-list ol li:last-child {
		margin-bottom: 0;
	}

	.reason-list-box-num p {
		top: -17.5px;
		font-size: 20px;
	}

	.reason-list-box-num p::before {
		width: 25px;
		bottom: 15px;
		left: 11.5px;
	}

	.reason-list-box-num p::after {
		width: 25px;
		bottom: 15px;
		right: 14.5px;
	}

	.reason-list-box-img {
		margin-bottom: 10px;
	}

	.reason-list-box-txt-title img {
		height: 35px;
	}

	.reason-list-box-txt-title {
		margin-bottom: 7.5px;
	}

	.reason-list-box-txt-title h3 {
		font-size: 18px;
		width: calc(100% - 45px);
		line-height: 1.3;
	}

	.reason-list-box-txt-title h3 small {
		font-size: 10px;
	}

	.reason-list-box-txt-txt p {
		font-size: 14px;
		line-height: 1.3;
	}

	.voice {
		background-image: url(../img/voice_bg_sp.webp);
		padding: 60px 0 40vw;
	}

	.voice-title {
		max-width: 325px;
		margin: 0 auto 15px;
	}

	.voice-title img {
		width: 70px;
	}

	.voice-title h2 {
		width: calc(100% - 85px);
		font-size: 23px;
	}

	.swiper-button-prev,
	.swiper-button-next {
		width: 30px;
	}

	.swiper-button-next {
		right: -15px;
	}

	.swiper-button-prev {
		left: -15px;
	}

	.swiper-pagination {
		margin: 15px auto 45px;
	}

	.swiper-pagination-bullet {
		width: 10px;
		height: 10px;
	}

	.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
		margin: 0 5px;
	}

	.voice-swiper {
		max-width: 500px;
		width: calc(100% - 35px);
	}

	.q-cont {
		padding: 35px 0;
	}

	.q-cont-title h2 {
		padding: 10px 20px;
		font-size: 24px;
		max-width: 340px;
		margin: 0 auto 15px;
	}

	.q-cont-title h3 {
		font-size: 24px;
	}

	.q-cont-title h3::before {
		width: 40px;
		height: 2px;
		left: -50px;
	}

	.q-cont-title h3::after {
		width: 40px;
		height: 2px;
		right: -45px;
	}

	.q-cont-num ul li img {
		width: 24.5px;
		margin-right: 15px;
	}

	.q-cont-num ul li p {
		font-size: 16px;
	}

	.q-cont-num ul li span {
		font-size: 36px;
	}

	.q-cont-num ul li span small {
		font-size: 20px;
	}

	.q-cont-num {
		max-width: 280px;
		margin: 0 auto 20px;
	}

	.q-cont-list {
		max-width: 500px;
	}

	.q-cont-list ol {
		display: block;
		margin-bottom: 15px;
	}

	.q-cont-list ol li {
		margin-bottom: 30px;
	}

	.q-cont-list ol li:last-child {
		margin-bottom: 0;
	}

	.q-cont-num ul li:nth-child(1) {
		margin-bottom: 5px;
	}

	.q-cont-list p {
		font-size: 12px;
	}

	.quality {
		padding: 35px 0;
	}

	.quality .cmn-title h2 img {
		width: 72.5px;
	}

	.quality-list ol {
		display: block;
		max-width: 500px;
		margin: 0 auto;
	}

	.quality-list ol li {
		margin-bottom: 30px;
	}

	.quality-list ol li:last-child {
		margin-bottom: 0;
	}

	.quality-list-img {
		margin-bottom: 15px;
	}

	.quality-list-txt h3 {
		margin-bottom: 10px;
	}

	.quality-list-txt p {
		font-size: 12px;
	}

	.lineup .cmn-title img {
		max-width: 360px;
	}

	.lineup-list ul {
		grid-template-columns: repeat(3, 1fr);
		gap: 12.5px;
		max-width: 500px;
		margin: 0 auto;
	}

	.lineup-list-txt h3 {
		font-size: 12px;
		padding-bottom: 7.5px;
	}

	.lineup-list-img {
		margin-bottom: 7.5px;
	}

	.toggle-btn {
		font-size: 10px;
		margin-top: 7.5px;
		padding-right: 0px;
		padding-left: 0;
	}

	.toggle-btn::after {
		right: 23.5%;
		width: 6px;
		height: 6px;
		border-right: 1px solid #FD4B46;
		border-bottom: 1px solid #FD4B46;
	}

	.accordion-open .txt {
		padding-top: 7.5px;
		font-size: 10px;
	}

	.lineup {
		padding: 35px 0 40px;
	}

	.lineup-list .txt small {
		padding-top: 5px;
	}

	.lineup .cmn-title {
		margin-bottom: 40px;
	}

	.price {
		padding: 60px 0;
		background-image: url(../img/price_bg_sp.webp);
	}

	.price .cmn-title {
		margin-bottom: 30px;
	}

	.price-flex {
		display: block;
		max-width: 265px;
	}

	.price-flex-cont {
		width: 100%;
		text-align: center;
	}

	.price-flex-cont-title h3 {
		font-size: 18px;
		padding: 5px 7.5px;
	}

	.price-flex-cont-title {
		width: auto;
		margin: 0 auto 10px;
		display: inline-block;
		text-align: center;
	}

	.price-flex-cont-num .flex {
		justify-content: center;
	}

	.price-flex-cont-num-txt.left p {
		font-size: 16px;
	}

	.price-flex-cont-num-txt.left span {
		font-size: 28px;
	}

	.price-flex-cont-num-txt.right span {
		font-size: 10px;
	}

	.price-flex-cont-num-txt.right p {
		font-size: 14px;
	}

	.price-flex-cont-num-txt.center p {
		font-size: 32px;
		top: -2.5px;
		left: 0;
		margin-inline: 7.5px 3.5px;
	}

	.price-flex-cont-caution p {
		font-size: 12px;
		text-align: left;
	}

	.price-flex-cont-txt {
		padding-block: 0px 10px;
		margin-block: 10px 15px;
		border-top: initial;
		border-bottom: 2px dotted #FD4B46;
	}

	.price-flex-cont-txt p {
		font-size: 10px;
	}

	.bene-poi {
		padding: 50px 0;
	}

	.bp-conts {
		display: block;
		max-width: 500px;
		margin: 0 auto;
	}

	.bp-cont {
		width: 100%;
	}

	.bp-cont:nth-child(1) {
		margin-bottom: 30px;
	}

	.bp-cont-inner {
		padding: 22.5px 30px;
	}

	.bp-cont-title h2 {
		font-size: 24px;
	}

	.bp-cont-title::before {
		width: 80px;
		height: 1px;
	}

	.bp-cont-txt p {
		font-size: 18px;
	}

	.bp-cont-txt p span {
		font-size: 26px;
	}

	.bp-cont-txt {
		margin-bottom: 15px;
	}

	.bp-cont-img {
		margin-bottom: 15px;
	}

	.bp-point-cont-title h3 {
		font-size: 16px;
		padding: 5px 10px;
		margin-bottom: 10px;
	}

	.bp-point-cont-list ul li {
		margin-bottom: 7.5px;
	}

	.bp-point-cont-list ul li img {
		width: 17.5px;
	}

	.bp-point-cont-list ul li p {
		font-size: 12px;
		line-height: 1.5;
		width: calc(100% - 25px);
		letter-spacing: 0;
	}

	.bp-point-cont-list ul li span {
		width: 12.5px;
		height: 12.5px;
	}

	.bp-point-cont.point {
		margin-bottom: 15px;
	}

	.media {
		padding: 60px 0;
	}

	.media-list ul {
		display: block;
		max-width: 500px;
		margin: 0 auto;
	}

	.media-list ul li {
		width: 100%;
	}

	.media-list ul li:nth-child(1) {
		margin-bottom: 20px;
	}

	.media-list-img {
		margin-bottom: 10px;
	}

	.media-list-txt-title p {
		font-size: 12px;
		padding-bottom: 2.5px;
	}

	.media-list-txt-title h3 {
		font-size: 18px;
	}

	.media-list-txt-txt p {
		font-size: 14px;
	}

	.faq {
		padding: 60px 0;
	}

	.faq-title {
		max-width: 250px;
		margin: 0 auto 20px;
	}

	.acc-wrap {
		max-width: 500px;
		margin: 0 auto 20px;
	}

	.acc-header {
		padding: 15px 12.5px;
	}

	.acc-header span,
	.acc-cont span {
		font-size: 20px;
	}

	.acc-header h3 {
		color: #FD4B46;
		font-size: 14px;
		padding-right: 30px;
		width: calc(100% - 30px);
	}

	.acc-header::before,
	.acc-header::after {
		right: 12.5px;
		width: 20px;
	}

	.acc-cont p {
		font-size: 12px;
		padding-right: 30px;
		width: calc(100% - 30px);
		line-height: 1.7;
	}

	.acc-cont {
		padding: 12.5px 12.5px 15px;
	}

	footer {
		padding: 25px 0 15px;
	}

	.footer-logo {
		max-width: 145px;
		margin: 0 auto 10px;
	}

	footer ul {
		margin-bottom: 15px;
	}

	footer ul li a {
		font-size: 12px;
		padding: 0px 15px;
	}

	footer .copy {
		font-size: 10px;
	}

	.price-flex-cont-caution {
		margin-top: 2.5px;
		padding-left: 30px;
	}
}

@media screen and (max-width: 500px) {
	.worry .cmn-title {
		margin-bottom: 40px;
	}

	.cmn-title h2 {
		font-size: 24px;
	}

	.reason-list ol {
		max-width: 277.5px;
	}

	.reason-list-box-txt-title h3 {
		width: calc(100% - 42.5px);
	}

	.swiper-button-next {
		right: -20px;
	}

	.swiper-button-prev {
		left: -20px;
	}

	.q-cont-title h3::before {
		width: 32.5px;
		left: -40px;
	}

	.q-cont-title h3::after {
		width: 32.5px;
		right: -40px;
	}

	.q-cont-title {
		margin-bottom: 22.5px;
	}

	.quality .inner {
		width: calc(100% - 70px);
	}

	.lineup .cmn-title img {
		width: 95%;
	}

	.toggle-btn {
		margin-top: 5px;
	}

	.toggle-btn::after {
		right: 15.5%;
		top: 50%;
		width: 5px;
		height: 5px;
	}

	.accordion-open .txt {
		padding-top: 5px;
		font-size: 8px;
	}

	.lineup-list-txt h3 {
		font-size: 11px;
		letter-spacing: 0;
	}

	.bp-cont-title {
		margin-bottom: 12.5px;
		padding-bottom: 10px;
	}

	.bp-cont-txt p {
		font-size: 16px;
	}

	.bp-point-cont-list ul li span {
		width: 7.5px;
		height: 7.5px;
	}

	.caution .bp-point-cont-list ul li p {
		width: calc(100% - 17.5px);
	}

	.bp-cont-inner {
		padding: 22.5px 27.5px;
	}

	.bp-cont-txt p {
		font-size: 15px;
		width: calc(100% + 30px);
		left: -15px;
		position: relative;
	}

	.media {
		padding: 60px 0 40px;
	}

	.media .inner {
		width: calc(100% - 70px);
	}

	.media .cmn-title h2 {
		white-space: nowrap;
	}

	.acc-cont p {
		line-height: 1.4;
	}
}
