@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@100;300;400;500;700;800;900&family=Noto+Sans+JP:wght@100..900&display=swap');

body {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	background: #FFF;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: .05em;
	color: #222;
}

img {
	width: 100%;
	display: block;
}

h2,
h3 {
	line-height: 1.2;
}

.inner {
	max-width: 1200px;
	width: calc(100% - 40px);
	margin: 0 auto;
}

.sp {
	display: none !important;
}

.abs {
	position: absolute;
}

.flex {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}

.flex.reverse {
	flex-direction: row-reverse;
}

.c-top {
	position: relative;
}

.fix {
	position: absolute;
	left: 0;
	width: 100%;
	z-index: -1;
}

.top-fix {
	top: 0;
}

.bottom-fix {
	bottom: 0;
}

.wrapper {
	width: 100%;
	margin: 0 auto;
	overflow: hidden;
	min-width: 1200px;
}

.abs-img {
	position: absolute;
}

header {
	position: fixed;
	width: 100%;
	left: 0;
	top: 0;
	border-bottom: 2px solid #51C0DD;
	background: #FFF;
	z-index: 10;
}

.header-inner {
	padding: 15px 0;
	width: calc(100% - 100px);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: #FFF;
}

.header-logo {
	width: 200px;
	margin-right: 20px;
}

