@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

body {
	font-family: "shippori-mincho", sans-serif;
	font-weight: 500;
	background: #FFF;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: .05em;
	color: #333;
}

img {
	width: 100%;
	display: block;
}

h2,
h3 {
	line-height: 1.2;
}

.inner {
	max-width: 1000px;
	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;
}

.amb {
	font-family: "ambroise-std", serif;
}

.noto {
	font-family: "Noto Sans JP", sans-serif;
}

.wrapper {
	width: 100%;
	margin: 0 auto;
	overflow: hidden;
	min-width: 1200px;
}

.abs-img {
	position: absolute;
}

header {
	width: 100%;
	background: linear-gradient(90deg, #004799, #001f42);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
}

.header-flex {
	padding: 5px 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: calc(100% - 100px);
	margin: 0 auto;
}

.header-logo {
	width: 200px;
}

.header-right {
	width: 300px;
}

.fv {
	margin-top: 70px;
	position: relative;
}

.fv-btn {
	position: absolute;
	width: 30vw;
	bottom: 5vw;
	left: 30vw;
}

.amazon {
	position: relative;
}

.amazon .caution-txt {
	position: absolute;
	bottom: 2.25vw;
	right: 22vw;
}

.amazon .caution-txt p,
.amazon .caution-txt a {
	color: #fff;
	font-size: .75vw;
	line-height: 1.5;
}

.amazon .caution-txt a {
	text-decoration: underline;
}

/*popup*/
.popup {
	display: none;
	height: 100vh;
	width: 100%;
	background: rgb(0, 21, 49, 0.7);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
}

.popup .mask {
	background: rgb(0, 21, 49, 0.7);
	position: fixed;
	top: 0;
	left: 0;
}

.popup .content {
	background: #fff;
	padding: 30px;
	width: min(650px, 90%);
	height: 90%;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
	box-sizing: border-box;
}

.popup .popup_txt {
	max-height: 80%;
	overflow-y: scroll;
}

.popup .ttl {
	color: #05479B;
	font-size: 16px;
	line-height: 21px;
	font-weight: 700;
	margin-bottom: 10px;
}

.popup .sub_ttl {
	color: #05479B;
	font-size: 14px;
	line-height: 21px;
	font-weight: 700;
	margin-bottom: 10px;
	display: flex;
}

.popup ul {
	margin-bottom: 20px;
}

.popup li {
	color: #333;
	font-size: 14px;
	line-height: 21px;
	font-weight: 500;
}

.popup button {
	font-size: 15px;
	font-weight: 700;
	color: #fff;
	background: #05479B;
	width: 150px;
	padding: 5px 0;
	margin: 10px auto 0;
	border-radius: 5px;
	border: none;
	display: block;
}

.second-img01 {
	margin: 60px auto;
}

.second-img02 {
	background: #d9e3f0;
	padding: 160px 0 90px;
	position: relative;
}

.second-img02::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 80px;
	background: #FFF;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.second-img02 .flex img {
	width: 49%;
}

.worry {
	position: relative;
}

.worry .inner {
	position: relative;
}

.worry-title {
	position: absolute;
	top: 5vw;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	z-index: 1;
	text-align: center;
}

.worry-title h2 {
	font-size: 2vw;
	color: #fff;
	line-height: 1.6;
}

