@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,700&family=Noto+Sans+JP:wght@100..900&display=swap');
div#CONTENTS_BLOCK.full_width {
	/* コンテンツサイズフルサイズ */
	max-width: none;
}
html.touch-device body,
html.touch-device #page {
	min-width: auto;
}
/* CSSファイル名をリネーム後に、独自の内容を追加 */
/* common */
body.fixed {
	width: 100%;
	height: 100%;
	position: fixed;
}
.inter {
	font-family: "Inter", sans-serif;
}
#CONTENTS {
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	font-size: min(1.404vw, 16px);
	line-height: 1.5;
}
div#CONTENTS {
	color: #333;
}
#CONTENTS a {
	color: inherit;
}
#CONTENTS img {
	vertical-align: top;
}
div#CONTENTS_BLOCK {
	margin: 0;
}
div#CONTENTS_BLOCK p {
	font-size: inherit;
	letter-spacing: 0.08em;
	line-height: 2.25;
}
#CONTENTS .conts_wrap {
	margin: 0 auto;
	width: 1080px;
	max-width: 95%;
}
#CONTENTS .headline01 {
	margin-bottom: 58px;
	text-align: center;
}
#CONTENTS .headline01 img {
	width: auto;
	max-width: 100%;
	max-height: 92px;
	vertical-align: top;
}
#CONTENTS .headline02 {
	margin-bottom: 53px;
	text-align: center;
	color: #7872AB;
	font-size: min(2.807vw, 32px);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.04em;
}
#CONTENTS .headline03 {
	margin: 0 auto 20px;
	padding: 0 min(3.333vw, 38px);
	width: fit-content;
	position: relative;
	text-align: center;
	color: #7872AB;
	font-weight: 700;
	font-size: min(2.807vw, 32px);
	line-height: 1.5;
	letter-spacing: 0.04em;
}
#CONTENTS .headline03::before,
#CONTENTS .headline03::after {
	width: 4px;
	height: 98%;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(-40deg);
	background: currentColor;
	content: '';
}
#CONTENTS .headline03::before {
	left: 0;
}
#CONTENTS .headline03::after {
	right: 0;
	transform: translateY(-50%) rotate(40deg);
}
@media only screen and (min-width: 641px) {
	div#CONTENTS_BLOCK {
		margin: 0;
		padding: 0;
	}
}
@media all and (min-width: 768px) {
	.sp {
		display: none !important;
	}
}
@media screen and (max-width: 767px) {
	.pc {
		display: none !important;
	}
	#CONTENTS a:hover {
		opacity: 1 !important;
	}
	#CONTENTS {
		font-size: min(3.571vw, 14px);
	}
	div#CONTENTS_BLOCK p {
		line-height: 2;
	}
	#CONTENTS .conts_wrap {
		margin: 0 16px;
		width: auto;
		max-width: initial;
	}
	#CONTENTS .headline01 {
		margin-bottom: 38px;
	}
	#CONTENTS .headline01 img {
		max-height: initial;
	}
	#CONTENTS .headline02 {
		margin-bottom: 34px;
		font-size: min(5.102vw, 20px);
		line-height: 1.6;
	}
	#CONTENTS .headline03 {
		margin: 0 auto 17px;
		padding: 0 min(5.357vw, 21px);
		font-size: min(5.102vw, 20px);
		text-align: center;
		line-height: 1.6;
		letter-spacing: 0.04em;
	}
	#CONTENTS .headline03::before,
	#CONTENTS .headline03::after {
		margin-top: 1px;
		width: 2px;
		height: 72%;
	}
}
@media screen and (max-width: 390px) {
	#CONTENTS .headline03 {
		font-size: 5.115vw;
		letter-spacing: 0;
	}
}
/* CONTENTS */
#main_visual {
	padding: min(7.018vw, 80px) 20px min(20.614vw, 235px);
	text-align: center;
	background: url(../img/mv_bg.png) no-repeat center center / cover;
}
#main_visual h1 {
	margin-bottom: min(3.684vw, 42px);
}
#cy-body.visual_appeal #main_visual img {
	width: min(56.316vw, 642px);
}
#main_visual p {
	color: #333;
	font-size: min(1.754vw, 20px);
	font-weight: 500;
	letter-spacing: 0.08em;
	line-height: 2;
}
#CONTENTS .menu_btn {
	width: min(10.526vw, 120px);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	position: fixed;
	right: min(3.509vw, 40px);
	bottom: min(3.509vw, 40px);
	color: #fff;
	font-size: clamp(10px, 1.053vw, 12px);
	font-weight: 700;
	letter-spacing: 0.08em;
	box-sizing: border-box;
	white-space: nowrap;
	border-radius: 100%;
	border: 1px solid #707070;
	background: #333333;
	cursor: pointer;
	aspect-ratio: 1;
	z-index: 10;
}
@media (hover: hover) {
	#CONTENTS .menu_btn:hover {
		background-color: #7872AB;
	}
}
#CONTENTS .menu_btn .icon {
	padding: min(1.316vw, 15px) 0 min(1.14vw, 13px);
	width: min(2.632vw, 30px);
}
#CONTENTS .menu_box {
	width: 100%;
	height: 100%;
	position: fixed;
	left: 0;
	top: 0;
	background: #fff;
	overflow-y: auto;
	z-index: 10000;
	display: none;
}
#CONTENTS .menu_wrap {
	box-sizing: border-box;
	margin: 0 auto;
	padding: 68px 0;
	max-width: 655px;
}
#CONTENTS .menu_wrap .menu_img {
	width: 494px;
	max-width: 100%;
	margin: 0 auto 44px;
}
#CONTENTS .menu_wrap .nav_list {
	margin-bottom: 40px;
}
#CONTENTS .menu_wrap .nav_list li {
	margin-bottom: 17px;
}
#CONTENTS .menu_wrap .nav_list li:last-child {
	margin-bottom: 0;
}
#CONTENTS .menu_wrap .nav_list li a {
	display: block;
}
#CONTENTS .menu_wrap .nav_list li a:hover {
	opacity: 0.7;
}
#CONTENTS .menu_wrap .menu_close {
	margin: 0 auto;
	width: 66px;
	cursor: pointer;
}
#CONTENTS .menu_wrap .menu_close:hover {
	opacity: 0.7;
}
#CONTENTS .about {
	padding: 120px 0 20px;
	background: #F5F2E9;
}
#CONTENTS .about .conts_wrap {
	width: 1120px;
}
#CONTENTS .about .mobility {
	margin: 0 min(2.105vw, 24px) 47px min(1.842vw, 21px);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#CONTENTS .about .mobility .headline02 {
	margin-bottom: 13px;
	width: 100%;
	text-align: left;
}
#CONTENTS .about .mobility .text_box {
	margin-top: 40px;
	width: 61%;
}
#CONTENTS .about .mobility .text_box p {
	margin-bottom: 36px;
}
#CONTENTS .about .mobility .text_box p:last-child {
	margin-bottom: 0;
}
#CONTENTS .about .mobility .photo_box {
	width: 32.3%;
}
#CONTENTS .about .mobility .photo_box img {
	width: 315px;
}
#CONTENTS .about .image {
	margin-bottom: 91px;
	text-align: center;
}
#CONTENTS .about .image img {
	width: min(73.333vw, 836px);
}
#CONTENTS .about .features .center_txt {
	margin-bottom: 93px;
	font-size: min(1.754vw, 20px);
	font-weight: 700;
	line-height: 1.8;
	letter-spacing: 0.18em;
	text-align: center;
}
#CONTENTS .about .features .img_box {
	margin-bottom: 90px;
	display: flex;
	justify-content: space-between;
}
#CONTENTS .about .features .img_box .text_box {
	padding-left: min(1.754vw, 20px);
	width: 48%;
	box-sizing: border-box;
}
#CONTENTS .about .features .img_box .text_box .heading {
	margin-bottom: 32px;
	font-weight: 700;
	font-size: min(2.105vw, 24px);
	letter-spacing: 0.04em;
	line-height: 1.5;
}
#CONTENTS .about .features .img_box .photo_list {
	width: 46.4%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px 0;
}
#CONTENTS .about .features .img_box .photo_list li {
	width: 46.2%;
}
#CONTENTS .about .features .img_box .photo_list li img {
	width: 100%;
}
#CONTENTS .about .features .img_box .photo_list li .txt {
	margin-top: min(0.526vw, 6px);
	display: block;
	text-align: center;
	font-size: clamp(10px, 1.053vw, 12px);
	letter-spacing: 0.08em;
}
#CONTENTS .about .features .img_box.rev {
	margin-bottom: 100px;
	flex-direction: row-reverse;
}
#CONTENTS .about .features .img_box.rev .text_box {
	padding-left: 0;
	width: 50%;
}
#CONTENTS .about .features .table_img {
	margin-bottom: 8px;
}
#CONTENTS .about .features .note_list li {
	font-size: clamp(10px, 1.053vw, 12px);
	letter-spacing: 0.08em;
	line-height: 1.5;
}
#CONTENTS .scene {
	padding: 120px 0 100px;
}
#CONTENTS .scene .headline01 {
	margin-bottom: 88px;
}
#CONTENTS .scene .headline03 {
	margin-bottom: 48px;
}
#CONTENTS .scene .center_txt {
	margin-bottom: 116px;
	text-align: center;
	font-size: min(1.579vw, 18px);
	letter-spacing: 0.04em;
	line-height: 2;
}
#CONTENTS .scene .scene_list li {
	margin-bottom: 86px;
}
#CONTENTS .scene .scene_list li:last-child {
	margin-bottom: 0 !important;
}
#CONTENTS .scene .scene_list .text_box {
	padding: 0 min(2.632vw, 30px);
	position: relative;
	z-index: 1;
}
#CONTENTS .scene .scene_list .text_box .ttl {
	padding-left: min(0.526vw, 6px);
	display: flex;
	gap: min(1.754vw, 20px);
	align-items: center;
	font-size: min(2.105vw, 24px);
	font-weight: 400;
}
#CONTENTS .scene .scene_list .text_box .ttl .num {
	width: min(5.263vw, 60px);
	display: block;
	border-right: 1px solid #707070;
	box-sizing: border-box;
}
#CONTENTS .scene .scene_list .text_box .ttl .num img {
	height: min(3.596vw, 41px);
}
#CONTENTS .scene .scene_list .text_box .ttl .txt {
	box-sizing: border-box;
	padding: min(0.789vw, 9px);
	width: fit-content;
	display: block;
	background: #D7D4E7;
}
#CONTENTS .scene .scene_list .text_box p {
	font-size: min(2.456vw, 28px);
	font-weight: 600;
	letter-spacing: 0.1em;
}
#CONTENTS .scene .scene_list li .photo {
	max-width: 100%;
}
#CONTENTS .scene .scene_list .item01 .photo {
	margin: max(-13.596vw, -155px) 0 0 auto;
	width: min(67.544vw, 770px);
}
#CONTENTS .scene .scene_list .item02 {
	margin-bottom: 152px;
}
#CONTENTS .scene .scene_list .item02 .photo {
	width: min(87.018vw, 992px);
	margin-top: max(-6.316vw, -72px);
}
#CONTENTS .scene .scene_list .item03 {
	margin-bottom: 119px;
}
#CONTENTS .scene .scene_list .item03 .photo {
	margin: max(-13.596vw, -155px) 0 0 auto;
	width: min(70.263vw, 801px);
}
#CONTENTS .scene .scene_list .item04 .photo {
	margin: max(-6.404vw, -73px) auto 0 auto;
	width: min(81.228vw, 926px);
}
#CONTENTS .different {
	padding: 86px 0 113px;
	background: #F5F2E9;
}
#CONTENTS .different .headline02 {
	margin-bottom: 32px;
}
#CONTENTS .different .center_txt {
	margin-bottom: 43px;
	text-align: center;
}
#CONTENTS .different .diff_image {
	margin-bottom: 115px;
	text-align: center;
}
#CONTENTS .different .diff_image img {
	width: 900px;
}
#CONTENTS .different .point .heading {
	margin-bottom: 60px;
	display: flex;
	gap: min(1.579vw, 18px);
}
#CONTENTS .different .point .heading .num {
	width: min(4.386vw, 50px);
	display: block;
	flex-shrink: 0;
}
#CONTENTS .different .point .heading .txt {
	margin-top: min(1.14vw, 13px);
	display: block;
	flex: 1;
	color: #494541;
	font-size: min(2.456vw, 28px);
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.1;
}
#CONTENTS .different .point01 .point_inner {
	margin: 0 auto;
	max-width: 1000px;
}
#CONTENTS .different .point01 .img_box01 {
	margin: 0 auto 40px;
	max-width: min(82.456vw, 940px);
	padding-right: 2.2%;
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
	gap: 18px;
	box-sizing: border-box;
}
#CONTENTS .different .point01 .img_box01 .text_box {
	padding: min(2.193vw, 25px) min(3.509vw, 40px) min(2.368vw, 27px);
	flex: 1;
	position: relative;
	background: #fff;
}
#CONTENTS .different .point01 .img_box01 .text_box::after {
	margin-left: max(-1.579vw, -18px);
	width: 0;
	height: 0;
	position: absolute;
	left: 100%;
	top: 45px;
	border-left: min(6.316vw, 72px) solid #fff;
	border-top: min(1.667vw, 19px) solid transparent;
	border-bottom: min(1.667vw, 19px) solid transparent;
	transform: rotate(25deg);
	content: '';
}
#CONTENTS .different .point01 .img_box01 .text_box p {
	color: #505050;
	font-size: min(1.579vw, 18px);
	line-height: 2;
	letter-spacing: 0.04em;
}
#CONTENTS .different .point01 .img_box01 .photo {
	margin-top: 12px;
	width: min(15.789vw, 180px);
}
#CONTENTS .different .point01 .image {
	margin-bottom: 53px;
}
#CONTENTS .different .point01 .text01 {
	margin-bottom: 12px;
	font-size: min(1.754vw, 20px);
	font-weight: 700;
	text-align: center;
}
#CONTENTS .different .point01 .img_box02 {
	margin-bottom: 80px;
	padding: 46px 7.2%;
	display: flex;
	gap: 31px;
	align-items: center;
	background: #fff;
	border: 1px solid #333333;
}
#CONTENTS .different .point01 .img_box02 .image_list {
	width: 26.64%;
}
#CONTENTS .different .point01 .img_box02 .text_box {
	margin-bottom: 5px;
	flex: 1;
}
#CONTENTS .different .point01 .img_box02 .text_box p {
	font-size: 14px;
	line-height: 1.714;
	letter-spacing: 0;
}
#CONTENTS .different .point01 .img_box02 .text_box p:not(:last-child) {
	margin-bottom: 7px;
}
#CONTENTS .different .point01 .img_box02 .text_box .note {
	font-size: 12px;
}
#CONTENTS .different .point01 .standards {
	margin-bottom: 11px;
	padding: 25px min(1.754vw, 20px) 26px;
	display: flex;
	align-items: center;
	background: #fff;
}
#CONTENTS .different .point01 .standards .left_box {
	margin: 4px 15px 0 13px;
	flex: 1;
}
#CONTENTS .different .point01 .standards .left_box p {
	font-size: min(1.754vw, 20px);
	font-weight: 700;
	line-height: 2.4;
	letter-spacing: 0;
}
#CONTENTS .different .point01 .standards .text_list {
	width: 68.4%;
	display: flex;
	flex-wrap: wrap;
	gap: min(1.053vw, 12px);
}
#CONTENTS .different .point01 .standards .text_list li {
	padding: 33px 15px 32px;
	width: calc((100% - min(2.105vw, 24px)) / 3);
	text-align: center;
	background: #F5EFE3;
	border-radius: 12px;
	box-sizing: border-box;
}
#CONTENTS .different .point01 .standards .text_list li .ttl {
	margin: 0 auto 12px;
	padding: 5px 10px 4px;
	width: 136px;
	max-width: 100%;
	font-size: min(1.754vw, 20px);
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0;
	color: #fff;
	background: #7872AB;
	border-radius: 15px;
	box-sizing: border-box;
}
#CONTENTS .different .point01 .standards .text_list li .text {
	letter-spacing: 0;
	line-height: 1.5;
}
#CONTENTS .different .point01 .note {
	font-size: min(1.228vw, 14px);
	line-height: 1.71;
	letter-spacing: 0;
}
#CONTENTS .different .point01 .note a {
	text-decoration: none;
}
#CONTENTS .different .point01 .note a:hover {
	text-decoration: underline;
}
#CONTENTS .different .point01 {
	margin-bottom: 90px;
}
#CONTENTS .different .point02 {
	margin: 0 auto 71px;
	max-width: 1000px;
	display: flex;
	justify-content: space-between;
	gap: 30px;
}
#CONTENTS .different .point02 .text_box {
	width: 47%;
}
#CONTENTS .different .point02 .text_box .heading {
	margin-bottom: 44px;
}
#CONTENTS .different .point02 .photo {
	margin-top: 26px;
	width: 50%;
	text-align: center;
}
#CONTENTS .different .point02 .photo img {
	width: 260px;
}
#CONTENTS .different .point03 {
	margin: 0 auto;
	max-width: 1020px;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	gap: 30px;
}
#CONTENTS .different .point03 .text_box {
	width: 50%;
}
#CONTENTS .different .point03 .text_box p {
	margin-bottom: 11px;
}
#CONTENTS .different .point03 .text_box p:last-child {
	margin-bottom: 0 !important;
}
#CONTENTS .different .point03 .text_box .heading {
	margin-bottom: 11px;
}
#CONTENTS .different .point03 .text_box .tbl_box {
	margin-bottom: 7px;
	max-width: 509px;
}
#CONTENTS .different .point03 .text_box table {
	width: 100%;
	border-collapse: collapse;
}
#CONTENTS .different .point03 .text_box th,
#CONTENTS .different .point03 .text_box td {
	padding: 2px;
	width: 50%;
	box-sizing: border-box;
	text-align: center;
	vertical-align: middle;
	color: #505050;
	font-size: min(1.316vw, 15px);
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: 0;
	background: #fff;
	border: 1px solid #707070;
}
#CONTENTS .different .point03 .text_box th {
	background: #D9D9D9;
	font-weight: 700;
}
#CONTENTS .different .point03 .text_box .note {
	margin-bottom: 0;
	padding-left: 1em;
	text-indent: -1em;
	font-size: min(1.228vw, 14px);
	line-height: 1.45;
}
#CONTENTS .different .point03 .photo {
	margin-top: 31px;
	width: 47%;
	text-align: center;
}
#CONTENTS .different .point03 .photo img {
	width: 315px;
}
#CONTENTS .buy {
	padding: 120px 0 50px;
}
#CONTENTS .buy .headline01 {
	margin-bottom: 54px;
}
#CONTENTS .buy .center-txt {
	margin-bottom: 10px;
	text-align: center;
}
#CONTENTS .buy .step_list {
	margin: 0 auto;
	max-width: 946px;
}
#CONTENTS .buy .step_list > li {
	padding-bottom: 20px;
	display: flex;
	justify-content: space-between;
	gap: 30px;
	position: relative;
	z-index: 1;
}
#CONTENTS .buy .step_list > li:not(:last-child)::before {
	width: 1px;
	height: 100%;
	position: absolute;
	left: 80px;
	top: 0;
	background: #707070;
	content: '';
	z-index: -1;
}
#CONTENTS .buy .step_list li .image {
	width: 160px;
}
#CONTENTS .buy .step_list li .text_box {
	max-width: 722px;
	display: flex;
	justify-content: space-between;
	flex: 1;
}
#CONTENTS .buy .step_list li .text_box .ttl_box {
	width: 34.4%;
	position: relative;
	display: flex;
	align-items: center;
}
#CONTENTS .buy .step_list li .text_box .ttl_box::after {
	width: 1px;
	height: 56px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	border-left: 1px dashed #707070;
	box-sizing: border-box;
	content: '';
}
#CONTENTS .buy .step_list li .text_box .ttl_box .ttl {
	padding-right: 10px;
	font-size: min(1.754vw, 20px);
	font-weight: 700;
}
#CONTENTS .buy .step_list li .text_box .ttl_box .ttl .num {
	margin-bottom: 11px;
	width: 69px;
	padding: 7px 3px;
	box-sizing: border-box;
	display: block;
	text-align: center;
	font-size: 16px;
	line-height: 1.1;
	border-radius: 8px;
	background: #D7D4E7;
}
#CONTENTS .buy .step_list li .text_box .text_list {
	width: 61.5%;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
