@charset "UTF-8";

.prdct_info .res-pc,
.prdct_info .res-sp {
	display: none !important;
}

.prdct_info img {
	max-width: 100%;
	height: auto;
}

@media screen and (min-width: 768px) {
	.prdct_info .res-pc {
		display: block !important;
	}
}

@media screen and (max-width: 767px) {
	.prdct_info .res-sp {
		display: block !important;
	}
}

.prdct_info .mv_wrap {
	margin: 0;
}

.prdct_info h2 {
	font-size: 55px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 50px;
	font-feature-settings: "palt";
	line-height: 1.3;
}

@media screen and (max-width: 767px) {
	.prdct_info h2 {
		font-size: max(7.3333vw, 12px);
		margin-bottom: 6.6666vw;
	}
}

.prdct_info h2 sup {
	font-size: max(35%, 12px);
	top: -1.5em;
}

.prdct_info section#sec02 h2 {
	color: #0a3241;
	line-height: 1.3;
}

.prdct_info h3 {
	font-size: 30px;
	font-weight: bold;
	line-height: 1.2;
	margin-bottom: 30px;
	font-feature-settings: "palt";
}

@media screen and (max-width: 767px) {
	.prdct_info h3 {
		font-size: max(5.0666vw, 12px);
		margin-bottom: 2.6666vw;
	}

	.prdct_info .flx>h3 {
		margin-bottom: 0;
		margin-top: 6.6666vw;
	}
}

.prdct_info section#sec02 h3 {
	color: #3e3a39;
}

.prdct_info section#sec04 h3 {
	color: #0a3241;
}

.prdct_info h3.fullW {
	text-align: center;
	/* margin: 70px 0 40px; */
}

@media screen and (max-width: 767px) {
	.prdct_info h3.fullW {
		text-align: center;
		margin: 13.3333vw 0 6.6666vw;
	}

}

.prdct_info h3 sup {
	font-size: max(45%, 12px);
	top: -1em;
}

.prdct_info h4 {
	font-size: 17px;
	color: #808080;
	font-weight: bold;
	margin-bottom: 20px;
	line-height: 1.4;
}

@media screen and (max-width: 767px) {
	.prdct_info h4 {
		font-size: max(3.7333vw, 12px);
		margin-bottom: 2.6666vw;
		text-align: center;
	}
}

.prdct_info h4 strong {
	font-size: 22px;
	color: #fa8548;
}

@media screen and (max-width: 767px) {
	.prdct_info h4 strong {
		font-size: max(4.5333vw, 12px);
	}
}

.prdct_info h4 sup {
	font-size: max(45%, 12px);
	top: -1em;
}

.prdct_info img {
	display: block;
}

.prdct_info .TaC {
	text-align: center;
}

@media screen and (max-width: 767px) {
	.prdct_info .spTaC {
		text-align: center;
	}
}

.mb0 {
	margin-bottom: 0 !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

@media screen and (max-width: 767px) {
	.mb20 {
		margin-bottom: 2.6666vw !important;
	}
}

.mb30 {
	margin-bottom: 30px !important;
}

@media screen and (max-width: 767px) {
	.mb30 {
		margin-bottom: 4vw !important;
	}
}



.mb50 {
	margin-bottom: 50px !important;
}

@media screen and (max-width: 767px) {
	.mb50 {
		margin-bottom: 6.6666vw !important;
	}
}

.prdct_info .color {
	color: #fa8548;
}

.prdct_info .relative {
	position: relative;
}


.prdct_info {
	margin: auto;
	width: min(100%, 940px);
	font-size: 15px;
	line-height: 1.7;
}

@media screen and (max-width: 767px) {
	.prdct_info {
		font-size: max(3.4666vw, 12px);
	}
}

.prdct_info img {
	width: 100%;
}

.img_kdmr {
	border-radius: 10px;
}

@media screen and (max-width: 767px) {
	.img_kdmr {
		border-radius: 1.3333vw;
	}
}




.prdct_info .contents {
	width: 90%;
	margin: auto;
}

@media screen and (max-width: 767px) {
	.prdct_info .contents {
		width: 100%;
		padding: 0 6.6666vw;
	}
}


.prdct_info section {
	margin: 50px auto;
}

section#sec02 {
	padding: 50px min(10%, 47px);
	background: linear-gradient(to bottom, rgb(248, 243, 234) 10%, rgb(255, 255, 255) 30%, rgb(255, 255, 255) 70%, rgb(248, 243, 234) 90%);
	margin: 0 max(-5.558%, -47px) 0;
}

@media screen and (max-width: 767px) {
	section#sec02 {
		padding: 6.6666vw;
		margin: 0 -6.6666vw;
	}
}

section#sec04 {
	padding: 50px min(10%, 47px);
	background: linear-gradient(24deg, #e3e5e6 10%, rgb(255, 255, 255) 30%, rgb(255, 255, 255) 70%, #e3e5e6 90%);
	margin: 0 max(-5.558%, -47px);
}

@media screen and (max-width: 767px) {
	section#sec04 {
		padding: 6.6666vw;
		margin: 0 -6.6666vw;
	}
}

.flx {
	display: flex;
	gap: 5%;
}

@media screen and (max-width: 767px) {
	.flx {
		flex-flow: column;
		gap: 4vw;
	}
}

.flx_rr-col {
	flex-flow: row-reverse;
}

@media screen and (max-width: 767px) {
	.flx_rr-col {
		flex-flow: column;
	}
}