.box {
	background: linear-gradient(90deg, #c4b377, #c3a000);
	padding: 5px;
	line-height: 1;
	display: inline-block;
	margin: 0 2.5px;
}

.worry-list {
	width: 100%;
	max-width: 57.5vw;
	position: absolute;
	top: 14vw;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	z-index: 1;
}

.worry-list ul {
	margin-right: 2vw;
}

.worry-list ul li {
	display: flex;
	align-items: center;
	padding: 2vw .5vw;
	border-bottom: 1px solid #fff;
}

.worry-list ul li:nth-child(1) {
	border-top: 1px solid #fff;
}

.worry-list ul li .box {
	width: 1vw;
	height: 1vw;
	transform: rotate(45deg);
	background: #fff;
	margin-right: 1.25vw;
}

.worry-list ul li p {
	font-size: 1.4vw;
	color: #fff;
}

.worry-list ul li p span {
	position: relative;
}

.worry-list ul li p span::before {
	position: absolute;
	content: "";
	width: 100%;
	background: #c4b377;
	height: 1px;
	left: 0;
	bottom: -5px;
}

.recommend {
	background-image: url(../img/bg.webp);
	background-position: center;
	background-size: 100%;
	padding: 140px 0 90px;
	margin-top: -50px;
}

.recommend-box {
	background: rgba(255, 255, 255, .7);
	border: 1px solid #001f42;
	position: relative;
	padding: 52.5px;
}

.recommend-flex-right {
	position: absolute;
	width: 180px;
	right: -1px;
	bottom: -1px;
}

.recommend-flex-left {
	margin-right: 150px;
}

.recommend-flex-left h2 {
	padding-bottom: 35px;
	margin-bottom: 35px;
	border-bottom: 1px solid #cbcbcb;
	font-size: 42px;
	font-weight: 700;
}

.recommend-flex-left h2 .box {
	background: linear-gradient(90deg, #004799, #001f42);
	color: #fff;
	font-weight: 500;
}

.recommend-flex-left p {
	font-size: 18px;
	line-height: 1.7;
}

.recommend-flex-left p span {
	color: #00479a;
}

.reason {
	padding: 90px 0;
	background-image: url(../img/reason_bg.webp);
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.cmn-title {
	margin-bottom: 75px;
}

.cmn-title span {
	font-size: 64px;
	font-weight: 100;
	background: linear-gradient(90deg, #004799, #001f42);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.cmn-title h2 {
	font-size: 20px;
}

.reason-list {
	margin-bottom: 45px;
}

.reason-list ol {
	display: flex;
	justify-content: space-between;
}

.reason-list ol li {
	width: 30%;
}

.reason-list-img {
	margin-bottom: 15px;
}

.reason-list-top {
	padding-left: 22.5px;
}

.reason-list-title {
	position: relative;
	margin-bottom: 20px;
}

.reason-list-title h3 {
	font-weight: 700;
	font-size: 24px;
	line-height: 1.5;
	z-index: 1;
}

.reason-list-title p {
	position: absolute;
	bottom: 0;
	right: 0;
	font-size: 42px;
	font-weight: 100;
	opacity: .1;
	line-height: 1;
}

.reason-list-txt p {
	font-size: 16px;
	line-height: 1.7;
}

.reason-list-txt p span {
	color: #00479a;
	font-weight: 700;
}

.reason-box {
	max-width: 850px;
	margin: 0 auto;
	border: 1px solid #004799;
}

.reason-box-inner {
	background: #fff;
	padding: 20px 20px 30px;
	margin: 10px;
	box-shadow: 5px 5px 7px rgba(0, 71, 154, .15);
}

.reason-box-title {
	margin: 0 auto 30px;
	max-width: 375px;
	background: linear-gradient(90deg, #004799, #001f42);
	padding: 10px;
	text-align: center;
}

.reason-box-title h3 {
	color: #fff;
	font-size: 22px;
	font-weight: 500;
}

.reason-box-list {
	max-width: 700px;
	margin: 0 auto;
}

.reason-box-list ul {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 15px;
}

.reason-box-list ul li {
	font-size: 15px;
	letter-spacing: .05rem;
	padding-left: 27.5px;
	position: relative;
}

.reason-box-list ul li::before {
	width: 10px;
	height: 10px;
	background: linear-gradient(90deg, #004799, #001f42);
	content: "";
	position: absolute;
	top: 50%;
	left: 0%;
	transform: translateY(-50%) rotate(45deg);
	-webkit-transform: translateY(-50%)rotate(45deg);
	-ms-transform: translateY(-50%)rotate(45deg);
}

.merit {
	padding: 90px 0;
}

.merit-list ul {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
}

.merit-list ul li {
	position: relative;
}

.merit-list-box {
	border: 1px solid #004799;
	padding: 75px 10px 20px;
}

.merit-list-box-img {
	position: absolute;
	width: 100px;
	top: -35px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
}

.merit-list-box-txt {
	text-align: center;
}

.merit-list-box-txt h3 {
	font-size: 26px;
	line-height: 1.4;
}

.merit-list-box-txt h3 span {
	color: #004799;
	font-weight: 700;
}

.merit-list ul li:nth-child(1) .merit-list-box-txt h3 {
	padding: 18.5px 0;
}

.voice {
	background: #d9e3f0;
	padding: 90px 0;
}

.voice-list ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 15px;
}

.voice-list ul li {
	background: #fff;
	box-shadow: 5px, 5px, 5px, rgba(0, 71, 154, .15);
}

.voice-list-box {
	position: relative;
	padding: 25px;
}

.voice-list-box-bg {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	width: calc(100% - 20px);
	height: calc(100% - 15px);
}

.voice-list-box-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 12.5px;
	padding-bottom: 12.5px;
	border-bottom: 1px solid #80a3cd;
}

.voice-list-box-title img {
	width: 50px;
}

.voice-list-box-title p {
	width: calc(100% - 70px);
	font-size: 16px;
	font-family: "Noto Sans JP", sans-serif;
}

.voice-list-txt p {
	font-size: 14px;
	font-family: "Noto Sans JP", sans-serif;
}

.appeal {
	padding: 90px 0;
	background-image: url(../img/bg.webp);
	background-position: center;
	background-size: cover;
	background-repeat: repeat;
}

.appeal .cmn-title {
	margin-bottom: 100px;
}

.appeal-list ol li {
	width: 52.5%;
	margin-bottom: 50px;
	position: relative;
}

.appeal-list ol li:nth-child(2) {
	margin-left: 25%;
}

.appeal-list ol li:nth-child(3) {
	margin-left: 50%;
	margin-bottom: 0;
}

.appeal-list-flex-img {
	width: 200px;
	position: absolute;
	left: 0;
	top: -30px;
}

.appeal-list-flex-txt {
	width: calc(100% - 160px);
	margin-left: auto;
	padding: 15px 15px 15px 60px;
	background: #d9e3f0;
}

.appeal-list-flex-txt p {
	font-size: 32px;
	font-weight: 500;
	background: linear-gradient(90deg, #004799, #001f42);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	line-height: 1;
	margin-bottom: 5px;
}

.appeal-list-flex-txt h3 {
	font-size: 18px;
	font-weight: 700;
}

.appeal-list-flex-txt h3 .box {
	color: #fff;
	background: linear-gradient(90deg, #004799, #001f42);
	margin-bottom: 5px;
}

.contact-cont {
	padding: 90px 0;
}

.contact-cont .cmn-title {
	text-align: center;
}

.contact-form-box #contact-form {
	max-width: 625px;
	width: 100%;
	margin: 0 auto;
}

.contact-form-box #contact-form th {
	display: block;
	width: 100%;
	margin-bottom: 5px;
}

.contact-form-box #contact-form th label {
	font-size: 16px;
	font-weight: 500;
	color: #00479a;
}

.contact-form-box #contact-form th label span {
	background: #c4b377;
	font-size: 12px;
	color: #fff;
	line-height: 1;
	padding: 2.5px 5px 4.5px;
	margin-left: 7.5px;
	position: relative;
	top: -2px;
}

.contact-form-box #contact-form td {
	display: block;
	width: 100%;
	margin-bottom: 15px;
}

.contact-form-box #contact-form td input,
.contact-form-box #contact-form td select,
.contact-form-box #contact-form td textarea {
	background: #fff;
	border: 1px solid #cbcbcb;
	padding: 10px;
	width: 100%;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	text-align: left;
	outline: none;
	box-sizing: border-box;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	border-radius: 0;
	color: #333;
}