.header-right {
	max-width: 920px;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.header-right ul {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: calc(100% - 395px);
}

.header-right ul li a {
	font-size: 16px;
	font-weight: 300;
	color: #222;
}

.header-right .cmn-btn {
	width: 295px;
}

.cmn-btn a {
	position: relative;
	text-align: center;
	box-shadow: 0 3px 19px rgba(0, 0, 0, .25);
	border-radius: 50px;
	padding: 12.5px 0;
	font-size: 22px;
	font-weight: 700;
	color: #FFF;
	background: linear-gradient(90deg, rgba(255, 77, 48, 1) 0%, rgba(255, 191, 48, 1) 50%, rgba(255, 112, 30, 1) 100%);
	background-size: 200% 100%;
	background-position: 100% 0;
	display: block;
	transition: background-position 0.5s ease;
	/* ホバー時の滑らかアニメーション */
}

.cmn-btn a:hover {
	background-position: 0 0;
	/* ホバーで背景を動かす */
}

.cmn-btn a img {
	width: 25px;
	right: 12.5px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	position: absolute;
}

.nav-menu {
	display: none;
}

.nav-menu.active {
	display: block;
}

.fv {
	margin-top: 90px;
	padding-top: 70px;
	position: relative;
}

.form-cont {
	box-shadow: 0 3px 50px rgba(0, 0, 0, .25);
	background: #FFF;
	border-radius: 25px;
	position: absolute;
	top: 50%;
	right: -1vw;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	max-width: 26vw;
	width: 100%;
}

.form-cont-inner {
	padding: 1.75vw 2.5vw;
}

.form-cont-title {
	text-align: center;
	margin-bottom: 1.3vw;
}

.form-cont-title p {
	font-size: 1.3vw;
	font-weight: 700;
	color: #51C0DD;
}

.form-group {
	margin-bottom: 5px;
}

.form-group label {
	font-size: .85vw;
	padding-bottom: 2.5px;
	font-weight: 600;
	display: inline-block;
	position: relative;
}

.form-group label span {
	font-size: 10px;
	font-weight: 700;
	color: #51C0DD;
	position: absolute;
	top: -5px;
	right: -10px;
}

.form-group input {
	display: block;
	width: 100%;
	background: #EFEFEF;
	border: none;
	padding: .75vw;
	outline: none;
}

.radio-wrap {
	margin-top: 15px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: calc(100% - 4.25vw);
}

.flex.form-group label {
	width: 2vw;
}

.flex.form-group .radio-wrap label {
	width: 50%;
	display: flex;
	align-items: center;
}

.flex.form-group .radio-wrap label input {
	width: 25px;
	font-size: 15px;
	font-weight: 600;
	margin-right: 2.5px;
}

.form-group button {
	max-width: 295px;
	width: 100%;
	border-radius: 30px;
	padding: 10px 0;
	text-align: center;
	background: #FFA700;
	position: relative;
	font-size: 1vw;
	font-weight: 500;
	color: #FFF;
	border: none;
	margin: 20px auto 0;
	cursor: pointer;
}

.form-group button img {
	width: 25px;
	right: 12.5px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	position: absolute;
	transition: all .7s;
}

.form-group button:hover img {
	right: 5px;
}

.worry {
	background: #51C0DD;
	padding: 60px 0 0px;
	position: relative;
}

.worry::before {
	content: "";
	position: absolute;
	height: 100px;
	width: 100%;
	clip-path: polygon(0 0, 50% 100%, 100% 0);
	background-color: #51C0DD;
	left: 0;
	bottom: -99px;
}

.worry-title {
	text-align: center;
	margin-bottom: 30px;
}

.worry-title h2 {
	color: #FFF;
	font-size: 42px;
	font-weight: 700;
}

.worry-title h2 span {
	font-size: 52px;
}

.worry-cont {
	max-width: 1000px;
	margin: 0 auto;
}

.worry-cont ol {
	display: flex;
	justify-content: space-between;
}

.worry-cont ol li {
	width: 32.5%;
}

.worry-cont-title {
	margin-bottom: 10px;
	text-align: center;
}

.worry-cont-title img {
	height: 270px;
	width: auto;
}

.worry-cont-txt {
	background: #66CEEA;
	padding: 15px 25px;
}

.worry-cont-txt p {
	font-size: 18px;
	color: #FFF;
	line-height: 1.5;
	height: calc(1em * 1.5 * 4);
	/* 1em = フォントサイズ */
	font-weight: 500;
}

.solution {
	padding: 160px 0 60px;
	background-image: url(../img/solution_bg.webp);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	overflow: hidden;
}

.img-title {
	max-width: 830px;
	margin: 0 auto 60px;
}

.solution-list {
	margin-bottom: 50px;
}

.solution-list ol li {
	position: relative;
	margin-bottom: 75px;
}

.solution-list ol li::before {
	position: absolute;
	width: 1560px;
	height: 100%;
	top: 50px;
	left: -60px;
	border-radius: 20px;
	background: #FFF;
	content: "";
}

.solution-list ol li:nth-child(1)::before {
	top: 55px;
}

.solution-list ol li:nth-child(2)::before {
	right: -60px;
	left: initial;
}

.solution-list-flex {
	display: flex;
	justify-content: space-between;
	z-index: 1;
	position: relative;
}

.solution-list ol li:nth-child(2) .solution-list-flex {
	flex-direction: row-reverse;
}

.solution-list-left {
	width: 47.5%;
}

.solution-list-left .num {
	width: 70px;
	margin-bottom: 40px;
	margin-left: -20px;
}

.solution-list-txt {
	padding-left: 0px;
}

.solution-list-txt h3 {
	width: 67.5%;
	margin-bottom: 10px;
	display: block;
}

.solution-list-txt p {
	font-size: 17px;
	line-height: 2;
	font-weight: 400;
	padding-left: 40px;
}

.solution-list-txt p span {
	color: #51C0DD;
	font-weight: 700;
}

.solution-list-right {
	width: 45%;
}

.cta-btn.cmn-btn a {
	max-width: 450px;
	margin: 40px auto 0;
	padding: 25px 0;
}

.cta-btn.cmn-btn a p {
	background: #FFF;
	width: 65px;
	height: 65px;
	border-radius: 50%;
	top: 50%;
	left: 10px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	text-align: center;
	line-height: 64px;
	font-size: 24px;
	font-weight: 500;
	color: #FF8A00;
	position: absolute;
}

.cta-btn.cmn-btn a img {
	width: 35px;
	right: 20px;
}

.feature {
	padding: 100px 0;
	background-image: url(../img/feature_bg.webp);
	background-size: 100%;
	background-position: center;
}

.feature .img-title {
	max-width: 470px;
}

.feature-list {
	margin-bottom: 70px;
}

.feature-list ol {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
}

.feature-list ol li {
	width: 32.5%;
	height: auto;
	border-radius: 20px;
	background: #FFF;
	border: 3px solid #D1D1D1;
}

.feature-list-box {
	padding: 30px;
}

.feature-list-box-title {
	margin-block: -75px 30px;
}

.feature-list-box ul li {
	width: 100%;
	margin-bottom: 20px;
	display: flex;
	justify-content: space-between;
	border: none;
	align-items: flex-start;
}

.feature-list-box ul li img {
	width: 25px;
}

.feature-list-box ul li p {
	width: calc(100% - 32.5px);
	font-size: 20px;
	font-weight: 500;
}

.feature-list-box ul li p span {
	font-size: 15px;
}

.feature-list-box ul li:last-child {
	margin-bottom: 0;
}

.sm-title {
	text-align: center;
	margin-bottom: 30px;
}

.sm-title h3 {
	font-size: 36px;
	font-weight: 600;
}

.product {
	background: #EFFDFF;
	padding: 100px 0 60px;
}

.txt-title {
	margin-bottom: 60px;
}

.txt-title h2 {
	display: flex;
	align-items: center;
	justify-content: center;
}

.txt-title h2 img {
	width: 35px;
	margin-right: 30px;
}

.txt-title h2 p {
	font-size: 48px;
	font-weight: 600;
}

.tab-buttons {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 17.5px;
	margin-bottom: 25px;
	width: 100%;
}

.tab-btn {
	padding: 20px 0;
	cursor: pointer;
	background: #EBEBEB;
	border-radius: 40px;
	text-align: center;
	border: none;
	width: 100%;
	color: #5F5F5F;
	font-size: 18px;
	font-weight: 700;
	position: relative;
}

.tab-btn.active {
	background: #67C9E1;
	color: #fff;
}

.tab-btn.active::before {
	content: "";
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 12px 0 12px 16px;
	border-color: transparent transparent transparent #67C9E1;
	position: absolute;
	left: 50%;
	bottom: -15px;
	transform: translateX(-50%) rotate(90deg);
	-webkit-transform: translateX(-50%)rotate(90deg);
	-ms-transform: translateX(-50%)rotate(90deg);
}

.tab-content {
	display: none;
}

.tab-content.active {
	display: block;
}

.product-cont-box {
	background: #fff;
	padding: 60px;
	border-radius: 28px;
	display: flex;
	justify-content: space-between;
}

.product-cont-box-left {
	width: 50%;
}

.product-cont-box-right {
	width: 47.5%;
}

.product-cont-box-right h3 {
	font-size: 32px;
	font-weight: 600;
	color: #51C0DD;
	padding-bottom: 15px;
}

.product-cont-box-right p {
	font-size: 18px;
	line-height: 1.8;
	padding-bottom: 40px;
}

.product-cont-box-right ul li {
	padding-left: 30px;
	position: relative;
	font-size: 18px;
	font-weight: 600;
	margin-bottom: 10px;
}

.product-cont-box-right ul li::before {
	width: 18px;
	height: 18px;
	background: #51C0DD;
	border-radius: 50%;
	top: 52%;
	left: 0%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	content: "";
	position: absolute;
}

.ex {
	padding: 100px 0;
}

.ex-list li {
	margin-bottom: 30px;
	position: relative;
}

.ex-list li::before {
	position: absolute;
	width: 1000px;
	height: 110%;
	top: 35px;
	left: 50%;
	border-radius: 20px;
	background: #EFFDFF;
	content: "";
}

.ex-list li:nth-child(2)::before {
	left: initial;
	right: 50%;
}

.ex-list-box {
	background: #fff;
	box-shadow: 0 3px 15px rgba(0, 0, 0, .25);
	padding: 30px;
	border-radius: 28px;
	display: flex;
	justify-content: space-between;
	margin-right: 200px;
	position: relative;
	z-index: 1;
}

.ex-list-box-left {
	width: 27.5%;
}

.ex-list-box-right {
	width: 69%;
}

.ex-list li:nth-child(2) .ex-list-box {
	margin-right: 0;
	margin-left: 200px;
}

.ex-list-box-left img {
	margin-bottom: 10px;
}

.ex-list-box-left p {
	text-align: center;
	margin-bottom: 15px;
	font-size: 20px;
	font-weight: 700;
}

.ex-list-box-left-list {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 7.5px;
}

.ex-list-box-left-list:nth-child(4) {
	margin-bottom: 0;
}

.ex-list-box-left-list p.title {
	width: 52.5%;
	background: #51C0DD;
	border-radius: 15px;
	text-align: center;
	padding: 4.5px 0;
	font-size: 14px;
	color: #fff;
	font-weight: 600;
	margin-bottom: 0;
}

.ex-list-box-left-list p.cont {
	width: 45%;
	text-align: center;
	font-size: 16px;
	font-weight: 400;
	margin-bottom: 0;
}

.left.txt-title h2 {
	justify-content: left;
}

.ex-list-box-right h3 {
	padding-bottom: 15px;
	border-bottom: 1px solid #51C0DD;
	margin-bottom: 30px;
	font-size: 28px;
	font-weight: 700;
}

.ex-list-box-right h3 span {
	color: #51C0DD;
}

.ex-list-box-right-list {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	margin-bottom: 15px;
}

.ex-list-box-right-list:nth-child(3) {
	margin-bottom: 0;
}

.ex-list-box-right-list .table-box {
	width: 30%;
	border: 1px solid #51C0DD;
	position: relative;
}

.ex-list-box-right-list .table-box p {
	font-size: 15px;
	width: 100%;
	text-align: center;
	font-weight: 600;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	position: absolute
}

.ex-list-box-right-list p.cont {
	width: 67.5%;
	font-size: 16px;
	font-weight: 400;
}

.ex-list-box-right-list p.cont span {
	font-weight: 700;
	color: #51C0DD;
}

.flow {
	padding: 100px 0;
	background-image: url(../img/flow_bg.webp);
	background-color: #51C0DD;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.flow .txt-title {
	margin-bottom: 90px;
}

.flow .txt-title h2 {
	color: #fff;
}

.flow-box {
	background: #fff;
	position: relative;
}

.flow-box-inner {
	padding: 90px 30px;
}

.flow-box-huki {
	width: 365px;
	top: -30px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	position: absolute;
}

.flow-list {
	max-width: 820px;
	margin: 0 auto;
}

.flow-list ol {
	margin-bottom: 80px;
	display: flex;
	justify-content: space-between;
	position: relative;
}

.flow-list ol::before {
	content: "";
	width: 85%;
	height: 2px;
	background: #D5D5D5;
	top: 20px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	position: absolute;
}

.flow-list ol:last-child,
.flow-list ol:nth-child(2) {
	margin-bottom: 0;
}

.flow-list ol li {
	width: 18%;
}

.flow-list-title {
	text-align: center;
	margin-bottom: 40px;
	z-index: 1;
	position: relative;
}

.flow-list-title p {
	width: 45px;
	height: 45px;
	border-radius: 50%;
	background: #51C0DD;
	line-height: 44px;
	text-align: center;
	color: #fff;
	margin: 0 auto 10px;
	display: block;
	font-family: "M PLUS 1p", sans-serif;
	font-size: 24px;
	font-weight: 700;
}

.flow-list-title h3 {
	font-size: 24px;
	font-weight: 700;
	color: #51C0DD;
}

.flow-list-txt {
	text-align: center;
}

.flow-list-txt img {
	height: 80px;
	width: auto;
	display: block;
	margin: 0 auto 25px;
}

.flow-list-txt p {
	font-size: 16px;
	white-space: nowrap;
	line-height: 1.6;
}

.flow .cmn-btn {
	margin-top: 60px;
}

.qa {
	padding: 100px 0 20px;
}

.qa-list {
	margin-bottom: 100px;
}

.qa-item {
	border-radius: 12px;
	border: 2px solid #51C0DD;
	padding: 15px 25px;
	margin-bottom: 10px;
}

.qa-item:last-child {
	margin-bottom: 0;
}

.qa-question {
	cursor: pointer;
	font-weight: bold;
	align-items: center;
	display: flex;
	position: relative;
	padding-right: 30px;
}

.qa-question::before {
	content: "＋";
	width: 38px;
	height: 38px;
	text-align: center;
	line-height: 36px;
	font-weight: 100;
	font-size: 24px;
	text-align: center;
	color: #51C0DD;
	right: 0px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	position: absolute;
}

.qa-question.open::before {
	content: "ー";
}

.qa-question span {
	text-align: center;
	line-height: 35px;
	font-weight: bold;
	font-size: 28px;
	color: #51C0DD;
	padding-right: 7.5px;
}

.qa-question h3 {
	font-weight: bold;
	font-size: 18px;
}

.qa-answer {
	display: none;
	padding: 20px 30px 10px 40px;
	justify-content: space-between;
	transition: all .7s;
}

.qa-answer.open {
	display: flex;
}

.qa-answer p {
	width: calc(100% - 60px);
	font-weight: normal;
	font-size: 16px;
	letter-spacing: 0.05em;
	line-height: 1.7;
}

.table-cont table th {
	width: 30%;
	border-top: 1px solid #484848;
	background: #F5F5F5;
	text-align: center;
	color: #51C0DD;
	font-size: 18px;
	font-weight: 700;
}

.table-cont table td {
	width: 70%;
	border-top: 1px solid #484848;
	padding: 20px 20px 20px 80px;
	font-size: 16px;
}

.table-cont table tr:last-child th,
.table-cont table tr:last-child td {
	border-bottom: 1px solid #484848;
}

/* .table-cont table tr:last-child td {
	color: #51C0DD;
} */
.thanks-body {
	background: #EFFDFF;
}

.thanks {
	margin-top: 85px;
	padding: 120px 0;
}

.thanks-txt {
	text-align: center;
	margin-bottom: 20px;
}

.thanks-txt p {
	padding-bottom: 60px;
	font-size: 18px;
	line-height: 2;
}

.back-link {
	text-align: center;
}

.back-link a {
	text-align: center;
	font-size: 18px;
	text-decoration: underline;
	color: #51C0DD;
	display: block;
}

.top-btn {
	position: fixed;
	width: 60px;
	bottom: 12.5%;
	right: 40px;
	cursor: pointer;
	z-index: 1;
	transition: all 0.5s;
	opacity: 0;
}

.top-btn.show {
	opacity: 1;
}

.privacy-check {
	margin-top: 10px;
	cursor: pointer;
}

.privacy-check label input {
	margin-right: 5px;
	width: auto;
	display: inline-block;
	position: relative;
	bottom: -2px;
}

.privacy-check label {
	font-size: .85vw;
	line-height: 1;
}

.privacy-check label a {
	font-size: .85vw;
	color: #51C0DD;
	text-decoration: underline;
}

.grecaptcha-badge {
	z-index: 1;
}

@media screen and (max-width: 1400px) {
	.header-inner {
		padding: 10px 0;
		width: calc(100% - 20px);
	}

	.header-logo {
		width: 100px;
		margin-right: 15px;
	}

	.header-right {
		max-width: 720px;
	}

	.header-right ul {
		width: calc(100% - 320px);
	}
}

@media screen and (max-width: 1200px) {
	.form-cont-title p {
		font-size: 16px;
	}

	.form-cont-title {
		margin-bottom: 10px;
	}

	.form-group label,
	.privacy-check label a {
		font-size: 10px;
	}

	.form-cont {
		right: 0;
		max-width: 320px;
	}

	.form-group button {
		font-size: 14px;
		margin: 5px auto 0;
	}

	.header-right {
		max-width: 660px;
	}
}

@media screen and (max-width: 834px) {
	.wrapper {
		min-width: 100%;
	}

	.sp {
		display: block !important;
	}

	.pc {
		display: none !important;
	}

	.hamburger {
		width: 30px;
		cursor: pointer;
	}

	.hamburger span {
		display: block;
		height: 2px;
		background: #51C0DD;
		margin: 6px 0;
		transition: all 0.3s;
	}

	.hamburger.active span:nth-child(1) {
		transform: translateY(9px) rotate(45deg);
	}

	.hamburger.active span:nth-child(2) {
		opacity: 0;
	}

	.hamburger.active span:nth-child(3) {
		transform: translateY(-9px) rotate(-45deg);
	}

	.nav-menu {
		background: #fff;
		padding: 20px;
	}

	.nav-menu ul li a {
		color: #51C0DD;
		font-size: 18px;
		margin-bottom: 10px;
		display: block;
	}

	.header-right .cmn-btn {
		width: 170px;
	}

	.header-right .cmn-btn a {
		font-size: 17px;
		padding: 10px 0;
	}

	.header-right .cmn-btn a img {
		width: 22.5px;
	}

	.header-right {
		max-width: 215px;
	}

	.thanks {
		margin-top: 70px;
		padding: 50px 0;
	}

	.txt-title h2 p {
		font-size: 26px;
	}

	.txt-title h2 img {
		width: 20px;
		margin-right: 20px;
	}

	.txt-title h2 {
		align-items: flex-end;
	}

	.txt-title {
		margin-bottom: 40px;
	}

	.thanks-txt {
		margin-bottom: 0;
	}

	.thanks-txt p {
		padding-bottom: 20px;
		font-size: 15px;
		line-height: 2.2;
	}

	.back-link a {
		font-size: 16px;
	}

	.fv {
		margin-top: 0px;
		padding-top: 0px;
	}

	.form-cont {
		right: initial;
		max-width: 500px;
		position: relative;
		top: initial;
		transform: initial;
		-webkit-transform: initial;
		-ms-transform: initial;
		margin: 30px auto 50px;
		width: calc(100% - 20px);
	}

	.form-cont-inner {
		padding: 15px 17.5px 20px;
	}

	.form-cont-title {
		margin-bottom: 15px;
	}

	.form-cont-title p {
		font-size: 22px;
	}

	.form-group {
		margin-bottom: 10px;
	}

	.form-group label,
	.privacy-check label a {
		font-size: 16px;
		padding-bottom: 5px;
	}

	.form-group input {
		padding: 15px;
	}

	.flex.form-group label {
		width: 35px;
	}

	.radio-wrap {
		margin-top: 10px;
		width: calc(100% - 60px);
	}

	.form-group button {
		font-size: 20px;
		margin: 20px auto 0;
		max-width: 265px;
		width: 100%;
		display: block;
	}

	.worry {
		padding: 50px 0 20px;
	}

	.worry-cont-title img {
		height: auto;
		width: 100%;
	}

	.worry-title h2 {
		font-size: 24px;
	}

	.worry-title h2 span {
		font-size: 30px;
	}

	.worry-cont ol {
		display: block;
		max-width: 500px;
		margin: 0 auto;
	}

	.worry-cont ol li {
		width: 100%;
		margin-bottom: 20px;
	}

	.worry-cont ol li:last-child {
		margin-bottom: 0;
	}

	.worry-cont-txt {
		padding: 15px 20px;
	}

	.worry-cont-txt p {
		font-size: 15px;
		line-height: 1.8;
		height: auto;
	}

	.worry::before {
		height: 80px;
		bottom: -79px;
	}

	.solution {
		padding: 130px 0 50px;
		background-image: url(../img/solution_bg_sp.webp);
	}

	.img-title {
		max-width: 275px;
		margin: 0 auto 30px;
	}

	.solution-list {
		margin: 0 auto 50px;
		max-width: 500px;
	}

	.solution-list-flex {
		display: block;
	}

	.solution-list-left {
		width: 100%;
		margin-bottom: 15px;
	}

	.solution-list-left .num {
		width: 62.5px;
		margin-bottom: 20px;
	}

	.solution-list-txt {
		padding-left: 0px;
	}

	.solution-list-txt h3 {
		width: 100%;
		margin-bottom: 10px;
		padding-inline: 25px 20px;
	}

	.solution-list ol li:nth-child(1) .solution-list-txt h3 {
		padding-inline: 45px;
	}

	.solution-list-txt p {
		font-size: 15px;
		line-height: 1.9;
	}

	.solution-list ol li {
		margin-bottom: 30px;
	}

	.solution-list-right {
		width: 100%;
	}

	.solution-list ol li:nth-child(2) .solution-list-left .num {
		margin-left: auto;
	}

	.solution-list ol li::before {
		width: 150%;
		height: 55%;
		top: 55px;
		left: -10px;
	}

	.solution-list ol li:nth-child(2)::before {
		right: -10px;
	}

	.cta-btn.cmn-btn a {
		max-width: 350px;
		margin: 0px auto;
		padding: 20px 0;
	}

	.cta-btn.cmn-btn a p {
		width: 50px;
		height: 50px;
		line-height: 49px;
		font-size: 18px;
	}

	.feature {
		padding: 50px 0;
		background-image: url(../img/feature_bg_sp.webp);
	}

	.feature .img-title {
		max-width: 255px;
		margin-bottom: 75px;
	}

	.feature-list {
		margin: 0 auto;
		max-width: 500px;
	}

	.feature-list ol {
		display: block;
		justify-content: space-between;
		align-items: initial;
	}

	.feature-list-box {
		padding: 30px 20px;
	}

	.feature-list ol li {
		width: 100%;
		margin-bottom: 65px;
	}

	.feature-list-box ul li p {
		font-size: 18px;
	}

	.feature-list-box ul li p span {
		font-size: 14px;
	}

	.feature-list ol li .feature-list-box ul li {
		margin-bottom: 15px;
	}

	.feature-list ol li .feature-list-box ul li:last-child {
		margin-bottom: 0;
	}

	.sm-title {
		text-align: center;
	}

	.sm-title h3 {
		font-size: 24px;
	}

	.system-img img {
		max-width: 500px;
		margin: 0 auto;
	}

	.product {
		padding: 50px 0;
	}

	.product-cont {
		max-width: 500px;
		margin: 0 auto 30px;
	}

	.tab-btn {
		padding: 12.5px 15px;
		border-radius: 20px;
	}

	.tab-buttons {
		gap: 0 5px;
	}

	.product-cont-box {
		padding: 30px 25px;
		display: block;
	}

	.product-cont-box-left {
		width: 100%;
		margin-bottom: 20px;
	}

	.product-cont-box-right {
		width: 100%;
	}

	.product-cont-box-right h3 {
		font-size: 22px;
	}

	.product-cont-box-right p {
		font-size: 15px;
		padding-bottom: 30px;
	}

	.product-cont-box-right ul li {
		font-size: 15px;
		padding-left: 25px;
	}

	.ex {
		padding: 50px 0;
	}

	.left.txt-title h2 {
		padding-left: 10px;
	}

	.ex-list li {
		margin: 0 auto 40px;
		max-width: 500px;
	}

	.ex-list-box {
		padding: 20px;
		display: block;
		margin-right: 0;
	}

	.ex-list-box-left {
		width: 100%;
		margin-bottom: 20px;
	}

	.ex-list-box-right {
		width: 100%;
	}

	.ex-list-box-left-list p.title {
		padding: 6.5px 0;
		font-size: 12px;
		width: 47.5%;
	}

	.ex-list-box-left-list p.cont {
		width: 52.5%;
	}

	.ex-list-box-right h3 {
		padding-bottom: 10px;
		margin-bottom: 20px;
		font-size: 22px;
		text-align: center;
	}

	.ex-list li:nth-child(2) .ex-list-box {
		margin-right: 0;
		margin-left: 0;
	}

	.ex-list-box-right-list .table-box p {
		text-align: left;
		width: calc(100% - 14.5px);
	}

	.ex-list-box-right-list .table-box {
		width: 80px;
	}

	.ex-list-box-right-list p.cont {
		width: calc(100% - 90px);
		font-size: 14px;
		padding: 10px 0;
	}

	.ex-list li::before {
		width: 150%;
		height: 99%;
		top: 27.5px;
		left: 15px;
	}

	.ex-list li:nth-child(2)::before {
		right: 15px;
	}

	.flow {
		padding: 50px 0;
		background-size: 100%;
		background-repeat: repeat;
	}

	.flow-box-inner {
		padding: 40px 17.5px;
	}

	.flow-box {
		max-width: 500px;
		margin: 0 auto;
	}

	.flow-box-huki {
		max-width: 300px;
		width: 100%;
		top: -25px;
	}

	.flow .cmn-btn {
		margin-top: 30px;
	}

	.flow-list ol li {
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		margin-bottom: 30px;
	}

	.flow-list ol li:last-child {
		margin-bottom: 0;
	}

	.flow-list-title {
		margin-bottom: 0px;
	}

	.flow-list-title p {
		width: 35px;
		height: 35px;
		line-height: 34px;
		font-size: 20px;
		margin-bottom: 0;
	}

	.flow-list ol li img {
		height: 50px;
		width: auto;
		margin: auto 0;
	}

	.flow-list-txt {
		text-align: left;
		width: calc(100% - 45px);
		display: flex;
		justify-content: space-between;
	}

	.flow-list-txt p {
		font-size: 14px;
	}

	.flow-list-txt h3 {
		font-size: 22px;
		font-weight: 600;
		color: #51C0DD;
		padding-bottom: 7.5px;
	}

	.flow-list-txt-txt {
		width: calc(100% - 80px);
	}

	.flow-list ol::before {
		width: 2px;
		height: 87.5%;
		top: 20px;
		left: 17.5px;
	}

	.qa {
		padding: 50px 0 10px;
	}

	.qa-item {
		padding: 17.5px;
	}

	.qa-question h3 {
		font-size: 16px;
	}

	.qa-answer {
		padding: 20px 0px 5px 0px;
	}

	.qa-list {
		max-width: 500px;
		margin: 0 auto 50px;
	}

	.qa-answer p {
		width: 100%;
		font-size: 15px;
	}

	.table-cont {
		max-width: 500px;
		margin: 0 auto;
	}

	.table-cont table td {
		vertical-align: middle;
		padding: 15px;
		font-size: 14px;
	}

	.table-cont table th {
		font-size: 14px;
		font-weight: 700;
		padding: 15px;
		text-align: left;
		vertical-align: baseline;
	}

	.feature-list ol li:last-child {
		margin-bottom: 40px;
	}

	.top-btn {
		width: 40px;
		right: 10px;
	}
}

@media screen and (max-width: 500px) {
	.inner {
		width: calc(100% - 30px);
	}

	.fv {
		margin-top: 20px;
	}

	.worry-title h2 {
		font-size: 22px;
	}

	.worry-title h2 span {
		font-size: 28px;
	}

	.worry-cont-txt {
		padding: 15px;
	}

	.solution-list ol li::before {
		height: 60%;
		top: 50px;
		left: 0;
	}

	.solution-list ol li:nth-child(2)::before {
		right: 0;
	}

	.solution-list-left .num {
		margin-left: 15px;
	}

	.solution-list ol li:nth-child(2) .solution-list-left .num {
		margin-right: 15px;
	}

	.solution-list-txt p {
		padding-left: 15px;
	}

	.qa-question {
		align-items: initial;
	}

	.qa-question h3 {
		padding-top: 4.5px;
		line-height: 1.5;
	}

	.tab-btn {
		padding: 12.5px 5px;
		font-size: 13px;
	}

	.table-cont table th {
		width: 35%;
	}

	.table-cont table td {
		width: 65%;
		font-size: 13px;
	}
}