.flx_cr-col {
	flex-flow: column-reverse;
}

@media screen and (max-width: 767px) {
	.flx_cr-col {
		flex-flow: column;
	}
}

.flx>* {
	flex-basis: 50%;
}

.flx_bas80 {
	flex-basis: 80%;
}

.flx_bas62 {
	flex-basis: 62%;
}

.flx_bas45 {
	flex-basis: 45%;
}

.flx_bas40 {
	flex-basis: 40%;
}

.flx_grow1 {
	flex-grow: 1;
}

.gap20px {
	gap: 20px;
}

.flx_txt_wrap {
	display: flex;
	align-items: center;
}

@media screen and (max-width: 767px) {
	.flx_txt_wrap {
		align-items: unset;
	}
}

.flx_txt_wrap.al_b {
	align-items: flex-end;
}

.detail {
	margin-bottom: 50px;
	position: relative;
}

@media screen and (max-width: 767px) {
	.detail {
		margin-bottom: 6.6666vw;
	}
}


.small_head {
	background: #001e43;
	border-radius: 9999px;
	width: fit-content;
	margin: 0 auto 20px;
	font-weight: bold;
	color: #FFF;
	padding: 2px 40px;
	font-size: 17px;
}

.small_head+div.flx {
	width: 90%;
	margin: auto;
}

@media screen and (max-width: 767px) {
	.small_head {
		margin: 0 auto 4vw;
		padding: 0.2vw 10vw;
		font-size: max(3.4666vw, 12px);
	}

	.small_head+div.flx {
		margin-bottom: 13.3333vw;
		gap: 9.3333vw;
	}
}

ul.note,
ol.note {
	font-size: 12px;
	margin: 20px 0;
}

ol.note.list-notes:last-child {
	margin-bottom: 20px;
}

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

	ul.note,
	ol.note {
		font-size: max(2.6666vw, 12px);
		margin: 2.6666vw 0;
		line-height: 1.4;
	}
}

h2+ul.note,
h2+ol.note {
	text-align: center;
	margin-top: -40px;
}

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

	h2+ul.note,
	h2+ol.note {
		text-align: unset;
		margin-top: -5.3333vw;
	}
}

ul.note>li>span,
ol.note>li>span {
	display: inline-block;
	margin-right: 8px;
}

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

	ul.note>li>span,
	ol.note>li>span {
		margin-right: 1.3333vw;
	}
}

.point_wrap {
	background: linear-gradient(to right, #f7f2e9 70%, transparent 30%);
	border-radius: 10px;
	padding: 20px 0 20px 50px;
	margin-bottom: 50px;
	color: #0a3241;
}

@media screen and (max-width: 767px) {
	.point_wrap {
		background: #f7f2e9;
		border-radius: 1.3333vw;
		padding: 5.0666vw 6.4vw;
		margin-bottom: 6.6666vw;
	}
}

.point_over_pic {
	position: relative;

}

.point_over_pic>img {
	position: absolute;
	bottom: -20px;
}

@media screen and (max-width: 767px) {
	.point_over_pic>img {
		position: relative;
		bottom: unset;
	}
}

/* sec03 */

#sec03 .img_base {
	width: 90%;
	display: block;
}

@media screen and (max-width: 767px) {
	#sec03 .img_base {
		width: 85%;
	}
}

@media screen and (min-width: 768px) {
	#sec03 .img_base.pc_r {
		margin-right: 0;
		margin-left: auto;
	}

	#sec03 .img_base.pc_l {
		margin-right: auto;
		margin-left: 0;
	}
}

@media screen and (max-width: 767px) {
	#sec03 .img_base.sp_r {
		margin-right: 0;
		margin-left: auto;
	}

	#sec03 .sp_w90 {
		width: 90%;
		margin: auto;
	}
}


#sec03 .img_phone {
	position: absolute;
	display: block;
	width: 27%;
	height: auto;
	top: 0;
	bottom: 0;
	margin: auto;
	max-height: 85%;
	object-fit: contain;
}

@media screen and (max-width: 767px) {
	#sec03 .img_phone.sp_r {
		top: 0;
		bottom: 0;
		right: 0;
		margin: auto;
		/* object-position: right; */
	}
}

#sec03 .img_phone_b {
	position: absolute;
	display: block;
	width: 55%;
	height: auto;
	bottom: -10%;
	right: -10%;
	margin: auto;
}

@media screen and (max-width: 767px) {
	#sec03 .img_phone_b {
		left: -10%;
		right: unset;
	}

}

#sec03 .detail.colord {
	background: linear-gradient(150deg, rgb(248, 243, 234) 70%, rgb(255, 255, 255) 100%);
	border-top-left-radius: 10px;
	border-bottom-left-radius: 10px;
	margin-right: max(-5.558%, -47px);
	padding: 20px min(10%, 47px) 20px 35px;
}

@media screen and (max-width: 767px) {
	#sec03 .detail.colord {
		border-radius: unset;
		margin: 0 -6.6666vw 6.6666vw;
		padding: 6.6666vw;
	}
}


/* sec04 */
#sec04 .visual_wrap {
	width: 80%;
	margin: auto;
}

@media screen and (max-width: 767px) {
	#sec04 .visual_wrap {
		width: 100%;
		margin: 0 auto 2.6666vw;
	}
}

#sec04 .lead_wrap {
	width: 90%;
	margin: auto;
}

@media screen and (max-width: 767px) {
	#sec04 .lead_wrap {
		width: 100%;
		margin-bottom: 6.6666vw;
	}
}