.select-wrap {
	position: relative;
	display: inline-block;
	width: 100%;
}

.select-wrap::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 15px;
	width: 8px;
	height: 8px;
	border-left: 2px solid #333;
	border-bottom: 2px solid #333;
	transform: translateY(-50%) rotate(-45deg);
	pointer-events: none;
}

.select-wrap select:invalid {
	color: #333;
}

input[type="date"],
.date::-webkit-date-and-time-value {
	text-align: left;
	-webkit-text-align-last: left;
	min-height: 15px;
}

.button-wraps {
	margin-top: 20px;
	text-align: center;
}

.button-wraps button {
	border: none;
	outline: none;
	background: initial;
	max-width: 340px;
	display: block;
	width: 100%;
	margin: 0 auto;
	transition: all .6s;
	cursor: pointer;
}

.button-wraps button:hover {
	opacity: .8;
}

.contact-form-box #contact-form td input::placeholder,
.contact-form-box #contact-form td select::placeholder,
.contact-form-box #contact-form td textarea::placeholder {
	color: #cbcbcb;
	font-family: "Noto Sans JP", sans-serif;
}

footer p {
	background: #00479a;
	line-height: 1;
	padding: 10px 0;
	font-size: 12px;
	color: #fff;
	font-family: "Noto Sans JP", sans-serif;
	text-align: center;
}