#CONTENTS .buy .step_list li .text_box .text_list > li {
	padding-left: 13px;
	width: 100%;
	position: relative;
	letter-spacing: 0.08em;
	line-height: 2.2;
}
#CONTENTS .buy .step_list li .text_box .text_list > li::before {
	width: 8px;
	height: 8px;
	position: absolute;
	left: 0;
	top: 1.1em;
	box-sizing: border-box;
	transform: translateY(-50%);
	border-radius: 100%;
	background: #7872AB;
	content: '';
}
#CONTENTS .buy .step_list li .text_box .text_list li .note_box {
	margin-top: 7px;
	font-size: min(1.228vw, 14px);
	line-height: 1.715;
}
#CONTENTS .buy .step_list li .text_box .text_list li .note_box p {
	line-height: inherit;
	letter-spacing: 0;
}
#CONTENTS .buy .step_list li .text_box .text_list li .note_box ul {
	margin-left: 1em;
	max-width: 350px;
	line-height: inherit;
}
#CONTENTS .buy .step_list li .text_box .text_list li .note_box li {
	padding-left: 1em;
	text-indent: -1em;
	line-height: inherit;
	letter-spacing: 0;
}
#CONTENTS .ask {
	padding: 50px 0 0;
}
#CONTENTS .ask .headline01 {
	margin-bottom: 53px;
}
#CONTENTS .ask .center_txt {
	margin-bottom: 34px;
	text-align: center;
}
#CONTENTS .ask .link_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px 0;
}
#CONTENTS .ask .link_list li {
	width: 48.2%;
}
#CONTENTS .ask .link_list li .image {
	margin: 0 auto 40px;
	max-width: 480px;
}
#CONTENTS .com_btn {
	margin: 0 auto;
	max-width: 480px;
}
#CONTENTS .com_btn a {
	padding: 25px min(1.754vw, 20px) 26px;
	position: relative;
	display: block;
	text-align: center;
	color: #fff !important;
	text-decoration: none !important;
	font-size: min(1.754vw, 20px);
	font-weight: 700;
	letter-spacing: 0.04em;
	border-radius: 50px;
	background: #494541;
	overflow: hidden;
}
#CONTENTS .com_btn a.disabled {
	pointer-events: none;
	cursor: default;
	opacity: 0.7;
}
#CONTENTS .com_btn a::before {
	width: 0;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: #D7D4E7;
	transition: 0.3s;
	content: '';
}
#CONTENTS .com_btn a:hover::before {
	width: 100%;
}
#CONTENTS .com_btn a .btn_txt {
	position: relative;
	z-index: 1;
}
#CONTENTS .rules {
	padding: 120px 0 160px;
	background: #F5F2E9;
}
#CONTENTS .rules .text01 {
	margin-bottom: 25px;
	text-align: center;
	font-size: min(2.456vw, 28px);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.04em;
	color: #7872AB;
}
#CONTENTS .rules .text02 {
	margin-bottom: 39px;
	text-align: center;
}
#CONTENTS .rules .image01 {
	margin: 0 auto 63px;
	width: 380px;
	max-width: 36%;
}
#CONTENTS .rules .img_list01 {
	margin: 0 auto 81px;
	max-width: 860px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 60px 0;
}
#CONTENTS .rules .img_list01 li {
	width: 47%;
	max-width: 373px;
}
#CONTENTS .rules .img_list01 li .text {
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 22px;
}
#CONTENTS .rules .img_list01 li .icon {
	width: 58px;
}
#CONTENTS .rules .img_list01 li .icon01 {
	width: 120px;
}
#CONTENTS .rules .img_box01 {
	margin: 0 4px 77px;
	display: flex;
	justify-content: space-between;
}
#CONTENTS .rules .img_box01 .text_box {
	width: 53.2%;
}
#CONTENTS .rules .img_box01 .text_box p {
	text-align: justify;
	letter-spacing: 0.06em;
}
#CONTENTS .rules .img_box01 .text_box .ttl {
	margin-bottom: 39px;
	margin-right: -1em;
	color: #7872AB;
	font-weight: 700;
	font-size: min(2.456vw, 28px);
	line-height: 1.29;
	letter-spacing: 0.04em;
}
#CONTENTS .rules .img_box01 .photo_box {
	margin-top: 3px;
	width: 43.4%;
}
#CONTENTS .rules .img_box01 .photo_box img {
	width: 100%;
}
#CONTENTS .rules .img_box02 {
	margin: 0 3px 55px 18px;
	display: flex;
	justify-content: space-between;
}
#CONTENTS .rules .img_box02 .text_box {
	width: 48%;
}
#CONTENTS .rules .img_box02 .text_box .image {
	max-width: 488px;
	margin-bottom: 29px;
}
#CONTENTS .rules .img_box02 .text_box .text_list {
	display: flex;
	flex-direction: column;
	gap: 15px;
	font-size: min(1.711vw, 19.5px);
	letter-spacing: 0.039em;
	color: #251E1C;
}
#CONTENTS .rules .img_box02 .text_box .text_list li {
	width: 100%;
	padding-left: 27px;
	position: relative;
}
#CONTENTS .rules .img_box02 .text_box .text_list li::before {
	width: 8px;
	position: absolute;
	left: 14px;
	top: 11px;
	aspect-ratio: 1;
	background: #5780AC;
	border-radius: 100%;
	content: '';
}
#CONTENTS .rules .img_box02 .text_box .text_list .red {
	color: #B75551;
	font-size: min(2.281vw, 26px);
	font-weight: 700;
}
#CONTENTS .rules .img_box02 .photo_box {
	width: 45.3%;
}
#CONTENTS .rules .img_box02 .photo_box img {
	width: 100%;
}
#CONTENTS .rules .img_box02 .photo_box .flash_light {
	width: 100%;
	position: relative;
	overflow: hidden;
	aspect-ratio: 960/500;
}
#CONTENTS .rules .img_box02 .photo_box .flash_light video {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
#CONTENTS .rules .img_box02 .photo_box .txt {
	display: block;
	margin-top: 11px;
	color: #1C1715;
}
#CONTENTS .rules .helmet {
	margin-bottom: 101px;
	padding: 45px 39px 47px 67px;
	display: flex;
	gap: 29px;
	border-radius: 12px;
	border: 2px solid #7872AB;
	background: #fff;
}
#CONTENTS .rules .helmet .photo {
	width: 14.2%;
}
#CONTENTS .rules .helmet .photo img {
	width: 100%;
}
#CONTENTS .rules .helmet .text_box {
	margin-top: 8px;
	flex: 1;
}
#CONTENTS .rules .helmet .text_box .ttl {
	margin-bottom: 19px;
	font-size: min(2.456vw, 28px);
	font-weight: 700;
	letter-spacing: 0;
}
#CONTENTS .rules .text_lead {
	margin-bottom: 49px;
	text-align: center;
	font-weight: 700;
	font-size: min(2.105vw, 24px);
	line-height: 1.33;
	letter-spacing: 0.04em;
}
#CONTENTS .rules .movie_box {
	margin-bottom: 120px;
}
#CONTENTS .rules .movie_box .text_lead {
	margin-bottom: 23px;
}
#CONTENTS .rules .movie_box .movie {
	max-width: 800px;
	margin: 0 auto;
}
#CONTENTS .rules .img_list02 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 60px 0;
}
#CONTENTS .rules .img_list02 li {
	width: 48%;
}
#CONTENTS .rules .img_list02 .photo {
	margin: 0 auto 14px;
	max-width: 508px;
}
#CONTENTS .rules .img_list02 p {
	margin: 0 auto 33px;
	max-width: 508px;
}
#CONTENTS .faq {
	padding: 120px 0 30px;
}
#CONTENTS .faq .headline01 {
	margin-bottom: 50px;
}
#CONTENTS .faq .faq_list {
	margin: 0 auto;
	max-width: 1000px;
}
#CONTENTS .faq .faq_list dt {
	margin-top: 8px;
	padding: 13px 50px 14px 2px;
	display: flex;
	gap: 5px;
	position: relative;
	cursor: pointer;
}
#CONTENTS .faq .faq_list dt:first-child {
	margin-top: 0;
}
#CONTENTS .faq .faq_list dt::before {
	width: 18px;
	height: 2px;
	position: absolute;
	right: 16px;
	top: 30px;
	background: #000;
	content: '';
}
#CONTENTS .faq .faq_list dt::after {
	width: 2px;
	height: 18px;
	position: absolute;
	right: 24px;
	top: 22px;
	background: #000;
	content: '';
}
#CONTENTS .faq .faq_list dt.on::after {
	display: none;
}
#CONTENTS .faq .faq_list dt .num {
	margin-top: 3px;
	min-width: min(6.14vw, 70px);
	display: block;
	flex-shrink: 0;
	font-size: min(2.807vw, 32px);
	font-weight: 700;
	line-height: 1.05;
}
#CONTENTS .faq .faq_list dt .ttl {
	display: flex;
	gap: min(1.053vw, 12px);
	align-items: flex-start;
	flex: 1;
	font-size: min(1.579vw, 18px);
	line-height: 2;
	letter-spacing: 0.04em;
}
#CONTENTS .faq .faq_list dt .ttl::after {
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	bottom: 0;
	background-image: linear-gradient(to right, #707070 20%, transparent 20%);
	background-size: 10px 2px;
	content: '';
}
#CONTENTS .faq .faq_list dt .ttl .tag {
	margin-top: min(0.614vw, 7px);
	padding: 4px 5px;
	box-sizing: border-box;
	min-width: min(8.947vw, 102px);
	text-align: center;
	color: #fff;
	font-size: min(1.14vw, 13px);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 0;
	background: #79BDD0;
	border-radius: 4px;
}
#CONTENTS .faq .faq_list dt .ttl .tag01 {
	background: #8000FF;
}
#CONTENTS .faq .faq_list dt .ttl .tag02 {
	background: #0053EF;
}
#CONTENTS .faq .faq_list dt .ttl .tag03 {
	background: #00CADB;
}
#CONTENTS .faq .faq_list dt .ttl .tag04 {
	background: #00C33C;
}
#CONTENTS .faq .faq_list dt .ttl .tag05 {
	background: #FF8900;
}
#CONTENTS .faq .faq_list dt .ttl .tag06 {
	background: #009CEF;
}
#CONTENTS .faq .faq_list dt .ttl .txt {
	flex: 1;
	color: #505050;
	letter-spacing: 0.04em;
}
#CONTENTS .faq .faq_list dd {
	display: none;
}
#CONTENTS .faq .faq_list dd .inner_wrap {
	padding: 24px 40px 38px;
}
#CONTENTS .faq .faq_list dd p {
	margin-bottom: 33px;
}
#CONTENTS .faq .faq_list dd p:last-child {
	margin-bottom: 0 !important;
}
#CONTENTS .faq .faq_list dd p.mb01 {
	margin-bottom: 0;
}
#CONTENTS .faq .faq_list dd p.mb0 {
	margin-bottom: 0;
}
#CONTENTS .faq .faq_list dd .note {
	padding-left: 1em;
	text-indent: -1em;
}
#CONTENTS .faq .faq_list dd .btn a {
	padding: 6px 40px 7px 25px;
	display: inline-block;
	vertical-align: top;
	text-decoration: none;
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
	border-radius: 50px;
	background: #333 url(../img/btn_icon01.png) no-repeat right 25px center / 5px;
}
#CONTENTS .faq .faq_list dd .btn a:hover {
	opacity: 0.7;
}
#CONTENTS .faq .faq_list dd .image01 {
	margin-bottom: 20px;
	max-width: 840px;
}
#CONTENTS .faq .faq_list dd .img_box {
	display: flex;
	justify-content: space-between;
	margin-bottom: 5px;
}
#CONTENTS .faq .faq_list dd .img_box .text_box {
	margin-bottom: 40px;
	width: 61%;
}
#CONTENTS .faq .faq_list dd .img_box .photo_box {
	width: 35.5%;
	margin-top: 6px;
}
#CONTENTS .faq .faq_list dd .img_box .photo_box img {
	width: 310px;
}
#CONTENTS .faq .faq_list dd .gray_box {
	margin-bottom: 40px;
	padding: 22px 40px 25px;
	font-size: min(1.228vw, 14px);
	line-height: 2.57;
	letter-spacing: 0.06em;
	border-radius: 12px;
	background: #F4F4F4;
}
#CONTENTS .faq .faq_list dd .gray_box:last-child {
	margin-bottom: 0 !important;
}
#CONTENTS .faq .faq_list dd .gray_box p {
	margin-bottom: 0;
	line-height: inherit;
	letter-spacing: inherit;
}
#CONTENTS .faq .faq_list dd .gray_box ul,
#CONTENTS .faq .faq_list dd .gray_box li {
	line-height: inherit;
}
#CONTENTS .faq .faq_list dd .gray_box .text_list li {
	padding-left: 1em;
	text-indent: -1em;
	letter-spacing: 0;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box {
	display: flex;
	justify-content: space-between;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col01 {
	margin-bottom: 23px;
	width: 60%;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 {
	margin-bottom: 23px;
	width: 36%;
	max-width: 303px;
	align-self: flex-end;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 table {
	width: 100%;
	border-collapse: collapse;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 th,
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 td {
	width: 50%;
	padding: 2px;
	text-align: center;
	vertical-align: middle;
	font-size: min(1.316vw, 15px);
	font-weight: 400;
	color: #505050;
	letter-spacing: 0;
	line-height: 1.5;
	box-sizing: border-box;
	background: #fff;
	border: 1px solid #707070;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 th {
	font-weight: 700;
	background: #D9D9D9;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col03 {
	width: 62%;
	max-width: 520px;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col03 p {
	letter-spacing: 0.08em;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col03 .sub_note {
	padding-left: 1em;
	text-indent: -1em;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col04 {
	margin-top: 3em;
	width: 36%;
}
#CONTENTS .faq .faq_list dd .gray_box .sub_box .col04 img {
	width: auto;
}
#CONTENTS .faq .faq_list dd .tbl_image {
	margin: -10px 0 0;
}
#CONTENTS .faq .faq_list dd .tbl_image img {
	width: 913px;
}
#CONTENTS .faq .faq_list dd .img_box .photo_box01 {
	margin-right: -25px;
	width: calc(35.6% + 25px);
}
#CONTENTS .faq .faq_list dd .img_box .photo_box01 img {
	width: auto;
}
#CONTENTS .faq .faq_list dd .img_box .photo_box02 {
	margin-top: 19px;
	width: 26%;
}
#CONTENTS .faq .faq_list dd .img_box .photo_box02 img {
	width: 195px;
}
#CONTENTS .btn_list {
	margin: 0 auto;
	max-width: 1040px;
	display: flex;
	justify-content: space-between;
}
#CONTENTS .btn_list li {
	margin: 0;
	width: 48%;
	max-width: 480px;
}
#CONTENTS .bottom_banner {
	margin-top: 155px;
	padding: 65px min(1.754vw, 20px) 146px;
	text-align: center;
	background: #F5F2E9;
}
#CONTENTS .bottom_banner p {
	margin-bottom: 21px;
	font-size: min(2.105vw, 24px);
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.3;
}
#CONTENTS .bottom_banner a {
	margin: 0 auto;
	max-width: 800px;
	display: block;
}
#CONTENTS .bottom_banner a:hover {
	opacity: 0.7;
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
	#CONTENTS .about .mobility {
		margin-left: 0;
		margin-right: 0;
	}
	#CONTENTS .about .mobility .text_box .headline02 {
		letter-spacing: 0;
	}
	#CONTENTS .about .features .img_box .text_box .heading {
		letter-spacing: 0;
	}
}
@media screen and (max-width: 767px) {
	#main_visual {
		padding: min(9.694vw, 38px) min(5.102vw, 20px) min(76.02vw, 298px);
		background-image: url(../img/mv_bg_sp.png);
		background-position: left 50% top 70%;
	}
	#main_visual h1 {
		margin-bottom: min(3.827vw, 15px);
	}
	#cy-body.visual_appeal #main_visual img {
		width: min(76.786vw, 301px);
	}
	#main_visual p {
		font-size: min(3.571vw, 14px);
		letter-spacing: 0.06em;
	}
	#CONTENTS .menu_btn {
		width: 64px;
		right: 0;
		bottom: 0;
		color: #fff;
		font-size: 0;
		border-radius: 0;
	}
	#CONTENTS .menu_btn .icon {
		padding: 0;
		width: 24px;
	}
	#CONTENTS .menu_wrap {
		padding: 66px 20px;
		max-width: 400px;
	}
	#CONTENTS .menu_wrap .menu_img {
		width: 301px;
		margin-bottom: 28px;
	}
	#CONTENTS .menu_wrap .nav_list {
		margin-bottom: 35px;
	}
	#CONTENTS .menu_wrap .nav_list li {
		margin-bottom: 9px;
	}
	#CONTENTS .menu_wrap .nav_list li:last-child {
		margin-bottom: 0;
	}
	#CONTENTS .menu_wrap .menu_close {
		width: 37px;
	}
	#CONTENTS .menu_wrap .menu_close:hover {
		opacity: 1;
	}
	#CONTENTS .about {
		padding: 83px 0 40px;
	}
	#CONTENTS .about .conts_wrap {
		width: auto;
	}
	#CONTENTS .about .mobility {
		margin: 0 0 30px 10px;
		display: block;
	}
	#CONTENTS .about .mobility .headline02 {
		margin: 0 -1rem 34px 0;
		width: auto;
	}
	#CONTENTS .about .mobility .text_box {
		margin: 0;
		width: auto;
	}
	#CONTENTS .about .mobility .text_box p {
		margin-bottom: 28px;
		letter-spacing: 0.12em;
	}
	#CONTENTS .about .mobility .text_box p:last-child {
		margin-bottom: 0;
	}
	#CONTENTS .about .mobility .photo_box {
		margin-top: 16px;
		padding-left: min(7.653vw, 30px);
		width: auto;
		text-align: center;
	}
	#CONTENTS .about .mobility .photo_box img {
		width: min(61.224vw, 240px);
	}
	#CONTENTS .about .image {
		margin-bottom: 79px;
	}
	#CONTENTS .about .image img {
		width: 100%;
	}
	#CONTENTS .about .features .center_txt {
		margin-bottom: 34px;
		font-size: min(3.571vw, 14px);
		line-height: 1;
		line-height: 1.71;
		letter-spacing: 0.08em;
	}
	#CONTENTS .about .features .img_box {
		margin: 0 min(2.551vw, 10px) 55px;
		display: block;
	}
	#CONTENTS .about .features .img_box .text_box {
		padding-left: 0;
		width: auto;
	}
	#CONTENTS .about .features .img_box .text_box .heading {
		margin-bottom: 15px;
		font-size: min(4.592vw, 18px);
		line-height: 1.78;
	}
	#CONTENTS .about .features .img_box .text_box p {
		letter-spacing: 0.12em;
	}
	#CONTENTS .about .features .img_box .photo_list {
		margin-top: 16px;
		width: auto;
		flex-direction: column;
		gap: 19px 0;
	}
	#CONTENTS .about .features .img_box .photo_list li {
		width: 70.4%;
	}
	#CONTENTS .about .features .img_box .photo_list li:nth-child(2n) {
		margin-left: auto;
	}
	#CONTENTS .about .features .img_box .photo_list li .txt {
		margin-top: 12px;
		font-size: min(3.061vw, 12px);
	}
	#CONTENTS .about .features .img_box.rev {
		margin-bottom: 45px;
	}
	#CONTENTS .about .features .img_box.rev .text_box {
		width: auto;
	}
	#CONTENTS .about .features .table_img {
		margin-bottom: 20px;
		overflow-x: auto;
	}
	#CONTENTS .about .features .table_img img {
		width: 1120px;
		max-width: initial;
	}
	#CONTENTS .about .features .note_list li {
		font-size: min(3.061vw, 12px);
	}
	#CONTENTS .scene {
		padding: 60px 0;
	}
	#CONTENTS .scene .headline01 {
		margin-bottom: 38px;
	}
	#CONTENTS .scene .headline03 {
		margin-bottom: 17px;
	}
	#CONTENTS .scene .center_txt {
		margin-bottom: 54px;
		font-size: min(3.571vw, 14px);
		font-weight: 700;
		letter-spacing: 0.12em;
		line-height: 1.71;
	}
	#CONTENTS .scene .scene_list li {
		margin-bottom: 43px;
	}
	#CONTENTS .scene .scene_list .text_box {
		padding: 0;
	}
	#CONTENTS .scene .scene_list .text_box .ttl {
		margin-bottom: 15px;
		padding-left: min(1.531vw, 6px);
		gap: min(5.102vw, 20px);
		font-size: min(4.592vw, 18px);
	}
	#CONTENTS .scene .scene_list .text_box .ttl .num {
		width: min(15.306vw, 60px);
	}
	#CONTENTS .scene .scene_list .text_box .ttl .num img {
		height: min(10.459vw, 41px);
	}
	#CONTENTS .scene .scene_list .text_box .ttl .txt {
		padding: 6px min(2.296vw, 9px);
	}
	#CONTENTS .scene .scene_list .text_box p {
		margin-bottom: 6px;
		font-size: min(5.102vw, 20px);
	}
	#CONTENTS .scene .scene_list li .photo {
		margin: 0 !important;
		width: auto !important;
	}
	#CONTENTS .scene .scene_list li .photo img {
		width: 100%;
	}
	#CONTENTS .scene .scene_list .item02 {
		margin-bottom: 62px;
	}
	#CONTENTS .scene .scene_list .item03 {
		margin-bottom: 62px;
	}
	#CONTENTS .different {
		padding: 40px 0 80px;
	}
	#CONTENTS .different .headline02 {
		margin: 0 0 35px;
	}
	#CONTENTS .different .center_txt {
		margin-bottom: 16px;
	}
	#CONTENTS .different .diff_image {
		margin: 0 -15px 60px 9px;
		padding-right: 15px;
		overflow-x: auto;
	}
	#CONTENTS .different .diff_image img {
		width: 548px;
		max-width: initial;
	}
	#CONTENTS .different .point .heading {
		margin: 0 5px 32px;
		flex-direction: column;
		gap: min(3.316vw, 13px);
	}
	#CONTENTS .different .point .heading .num {
		width: min(12.755vw, 50px);
	}
	#CONTENTS .different .point .heading .txt {
		margin: 0 5px;
		color: #494541;
		font-size: min(6.122vw, 24px);
		line-height: 1.29;
	}
	#CONTENTS .different .point01 .point_inner {
		max-width: initial;
	}
	#CONTENTS .different .point01 .img_box01 {
		margin: 0 min(2.551vw, 10px) 26px;
		max-width: initial;
		padding: 0;
		display: block;
	}
	#CONTENTS .different .point01 .img_box01 .text_box {
		padding: 19px min(7.653vw, 30px) 21px;
	}
	#CONTENTS .different .point01 .img_box01 .text_box::after {
		margin: max(-6.378vw, -25px) 0 0;
		left: auto;
		right: min(27.296vw, 107px);
		top: 100%;
		border-top: min(17.857vw, 70px) solid #fff;
		border-left: min(4.082vw, 16px) solid transparent;
		border-right: min(4.082vw, 16px) solid transparent;
		border-bottom: none;
		transform: rotate(-47deg);
	}
	#CONTENTS .different .point01 .img_box01 .text_box p {
		font-size: min(3.571vw, 14px);
		line-height: 2.14;
		position: relative;
		z-index: 2;
	}
	#CONTENTS .different .point01 .img_box01 .photo {
		margin-top: max(-6.888vw, -27px);
		margin-left: auto;
		width: min(33.418vw, 131px);
		position: relative;
		z-index: 1;
	}
	#CONTENTS .different .point01 .image {
		margin: 0 -15px 50px min(2.551vw, 10px);
		padding-right: 15px;
		overflow-x: auto;
		text-align: center;
	}
	#CONTENTS .different .point01 .image img {
		max-width: initial;
		width: 1000px;
	}
	#CONTENTS .different .point01 .text01 {
		margin-bottom: 14px;
		font-size: min(4.082vw, 16px);
		line-height: 1.75;
		letter-spacing: 0.06em;
	}
	#CONTENTS .different .point01 .img_box02 {
		margin: 0 min(2.551vw, 10px) 80px;
		padding: 31px min(7.653vw, 30px);
		display: block;
		border: none;
		border-radius: 12px;
	}
	#CONTENTS .different .point01 .img_box02 .image_list {
		margin-bottom: 27px;
		width: auto;
		display: block;
	}
	#CONTENTS .different .point01 .img_box02 .image_list li {
		margin-bottom: 18px;
		width: auto;
		text-align: center;
	}
	#CONTENTS .different .point01 .img_box02 .image_list li img {
		width: 228px;
	}
	#CONTENTS .different .point01 .img_box02 .image_list li:last-child {
		margin-bottom: 0;
	}
	#CONTENTS .different .point01 .img_box02 .text_box p {
		font-size: min(3.061vw, 12px);
		line-height: 2;
	}
	#CONTENTS .different .point01 .img_box02 .text_box p:not(:last-child) {
		margin-bottom: 11px;
	}
	#CONTENTS .different .point01 .img_box02 .text_box .note {
		margin-left: 0;
	}
	#CONTENTS .different .point01 .standards {
		margin: 0 -15px 18px;
		padding: 35px 16px 58px;
		display: block;
	}
	#CONTENTS .different .point01 .standards .left_box {
		margin: 0 0 33px;
		text-align: center;
	}
	#CONTENTS .different .point01 .standards .left_box p {
		font-size: min(4.592vw, 18px);
		line-height: 2;
	}
	#CONTENTS .different .point01 .standards .text_list {
		width: auto;
		gap: 14px 16px;
	}
	#CONTENTS .different .point01 .standards .text_list li {
		padding: 33px min(2.551vw, 10px) 10px;
		width: calc(50% - 8px);
		min-height: 178px;
	}
	#CONTENTS .different .point01 .standards .text_list li .ttl {
		margin: 0 min(2.041vw, 8px) 10px;
		padding: 6px 5px 7px;
		width: auto;
		font-size: min(4.082vw, 16px);
	}
	#CONTENTS .different .point01 .standards .text_list li .text {
		line-height: 1.72;
	}
	#CONTENTS .different .point01 .note {
		margin: 0 0 0 min(2.551vw, 10px);
		font-size: min(3.571vw, 14px);
	}
	#CONTENTS .different .point01 .note a:hover {
		text-decoration: none;
	}
	#CONTENTS .different .point01 {
		margin-bottom: 78px;
	}
	#CONTENTS .different .point02 {
		margin-bottom: 60px;
		display: block;
	}
	#CONTENTS .different .point02 .text_box {
		width: auto;
	}
	#CONTENTS .different .point02 .text_box .heading {
		margin-bottom: 17px;
	}
	#CONTENTS .different .point02 .heading .num {
		margin-left: min(1.276vw, 5px);
	}
	#CONTENTS .different .point02 .text_box p {
		margin: 0 min(2.551vw, 10px);
		text-align: justify;
	}
	#CONTENTS .different .point02 .photo {
		width: auto;
		text-align: center;
	}
	#CONTENTS .different .point03 {
		display: block;
	}
	#CONTENTS .different .point03 .text_box {
		width: auto;
	}
	#CONTENTS .different .point03 .text_box .heading {
		margin-bottom: 17px;
	}
	#CONTENTS .different .point03 .text_box .heading .num {
		margin-left: min(1.02vw, 4px);
	}
	#CONTENTS .different .point03 .text_box p {
		margin: 0 0 16px min(2.551vw, 10px);
		letter-spacing: 0.12em;
	}
	#CONTENTS .different .point03 .text_box .tbl_box {
		margin: 0 10px 4px 11px;
		max-width: initial;
	}
	#CONTENTS .different .point03 .text_box th,
	#CONTENTS .different .point03 .text_box td {
		font-size: min(3.571vw, 14px);
	}
	#CONTENTS .different .point03 .text_box .note {
		font-size: min(3.061vw, 12px);
		line-height: 2;
		letter-spacing: 0.08em;
	}
	#CONTENTS .different .point03 .photo {
		margin: 16px 0 0;
		width: auto;
		text-align: center;
	}
	#CONTENTS .different .point03 .photo img {
		width: auto;
	}
	#CONTENTS .buy {
		padding: 80px 0 40px;
	}
	#CONTENTS .buy .headline01 {
		margin-bottom: 34px;
	}
	#CONTENTS .buy .center-txt {
		margin: 0 min(1.276vw, 5px) 58px min(2.551vw, 10px);
		text-align: left;
		letter-spacing: 0.12em;
	}
	#CONTENTS .buy .step_list {
		max-width: initial;
	}
	#CONTENTS .buy .step_list > li {
		padding-bottom: 28px;
		gap: min(6.122vw, 24px);
	}
	#CONTENTS .buy .step_list > li:not(:last-child)::before {
		left: 45px;
	}
	#CONTENTS .buy .step_list li .image {
		width: 90px;
		flex-shrink: 0;
	}
	#CONTENTS .buy .step_list li .text_box {
		margin-top: 5px;
		max-width: initial;
		display: block;
	}
	#CONTENTS .buy .step_list li .text_box .ttl_box {
		margin-bottom: 6px;
		padding-bottom: 14px;
		width: auto;
		display: block;
		border-bottom: 1px dashed #707070;
	}
	#CONTENTS .buy .step_list li .text_box .ttl_box::after {
		display: none;
	}
	#CONTENTS .buy .step_list li .text_box .ttl_box .ttl {
		font-size: min(4.592vw, 18px);
		padding-right: 0;
	}
	#CONTENTS .buy .step_list li .text_box .ttl_box .ttl .num {
		padding: 7px 2px;
		font-size: min(4.082vw, 16px);
		margin-bottom: 12px;
	}
	#CONTENTS .buy .step_list li .text_box .text_list {
		margin-right: 1em;
		width: auto;
	}
	#CONTENTS .buy .step_list li .text_box .text_list > li {
		padding-left: min(4.082vw, 16px);
		line-height: 1.71;
	}
	#CONTENTS .buy .step_list li .text_box .text_list > li::before {
		left: 5px;
		top: 0.8em;
	}
	#CONTENTS .buy .step_list li .text_box .text_list li .note_box {
		margin-top: -1px;
		font-size: min(3.061vw, 12px);
		line-height: 2;
	}
	#CONTENTS .buy .step_list li .text_box .text_list li .note_box p {
		letter-spacing: 0.06em;
	}
	#CONTENTS .buy .step_list li .text_box .text_list li .note_box ul {
		margin-left: 0;
		max-width: initial;
	}
	#CONTENTS .buy .step_list li .text_box .text_list li .note_box li {
		letter-spacing: 0.06em;
	}
	#CONTENTS .ask {
		padding: 40px 0 0;
	}
	#CONTENTS .ask .headline01 {
		margin-bottom: 35px;
	}
	#CONTENTS .ask .center_txt {
		margin: 0 min(2.551vw, 10px) 56px;
		text-align: justify;
	}
	#CONTENTS .ask .link_list {
		display: block;
	}
	#CONTENTS .ask .link_list li {
		margin-bottom: 60px;
		width: auto;
	}
	#CONTENTS .ask .link_list li:last-child {
		margin-bottom: 0;
	}
	#CONTENTS .ask .link_list li .image {
		margin-bottom: 30px;
		max-width: 341px;
	}
	#CONTENTS .com_btn {
		max-width: 361px;
	}
	#CONTENTS .com_btn a {
		padding: min(5.867vw, 23px) min(5.102vw, 20px);
		font-size: min(4.082vw, 16px);
	}
	#CONTENTS .com_btn a::before {
		display: none;
	}
	#CONTENTS .rules {
		padding: 80px 0;
	}
	#CONTENTS .rules .text01 {
		margin: 0 -5px 34px min(2.551vw, 10px);
		font-size: min(5.102vw, 20px);
		text-align: left;
		line-height: 1.6;
	}
	#CONTENTS .rules .text02 {
		margin: 0 min(2.551vw, 10px) 16px;
		text-align: justify;
	}
	#CONTENTS .rules .image01 {
		margin: 0 0 40px;
		width: auto;
		max-width: initial;
	}
	#CONTENTS .rules .image01 img {
		width: 100%;
	}
	#CONTENTS .rules .img_list01 {
		margin: 0 0 59px;
		max-width: initial;
		gap: 39px 0;
	}
	#CONTENTS .rules .img_list01 li {
		width: 100%;
		max-width: initial;
	}
	#CONTENTS .rules .img_list01 li .text {
		margin-bottom: 9px;
	}
	#CONTENTS .rules .img_box01 {
		margin: 0 0 50px;
		display: block;
	}
	#CONTENTS .rules .img_box01 .text_box {
		margin-bottom: 37px;
		width: auto;
	}
	#CONTENTS .rules .img_box01 .text_box p {
		text-align: center;
		letter-spacing: 0.12em;
	}
	#CONTENTS .rules .img_box01 .text_box .ttl {
		margin: 0 0 34px;
		font-size: min(5.102vw, 20px);
		line-height: 1.6;
	}
	#CONTENTS .rules .img_box01 .photo_box {
		margin-top: 0;
		width: auto;
	}
	#CONTENTS .rules .img_box02 {
		margin: 0 0 59px;
		display: block;
	}
	#CONTENTS .rules .img_box02 .text_box {
		margin-bottom: 33px;
		width: auto;
	}
	#CONTENTS .rules .img_box02 .text_box .image {
		max-width: 361px;
		margin: 0 auto 88px;
	}
	#CONTENTS .rules .img_box02 .text_box .text_list {
		font-size: min(3.571vw, 14px);
		line-height: 1.68;
		gap: 5px 0;
	}
	#CONTENTS .rules .img_box02 .text_box .text_list li {
		width: 100%;
		padding-left: min(4.082vw, 16px);
	}
	#CONTENTS .rules .img_box02 .text_box .text_list li::before {
		left: min(0.51vw, 2px);
		top: min(2.041vw, 8px);
	}
	#CONTENTS .rules .img_box02 .text_box .text_list .red {
		font-size: min(4.082vw, 16px);
	}
	#CONTENTS .rules .img_box02 .photo_box {
		width: auto;
	}
	#CONTENTS .rules .img_box02 .photo_box .txt {
		font-size: min(4.082vw, 16px);
		margin-top: 8px;
	}
	#CONTENTS .rules .helmet {
		margin-bottom: 59px;
		padding: 30px min(5.102vw, 20px) 26px;
		display: block;
		position: relative;
	}
	#CONTENTS .rules .helmet .photo {
		width: min(22.449vw, 88px);
		position: absolute;
		left: min(4.847vw, 19px);
		top: 30px;
	}
	#CONTENTS .rules .helmet .text_box {
		margin: 0;
	}
	#CONTENTS .rules .helmet .text_box .ttl {
		margin-bottom: 17px;
		margin-right: max(-3.827vw, -15px);
		padding-left: min(22.959vw, 90px);
		min-height: min(29.592vw, 116px);
		display: flex;
		align-items: center;
		font-size: min(5.102vw, 20px);
		line-height: 1.6;
	}
	#CONTENTS .rules .text_lead {
		margin-bottom: 19px;
		font-size: min(5.102vw, 20px);
		line-height: 1.6;
	}
	#CONTENTS .rules .movie_box {
		margin-bottom: 56px;
	}
	#CONTENTS .rules .movie_box .text_lead {
		margin-bottom: 16px;
		font-size: min(4.592vw, 18px);
		line-height: 1.78;
	}
	#CONTENTS .rules .movie_box .movie {
		max-width: 100%;
	}
	#CONTENTS .rules .img_list02 {
		gap: 50px 0;
	}
	#CONTENTS .rules .img_list02 li {
		width: 100%;
	}
	#CONTENTS .rules .img_list02 .photo {
		margin-bottom: 29px;
		max-width: initial;
	}
	#CONTENTS .rules .img_list02 p {
		display: none;
	}
	#CONTENTS .faq {
		padding: 80px 0 40px;
	}
	#CONTENTS .faq .headline01 {
		margin-bottom: 19px;
	}
	#CONTENTS .faq .faq_list {
		max-width: initial;
	}
	#CONTENTS .faq .faq_list dt {
		margin-top: 9px;
		padding: 16px 40px 17px 0;
		gap: 0;
	}
	#CONTENTS .faq .faq_list dt:first-child {
		margin-top: 0;
	}
	#CONTENTS .faq .faq_list dt::before {
		right: 9px;
		top: 29px;
	}
	#CONTENTS .faq .faq_list dt::after {
		right: 17px;
		top: 21px;
	}
	#CONTENTS .faq .faq_list dt .num {
		margin-top: 3px;
		font-size: min(6.122vw, 24px);
		min-width: min(12.755vw, 50px);
		display: block;
	}
	#CONTENTS .faq .faq_list dt .ttl {
		margin-top: 4px;
		display: block;
		font-size: min(4.082vw, 16px);
	}
	#CONTENTS .faq .faq_list dt .ttl .tag {
		margin: 0 0 7px 5px;
		padding-bottom: 3px;
		width: min(26.02vw, 102px);
		display: block;
		font-size: min(3.316vw, 13px);
	}
	#CONTENTS .faq .faq_list dt .ttl .txt {
		display: block;
	}
	#CONTENTS .faq .faq_list dd .inner_wrap {
		padding: 15px min(11.224vw, 44px) 21px;
	}
	#CONTENTS .faq .faq_list dd p {
		margin-bottom: 28px;
	}
	#CONTENTS .faq .faq_list dd p.mb01 {
		margin-bottom: 27px;
	}
	#CONTENTS .faq .faq_list dd .text01 {
		margin-bottom: 16px;
	}
	#CONTENTS .faq .faq_list dd .btn a {
		padding-top: 8px;
		text-align: left;
		line-height: 1.33;
	}
	#CONTENTS .faq .faq_list dd .btn a:hover {
		opacity: 1;
	}
	#CONTENTS .faq .faq_list dd .btn01 {
		margin: 0 -15px;
		text-align: center;
	}
	#CONTENTS .faq .faq_list dd .btn02 {
		margin: 0 -4px 0 -14px;
	}
	#CONTENTS .faq .faq_list dd .image01 {
		max-width: initial;
		margin: 0 -44px 20px;
		text-align: center;
	}
	#CONTENTS .faq .faq_list dd .img_box {
		display: block;
		margin-bottom: 21px;
	}
	#CONTENTS .faq .faq_list dd .img_box .text_box {
		margin-bottom: 16px;
		width: auto;
	}
	#CONTENTS .faq .faq_list dd .img_box .photo_box {
		margin: 0 -4px 0 -3px;
		width: auto;
		text-align: center;
	}
	#CONTENTS .faq .faq_list dd .img_box .photo_box img {
		width: auto;
	}
	#CONTENTS .faq .faq_list dd .gray_box {
		margin: 0 -3px 17px;
		padding: min(6.888vw, 27px) min(4.592vw, 18px) min(4.337vw, 17px);
		font-size: min(3.571vw, 14px);
		line-height: 1.73;
	}
	#CONTENTS .faq .faq_list dd .gray_box .note_list {
		margin: 11px 0 0 -0.9em;
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box {
		display: block;
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col01 {
		margin-bottom: 20px;
		width: auto;
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 th,
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 td {
		font-size: min(3.827vw, 15px);
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col02 {
		margin: 0 15px 13px;
		width: auto;
		max-width: initial;
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col03 {
		width: auto;
		max-width: initial;
		margin: 0 0 15px;
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col03 p {
		margin-bottom: 15px;
	}
	#CONTENTS .faq .faq_list dd .gray_box .sub_box .col04 {
		margin-bottom: 13px;
		width: auto;
		text-align: center;
	}
	#CONTENTS .faq .faq_list dd .tbl_image {
		margin: -12px -35px 0 0;
		padding-right: 35px;
		text-align: center;
		overflow-x: auto;
	}
	#CONTENTS .faq .faq_list dd .tbl_image img {
		width: 489px;
		max-width: initial;
	}
	#CONTENTS .scroll-hint-icon {
		padding: 5px 10px 10px;
		top: calc(50% - 45px);
	}
	#CONTENTS .faq .scroll-hint-icon {
		top: calc(50% - 49px);
	}
	#CONTENTS .scroll-hint-icon:before {
		width: 70px;
		height: 70px;
		background: url(../img/scroll_icon.png) no-repeat center center / 100%;
	}
	#CONTENTS .scroll-hint-icon:after {
		display: none;
	}
	#CONTENTS .scroll-hint-text {
		margin-top: -5px;
	}
	#CONTENTS .faq .faq_list dd .img_box .photo_box01 {
		margin: 0 -23px -20px -24px;
		width: auto;
		text-align: center;
	}
	#CONTENTS .faq .faq_list dd .img_box .photo_box02 {
		margin: -12px 0 20px;
		width: auto;
		text-align: center;
	}
	#CONTENTS .faq .faq_list dd .img_box .photo_box02 img {
		width: 195px;
	}
	#CONTENTS .btn_list {
		margin: 0 auto;
		max-width: 361px;
		flex-direction: column;
		gap: 20px 0;
	}
	#CONTENTS .btn_list li {
		width: 100%;
	}
	#CONTENTS .bottom_banner {
		margin-top: 120px;
		padding: 57px 16px 120px;
	}
	#CONTENTS .bottom_banner p {
		margin-bottom: 17px;
		font-size: min(4.592vw, 18px);
		line-height: 1.78;
	}
	#CONTENTS .bottom_banner a {
		max-width: 100%;
	}
}
@media screen and (max-width: 390px) {
	#CONTENTS .rules .text01 {
		letter-spacing: 0;
	}
	#CONTENTS .rules .img_box01 .text_box p {
		letter-spacing: 0.06em;
	}
	#CONTENTS .rules .movie_box .text_lead {
		letter-spacing: 0;
	}
	#CONTENTS .faq .faq_list dd .btn a {
		padding-right: 35px;
		letter-spacing: 0;
	}
}
@media screen and (max-width: 374px) {
	#CONTENTS .different .point01 .standards .text_list li .text {
		font-size: min(3.316vw, 13px);
	}
}