#confirm-area #contact-form table th {
	width: 40%;
	border-bottom: 1px solid #cbcbcb;
	padding: 20px 0 20px 30px;
	font-size: 16px;
	font-weight: 500;
	color: #004799;
	display: table-cell;
	vertical-align: baseline;
}

#confirm-area #contact-form table td {
	width: 60px;
	border-bottom: 1px solid #cbcbcb;
	padding: 20px 0 20px 10px;
	font-size: 15px;
	color: #000;
	display: table-cell;
	font-family: "Noto Sans JP", sans-serif;
}

#confirm-area #contact-form table tr:last-child th,
#confirm-area #contact-form table tr:last-child td {
	border-bottom: none;
	padding-bottom: 0;
}

#confirm-area table {
	margin-bottom: 75px;
}

.back-btn {
	max-width: 110px;
	width: 100%;
	margin: 25px auto 0;
}

.back-btn button,
.back-btn a {
	border-bottom: 1px solid #004799;
	padding-bottom: 5px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
}

.back-btn span {
	display: block;
	width: 10px;
	position: relative;
}

.back-btn span:before {
	content: '';
	width: 7px;
	height: 7px;
	border: 0;
	border-top: solid 1px #004799;
	border-left: solid 1px #004799;
	position: absolute;
	top: 50%;
	left: 0%;
	transform: translateY(-50%)rotate(-45deg);
	-webkit-transform: translateY(-50%)rotate(-45deg);
	-ms-transform: translateY(-50%)rotate(-45deg);
}

.back-btn p {
	font-size: 16px;
	font-weight: 500;
	color: #004799;
}

.contact-cont.confirm-cont,
.contact-cont.thanks-cont {
	padding-top: 160px;
	min-height: 97vh;
}

.thanks-txt {
	text-align: center;
	margin-bottom: 100px;
}

.thanks-txt p {
	font-size: 20px;
	line-height: 2;
	color: #000;
	white-space: nowrap;
}

a {
	transition: all .6s;
}

a:hover {
	opacity: .8;
}

.fade-up {
	opacity: 0;
	transform: translateY(50px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.fade-up.show {
	opacity: 1;
	transform: translateY(0);
}

@media screen and (max-width: 1200px) {
	.fv-btn {
		width: 100%;
		max-width: 350px;
		bottom: 55px;
		left: 365px;
	}

	.amazon .caution-txt {
		bottom: 25px;
		right: 250px;
	}

	.amazon .caution-txt p,
	.amazon .caution-txt a {
		font-size: 10px;
		transform: scale(.85);
	}

	.worry-title h2 {
		font-size: 24px;
	}

	.worry-title {
		top: 50px;
	}

	.worry-list {
		max-width: 700px;
		top: 160px;
	}

	.worry-list ul li {
		padding: 25px 10px;
	}

	.worry-list ul li .box {
		width: 12.5px;
		height: 12.5px;
		margin-right: 15px;
	}

	.worry-list ul li p {
		font-size: 20px;
	}
}

@media screen and (max-width: 834px) {
	.sp {
		display: block !important;
	}

	.pc {
		display: none !important;
	}

	.wrapper {
		min-width: 100%;
	}

	header {
		position: relative;
	}

	.header-flex {
		width: calc(100% - 10px);
	}

	.header-logo {
		width: 150px;
	}

	.header-right {
		width: 100%;
		max-width: 180px;
		margin-left: 10px;
	}

	.fv {
		margin-top: 0px;
	}

	.fv-btn {
		position: relative;
		background-image: url(../img/fv_btn_sp_bg.webp);
		background-size: cover;
		background-position: center;
		background-repeat: no-repeat;
		padding: 7.5px 20px;
		left: initial;
		bottom: initial;
		max-width: 100%;
	}

	.amazon .caution-txt p,
	.amazon .caution-txt a {
		font-size: 3.4vw;
		width: 100%;
		font-weight: 500;
		transform: initial;
	}

	.amazon .caution-txt {
		bottom: 5.5vw;
		right: initial;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		width: calc(100% - 60px);
	}

	.second-img01 .inner {
		width: calc(100% - 20px);
	}

	.second-img01 {
		margin: 40px auto;
	}

	.second-img02::before {
		height: 60px;
		top: -.5px;
	}

	.second-img02 {
		background: #d9e3f0;
		padding: 110px 0 70px;
	}

	.flex {
		display: block;
	}

	.second-img02 .flex img {
		width: 100%;
	}

	.second-img02 .inner {
		width: calc(100% - 15px);
		margin-right: 0;
	}

	.worry {
		position: relative;
		z-index: 1;
	}

	.worry-title {
		top: 10vw;
		width: calc(100% - 40px);
	}

	.worry-title h2 {
		font-size: 7vw;
	}

	.worry-list {
		max-width: 100%;
		top: 42.5vw;
		width: calc(100% - 40px);
	}

	.worry-list ul {
		margin-right: 0;
	}

	.recommend {
		background-image: url(../img/bg_sp.webp);
		padding: 70px 0;
		margin-top: -100px;
	}

	.recommend-box {
		padding: 50px 20px;
		max-width: 500px;
		margin: 0 auto;
	}

	.recommend-flex-right {
		width: 125px;
	}

	.recommend-flex-left {
		margin-right: 0;
	}

	.recommend-flex-left h2 {
		padding-bottom: 20px;
		margin-bottom: 20px;
		font-size: 36px;
		text-align: center;
		line-height: 1.4;
	}

	.recommend-flex-left h2 span.big {
		font-size: 62px;
	}

	.reason {
		padding: 70px 0;
	}

	.cmn-title {
		margin-bottom: 30px;
	}

	.cmn-title span {
		font-size: 40px;
	}

	.cmn-title h2 {
		line-height: 1.5;
	}

	.reason .swiper-button-next {
		position: absolute;
		right: 0;
		top: 40%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		color: #fff;
		z-index: 2;
		cursor: pointer;
		opacity: .8;
	}

	.reason .swiper-button-prev {
		position: absolute;
		left: 0;
		top: 40%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		color: #fff;
		z-index: 2;
		cursor: pointer;
		opacity: .8;
	}

	.reason .swiper-button-prev:after,
	.reason .swiper-button-next:after {
		font-size: 60px;
	}

	.reason .swiper-button-disabled {
		opacity: 0 !important;
	}

	.reason-list {
		position: relative;
	}

	.reason .swiper-pagination {
		position: relative;
		text-align: left;
		margin-top: 40px;
	}

	.reason .swiper-pagination-bullet {
		width: 55px;
		height: 5px;
		border-radius: 0;
		background: #fff;
		opacity: 1;
	}

	.reason .swiper-pagination-bullet-active {
		background: #00479a;
	}

	.reason-list-title p {
		font-size: 40px;
	}

	.reason-list-top {
		padding-left: 6vw;
	}

	.reason-box-inner {
		padding: 20px 12.5px 30px;
		margin: 7.5px;
	}

	.reason-box {
		max-width: 500px;
	}

	.reason-list {
		margin-bottom: 70px;
	}

	.reason-box-title {
		margin: 0 auto 20px;
		max-width: 375px;
		padding: 7.5px 10px;
	}

	.reason-box-title h3 {
		font-size: 24px;
	}

	.reason-box-list ul {
		display: block;
	}

	.reason-box-list {
		max-width: 100%;
		margin: 0 auto;
		width: calc(100% - 10px);
	}

	.reason-box-list ul li {
		font-size: 16px;
		padding-left: 25px;
		margin-bottom: 15px;
	}

	.reason-box-list ul li:last-child {
		margin-bottom: 0;
	}

	.merit {
		padding: 70px 0;
	}

	.merit .cmn-title {
		margin-bottom: 70px;
	}

	.merit-list ul {
		grid-template-columns: repeat(2, 1fr);
		gap: 45px 10px;
		max-width: 500px;
		margin: 0 auto;
	}

	.merit-list-box-img {
		position: absolute;
		width: 80px;
		top: -30px;
	}

	.merit-list-box {
		padding: 55px 10px 15px;
	}

	.merit-list-box-txt h3 {
		font-size: 18px;
	}

	.merit-list ul li:nth-child(1) .merit-list-box-txt h3 {
		padding: 12.5px 0;
	}

	.voice {
		padding: 70px 0;
	}

	.voice-list ul {
		display: flex;
		grid-template-columns: repeat(3, 1fr);
		gap: 0;
	}

	.fix-btn {
		position: fixed;
		width: 100%;
		max-width: 500px;
		z-index: 2;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		bottom: 0;
		opacity: 0;
		visibility: hidden;
		transition: all .7s;
	}

	.fix-btn.active {
		opacity: 1;
		visibility: visible;
	}

	.voice-list {
		max-width: 300px;
		margin: 0 auto;
		position: relative;
	}

	.voice-swiper .swiper-slide {
		box-shadow: 5px 5px 5px rgba(0, 71, 154, .15);
		position: relative;
	}

	.voice-list-box {
		padding: 25px 20px;
		position: initial;
	}

	/* 左上（先が左上向き） */
	.voice-list-box::before {
		content: '';
		position: absolute;
		top: 5px;
		left: 5px;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 15px 15px 0 0;
		border-color: rgba(0, 71, 154, .2) transparent transparent transparent;
	}

	.voice-list-box .corner-top-right {
		content: '';
		position: absolute;
		top: 5px;
		right: 5px;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 15px 0 0 15px;
		border-color: rgba(0, 71, 154, .2) transparent transparent transparent;
	}

	.voice-list-box .corner-bottom-left {
		content: '';
		position: absolute;
		bottom: 5px;
		left: 5px;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 0 15px 15px 0;
		border-color: transparent transparent rgba(0, 71, 154, .2) transparent;
	}

	.voice-list-box .corner-bottom-right {
		content: '';
		position: absolute;
		bottom: 5px;
		right: 5px;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 0 0 15px 15px;
		border-color: transparent transparent rgba(0, 71, 154, .2) transparent;
	}

	.voice-swiper-flex {
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: calc(100% - 30px);
		margin: 30px auto 0;
	}

	.voice .swiper-pagination {
		position: relative;
	}

	.voice .swiper-button-prev:after,
	.voice .swiper-button-next:after {
		display: none;
	}

	.voice .swiper-button-prev,
	.voice .swiper-button-next {
		width: 50px;
		cursor: pointer;
	}

	.voice .swiper-pagination-bullet {
		width: 20px;
		height: 3px;
		border-radius: 0;
		background: #fff;
		opacity: 1;
		margin: 0 2.5px;
	}

	.voice .swiper-pagination-bullet-active {
		background: linear-gradient(90deg, #004799, #001f42);
	}

	.appeal {
		padding: 70px 0;
		background-image: url(../img/bg_sp.webp);
	}

	.appeal .inner {
		width: 100%;
	}

	.appeal .cmn-title {
		margin-bottom: 60px;
	}

	.appeal-list {
		max-width: 500px;
		margin: 0 auto;
	}

	.appeal-list ol li {
		width: 100%;
		margin-bottom: 60px;
	}

	.appeal-list ol li:nth-child(2) {
		margin-left: 0%;
	}

	.appeal-list ol li:nth-child(3) {
		margin-left: 0%;
	}

	.appeal-list-flex-img {
		top: -15px;
	}

	.appeal-list ol li:nth-child(2) .appeal-list-flex-img {
		left: initial;
		right: 0;
	}

	.appeal-list-flex-txt {
		width: calc(100% - 180px);
		padding: 0px 20px 15px 40px;
	}

	.appeal-list ol li:nth-child(2) .appeal-list-flex-txt {
		margin-inline: 0 auto;
		padding: 0px 40px 15px 20px;
	}

	.appeal-list-flex-txt h3 {
		font-size: 16px;
	}

	.appeal-list-flex-txt h3 span.sp {
		display: inline-block !important;
	}

	.appeal-list-flex-txt p {
		font-size: 30px;
		position: relative;
		top: -10px;
	}

	.contact-cont {
		padding: 70px 0;
	}

	.button-wraps {
		margin-top: 10px;
	}

	#confirm-area table {
		margin-bottom: 50px;
	}

	.contact-cont.confirm-cont,
	.contact-cont.thanks-cont {
		padding-top: 100px;
	}

	#confirm-area #contact-form table th {
		width: 35%;
		padding: 15px 0 15px 0px;
		font-size: 14px;
	}

	#confirm-area #contact-form table td {
		width: 65%;
		padding: 15px 0 15px 5px;
		font-size: 14px;
	}

	.button-wraps button {
		padding: 0;
	}

	.back-btn {
		max-width: 85px;
		margin-top: 15px;
	}

	.button-wraps .back-btn button {
		padding: 0 0 5px;
	}

	.back-btn p {
		font-size: 14px;
	}

	.thanks-txt {
		margin-bottom: 60px;
	}

	.thanks-txt p {
		font-size: 16px;
		line-height: 1.8;
		white-space: initial;
	}

	.thanks-cont .back-btn {
		max-width: 100px;
	}
}

@media screen and (max-width: 500px) {

	.amazon .caution-txt p,
	.amazon .caution-txt a {
		font-size: 3vw;
	}

	.second-img02 .inner {
		width: calc(100% - 15px);
		margin-right: 5px;
	}

	.recommend {
		margin-top: -90px;
	}

	.recommend-flex-left h2 {
		font-size: 24px;
	}

	.recommend-flex-left h2 span.big {
		font-size: 54px;
	}

	.recommend-flex-right {
		width: 100px;
	}

	.recommend-flex-left p {
		font-size: 16px;
		padding-right: 40px;
	}

	.recommend-box {
		padding: 50px 20px 40px;
	}

	.reason .swiper-button-prev:after,
	.reason .swiper-button-next:after {
		font-size: 50px;
	}

	.reason .swiper-pagination {
		margin-top: 30px;
	}

	.reason-box-title h3 {
		font-size: 22px;
	}

	.reason-box-list ul li {
		padding-right: 25px;
	}

	.appeal .cmn-title {
		width: calc(100% - 40px);
		margin: 0 auto 70px;
	}

	.appeal-list-flex-img {
		width: 170px;
	}

	.appeal-list-flex-txt {
		width: calc(100% - 145px);
	}

	.appeal-list-flex-txt h3 {
		line-height: 1.5;
	}
}

@media screen and (max-width: 374px) {}
