@charset "UTF-8";

@font-face {
	font-family: 'D-DIN';
	font-display: block;
	font-style: normal;
	font-weight: 700;
	src: url('../fonts/D-DIN/D-DIN-Bold.woff2') format('woff2'),
		url('../fonts/D-DIN/D-DIN-Bold.woff') format('woff'),
		url('../fonts/D-DIN/D-DIN-Bold.ttf') format('truetype');
}

:root {
	--font-base: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", 'メイリオ', Meiryo, sans-serif;
	--font-D-DIN: 'D-DIN', "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", 'メイリオ', Meiryo, sans-serif;
	--color-white: #fff;
	--color-black01: #2D2D2D;
	--color-gray01: #808080;
	--color-ivory: #FAF8F6;
	--color-green01: #45B4AE;
	--color-yellow01: #FFFB29;
	--color-gradient01: linear-gradient(90deg, rgba(124, 129, 212, 1.00) 0%, rgba(80, 200, 209, 1.00) 100%);
}

@media screen and (max-width:769px) {
	:root {}
}

*, *::before, *::after {
	box-sizing: border-box;
}

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
}

html {
	font-size: 62.5%;
	overflow: inherit !important;
	font-size: clamp(5px, 0.70vw, 10px);
}

body {
	width: 100%;
	height: auto;
	position: relative;
	left: 0;
	top: 0;
	background: var(--color-ivory);
	color: var(--color-black01);
	font-size: 1.5rem;
	font-family: var(--font-base);
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0;
	overflow: auto;
}

h2 {
	font-size: 3.28rem;
	font-weight: 700;
	line-height: 1.6;
}

h3 {
	font-size: 2.1rem;
	font-weight: 700;
	line-height: 1.62;
}

p {
	font-size: 1em;
	font-weight: 400;
	line-height: 1.86;
}

ul, ol, li {
	list-style: none;
}

a {
	outline: none;
}

button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

a, button {
	text-decoration: none;
	transition: opacity .32s ease, color .25s ease, background-color .25s ease;
	color: #333;
}

a:hover, button:hover {
	opacity: 0.56;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

caption, th, td {
	text-align: left;
	font-weight: normal;
	vertical-align: middle;
}

select {
	color: var(--color-black02);
}

strong {
	font-weight: 700;
}

@media screen and (max-width:769px) {
	html {
		font-size: 10px;
		font-size: clamp(8px, 2.55vw, 25px);
	}

	body {
		font-size: 1.4rem;
	}

	h2 {
		font-size: 2.1rem;
		margin-bottom: 1rem;
	}

	h3 {
		font-size: 2.1rem;
		margin-bottom: 1rem;
	}

	p {
		font-size: 1.4rem;
	}

	img {
		width: 100%;
	}
}


/********************

   common

*********************/
/*****   class   *****/
#body_inner {
	width: 100%;
	margin: 0 auto;
	overflow: hidden;
}

.main_section {
	padding: 7.3rem 0 8.0rem;
}

.contents_wrapper {
	position: relative;
	display: block;
	max-width: 120rem;
	width: 93.2%;
	padding: 0;
	margin-right: auto;
	margin-left: auto;
	z-index: 10;
}

.underline01 {
	--underline_color: rgba(171, 205, 3, 0.44);
	position: relative;
	display: inline;
	font-size: 1.02em;
	background: linear-gradient(transparent 0%, transparent 19%, var(--underline_color) 19%, var(--underline_color) 92%, transparent 92%);
}


@media screen and (min-width:769.02px) {
	.sp_only {
		display: none !important;
	}
}

@media screen and (max-width:769px) {
	#body_inner {
		width: 100%;
		min-width: 0px;
	}

	.pc_only {
		display: none !important;
	}

	.contents_wrapper {
		width: calc(100% - 2.9rem);
		padding: 0;
	}

	.main_section {
		padding: 4rem 0 4.4rem;
	}
}


/********************
   parts
*********************/
.color-green {
	color: var(--color-green01);
	font-weight: 700;
}

.attention_text {
	font-size: 1.3rem;
	letter-spacing: 0.04em;
	line-height: 1.44;
}

.attention_mark {
	position: relative;
	top: -0.39em;
	left: -0.04em;
	font-size: 0.76em;
	letter-spacing: 0.1em;
}


/***   heading_block   ***/
.heading_block {
	--color: var(--color-black01);
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 0 auto 5rem;
	color: var(--color);
	text-align: center;
}

.heading_block[data-color="white"] {
	--color: #fff;
}

.heading_block__sub {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	row-gap: 0.87em;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 0 auto 0.92em;
	color: var(--color-green01);
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.076em;
}

.heading_block__sub::before {
	content: "";
	display: block;
	width: 3.47em;
	height: auto;
	aspect-ratio: 55/18;
	background: var(--color);
	-webkit-mask-image: url(../img/design/heading_block_design.svg);
	mask-image: url(../img/design/heading_block_design.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: contain;
	mask-size: contain;
}

.heading_block[data-color="white"] .heading_block__sub {
	color: inherit;
}

.heading_block__heading {
	display: block;
	color: inherit;
	font-size: 3.28rem;
	line-height: 1.4;
}

@media screen and (max-width:769px) {
	.heading_block {
		margin-bottom: 2.55rem;
	}

	.heading_block__sub {
		margin-bottom: 0.80em;
	}

	.heading_block__heading {
		font-size: 2.28rem;
		letter-spacing: 0;
	}
}


.dots_design {
	position: absolute;
	width: auto;
	height: auto;
	z-index: -1;
	background-color: transparent;
	background-image:
		radial-gradient(#328884 10%, transparent 10%);
	background-size: 1.5rem 1.5rem;
	background-repeat: repeat;
	pointer-events: none;
	z-index: -1;
}

@media screen and (max-width:769px) {
	.dots_design {
		background-size: 0.69rem 0.69rem;
	}
}



/******************   
	animation   
*******************/
/*****   アコーディオン   *****/
.js-acc_switch {
	position: relative;
	cursor: pointer;
}

.js-acc_switch_mark {
	content: "";
	position: absolute;
	top: 50%;
	right: 1.6rem;
	transform: translateY(-50%);
	width: 2em;
	height: auto;
	aspect-ratio: 1/1;
	border-radius: 100%;
	background: #4DC5BF;
}

.js-acc_switch_mark::before,
.js-acc_switch_mark::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-47%);
	margin: auto;
	display: block;
	width: 44%;
	height: 2px;
	background: #fff;
	transition: transform 0.16s linear;
}

.js-acc_switch_mark::before {
	transition: transform 0.32s linear;
}

.js-acc_switch_mark::after {
	transform: translateX(-50%) translateY(-47%) rotate(-90deg);
}

.js-acc_wrapper.active .js-acc_switch_mark::before {
	transform: translateX(-50%) translateY(-47%) rotate(180deg);
}

.js-acc_wrapper.active .js-acc_switch_mark::after {
	transition-delay: 0.16s;
	transform: translateX(-50%) translateY(-47%);
}

.js-acc_block {
	display: none;
}

@media screen and (max-width:769px) {
	.acc_switch::after {
		right: 1.4rem;
	}
}


/***   slider    ***/
.slider {
	display: none;
	opacity: 0;
}

.slider.slick-initialized {
	display: block;
	opacity: 1;
}

.slick-arrow {
	z-index: 10;
}

body .slick-track {
	display: flex;
	align-items: stretch;
}

.slick-track .slick-slide {
	height: auto;
}

.slick-track .slick-slide>div {
	height: 100%;
}

/* arrow */
body .slick-arrow {
	--size: 5rem;
	--position: calc(50% + 60rem);
	position: absolute;
	top: 47%;
	font-size: 0;
	line-height: 0;
	width: var(--size);
	height: calc(var(--size) * (1/1));
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 5000;
}

body .slick-arrow::before {
	display: none;
}

body .slick-arrow.slick-prev {
	left: auto;
	right: var(--position);
	transform: translateX(100%) translateY(-50%) rotate(180deg);
	background-image: url(../img/design/slider_arrow.svg);

}

body .slick-arrow.slick-next {
	right: auto;
	left: var(--position);
	transform: translateX(-100%) translateY(-50%);
	background-image: url(../img/design/slider_arrow.svg);
}


/* swiper */
body .swiper-pagination {
	position: relative;
	margin-top: 2.8rem;
}

body .swiper-pagination-bullet {
	width: 1.4rem;
	height: auto;
	margin: 0 0.55em !important;
	aspect-ratio: 1/1;
}

body .swiper-pagination-bullet-active {
	background: var(--color-green01);
}


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

	/* sp_slider */
	.slider_sp {
		display: none;
		opacity: 0;
	}

	.slider_sp.slick-initialized {
		display: block;
		opacity: 1;
	}

	.slick-dotted.slick-slider.slider_sp {
		position: relative;
		width: 100vw;
		left: 50%;
		transform: translateX(-50%);
	}

	.slider_sp .slick-slide {
		margin: 0 0.55rem;
	}

	/* arrow */
	body .slick-arrow {
		--size: 3.2rem;
		--position: calc(98%);
	}

	/***  dotted  ***/
	.slick-dotted.slick-slider.slider_sp .slick-dots {
		bottom: -0.5rem;
		transform: translateY(100%);
	}

	.slick-dotted.slick-slider.slider_sp .slick-dots li,
	.slick-dotted.slick-slider.slider_sp .slick-dots li button,
	.slick-dotted.slick-slider.slider_sp .slick-dots li button::before {
		--size: 0.5rem;
		width: var(--size);
		height: var(--size);
		padding: 0;
		border-radius: var(--size);
		opacity: 1;
		font-size: 0;
	}

	.slick-dotted.slick-slider.slider_sp .slick-dots li {
		margin: 0 0.32rem;
	}

	.slick-dotted.slick-slider.slider_sp .slick-dots li button::before {
		background: #D9D9D9;
	}

	.slick-dotted.slick-slider.slider_sp .slick-dots li:hover button::before {
		opacity: 0.6;
	}

	.slick-dotted.slick-slider.slider_sp .slick-dots li.slick-active button::before {
		background: var(--color-green);
	}

}


/********************

   header

*********************/
.header {
	position: absolute;
	width: 100%;
	padding-top: 3.2rem;
	color: #fff;
	z-index: 1000;
}

.header__logo {
	text-align: right;
	padding-right: 4.4rem;
	filter: brightness(0) invert(1);
}

.header__logo img {
	width: 30.4rem;
}

@media screen and (min-width:769.02px) {}

@media screen and (max-width:769px) {
	.header {
		padding-top: 1.55rem;
	}

	.header__logo {
		padding: 0.11rem 0 0;
		text-align: center;
	}

	.header__logo img {
		width: 18.2rem;
	}
}

/********************

   footer

*********************/
.footer {
	position: relative;
	width: 100%;
	padding: 3.2rem 0 5.6rem;
	background: var(--color-white);
	text-align: center;
	color: var(--color-black01);
}

.footer__copyright {
	font-size: 1.3rem;
	text-align: center;
}

@media screen and (max-width:769px) {
	.footer {
		padding: 2.2rem 0 5.5rem;
	}

	.home .footer {
		padding-bottom: 9.2rem;
	}
}



/********************

  fixed_block

*********************/
.fixed_contact_observer--fv {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(100% + 4.0rem);
	pointer-events: none;
}

.fixed_contact_observer--contact {
	position: absolute;
	top: 34rem;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}

@media screen and (max-width:769px) {
	.fixed_contact_observer--fv {
		display: none;
	}

	.fixed_contact_observer--contact {
		display: none;
	}
}

.fixed_contact {
	position: fixed;
	bottom: 1rem;
	right: 0;
	font-size: 1.8rem;
	z-index: 1000;
	pointer-events: none;
}

.fixed_contact.active {
	opacity: 1;
	pointer-events: all;
}

.fixed_contact::after {
	content: "";
	position: absolute;
	bottom: calc(100% - 0.87em);
	left: 50%;
	transform: translateX(-50%);
	display: block;
	width: auto;
	height: 2.28em;
	aspect-ratio: 70/34;
	background-image: url(../img/design/arrow02.svg);
	background-repeat: no-repeat;
	background-size: contain;
	opacity: 0;
	transform: translateX(-50%) translateY(-17%);
	transition: opacity 0.4s ease, transform 0.1s 0.4s ease;
	pointer-events: none;
}

.fixed_contact.active::after {
	opacity: 1;
	transform: translateX(-50%);
	transition: opacity 0.5s 0.44s ease, transform 0.44s 0.44s ease;
}

.fixed_contact__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	row-gap: 0.44em;
	box-shadow: 0 0.2em 0.2em rgba(0, 0, 0, 0.15);
	background-image: linear-gradient(360deg, rgba(208, 127, 70, 1.00) 0%, rgba(243, 231, 69, 1.00) 47%, rgba(208, 127, 70, 1.00) 100%);
	background-size: 100% 200%;
	background-position: 0 100%;
	color: #fff;
	width: auto;
	height: auto;
	max-width: 50rem;
	padding: 1.1em 1em 1.02em;
	font-size: 1em;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: 0.01em;
	text-align: center;
	transition: background 0.28s ease, opacity 0.47s ease-in-out, transform 0.50s ease-in-out;
	opacity: 0;
	transform: translateY(40%);
}

.fixed_contact.active .fixed_contact__btn {
	opacity: 1;
	transform: translateX(0);
}

.fixed_contact__btn:hover {
	opacity: 1;
	background-position: 0 -4%;
	-webkit-filter: brightness(1.1);
	filter: brightness(1.1);
}

.fixed_contact__btn::before {
	content: "";
	position: relative;
	display: block;
	width: 2.5em;
	aspect-ratio: 50/35;
	background-image: url(../img/icon/icon-mail.svg);
	background-repeat: no-repeat;
	background-size: contain;
}



/********************

  home

*********************/
body.home {
	margin-top: 0;
}

/********************

   main
   
*********************/
/*******************
	.fv
********************/
.fv {
	position: relative;
	margin-bottom: 0rem;
	height: clamp(62rem, 48.2vw, 92rem);
	z-index: 500;
}

.fv__bg {
	position: relative;
	width: 100%;
	height: 100%;
}

.fv__bg img {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.fv__bg .fv__bg_text {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: auto;
}

.fv__inner {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.fv__contents {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50.4%) translateX(-50%);
	width: 76%;
	max-width: 1500px;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	column-gap: 5.9rem;
	color: #fff;
	text-align: left;
	z-index: 10;
}



.fv__tit {
	position: relative;
	display: block;
	margin: 2.5rem 0 0;
	font-size: 4.7rem;
	max-width: 82rem;
}

.fv__tit_sub {
	position: absolute;
	top: 0;
	left: 0;
	transform: translateX(-47.6%) translateY(-73.2%);
	max-width: 20.4rem;
}

.fv__illust {
	max-width: 26.2rem;
}

.fv__illust figcaption {
	margin-top: 0.4em;
	font-size: 2.62rem;
	font-weight: 700;
	line-height: 1.32;
	text-align: center;
}

.fv__illust figcaption>span:nth-of-type(1) {
	font-size: 0.55em;
}


.fv__btn {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) translateY(50%);
	display: flex;
	align-items: center;
	justify-content: center;
	-moz-column-gap: 0.62em;
	column-gap: 0.62em;
	box-shadow: 0 0.2em 0.2em rgba(0, 0, 0, 0.15);
	background-image: linear-gradient(360deg, rgba(208, 127, 70, 1.00) 0%, rgba(243, 231, 69, 1.00) 50%, rgba(208, 127, 70, 1.00) 100%);
	background-size: 100% 200%;
	background-position: 0 100%;
	color: #fff;
	width: 66rem;
	height: 4.0em;
	max-width: 100%;
	font-size: 2.28rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	border-radius: 1rem;
	transition: 0.32s ease;
}

.fv__btn:hover {
	opacity: 1;
	background-position: 0 -4.7%;
	-webkit-filter: brightness(1.1);
	filter: brightness(1.1);
}

.fv__btn::before {
	content: "";
	position: relative;
	display: block;
	width: 2.34em;
	aspect-ratio: 50/35;
	background-image: url(../img/icon/icon-mail.svg);
	background-repeat: no-repeat;
	background-size: contain;
}


@media screen and (max-width:769px) {
	.fv {
		height: clamp(50rem, 156vw, 100rem);
		height: clamp(50rem, 159vw, 100rem);
	}

	.fv__bg .fv__bg_text {
		position: absolute;
		top: 6.2rem;
		left: 0;
		height: auto;
		width: 117.6%;
		max-width: 200%;
	}


	.fv__contents {
		width: 85.6%;
		max-width: 1500px;
		padding-top: 4.4rem;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		row-gap: 3.2rem;
		color: #fff;
		text-align: left;
		z-index: 10;
	}

	.fv__tit {
		position: relative;
		display: block;
		margin: 0;
		font-size: 4.0rem;
		max-width: 82rem;
	}

	.fv__tit_sub {
		position: absolute;
		top: 0;
		left: 0;
		transform: translateX(-22%) translateY(-76.2%) rotate(1.76deg);
		max-width: 8.2rem;
	}

	.fv__illust {
		max-width: 18.7rem;
		white-space: nowrap;
	}

	.fv__illust figcaption {
		margin-top: -0.11em;
	}


	.fv__btn {
		position: fixed;
		bottom: 0;
		transform: translateX(-50%);
		width: 102%;
		height: 3.4em;
		max-width: 1000%;
		-moz-column-gap: 0.55em;
		column-gap: 0.55em;
		box-shadow: none;
		font-size: 1.55rem;
		border-radius: 0;
		z-index: 1000;
	}

	.fv__btn:hover {}

	.fv__btn::before {
		width: 1.9em;
	}

}

/*******************
	.movie
********************/
.movie {
	position: relative;
	padding: 13rem 0 0;
	z-index: 100;
}

.movie .contents_wrapper {
	max-width: 64rem;
}

.movie .contents_wrapper>div>.dots_design {
	top: -10rem;
	right: -47rem;
	width: 55rem;
	height: 39rem;
	transform: translateY(-56%);
}

.movie video {
	width: 100%;
}

@media screen and (max-width:769px) {
	.movie {
		padding-top: 6.2rem;
	}

	.movie .contents_wrapper>div>.dots_design {
		width: 40rem;
		height: 32rem;
		left: -25rem;
	}
}

/*******************
	.about
********************/
.about {
	padding: 10rem 0 0;
}

.about .contents_wrapper {
	padding-bottom: 10rem;
}


.about .contents_wrapper {
	max-width: 102rem;
}

.about__tit {
	margin-bottom: 1.8em;
	font-size: 2rem;
}

.about__tit::before {
	content: "";
	display: inline-block;
	width: 0.73em;
	height: auto;
	aspect-ratio: 1/1;
	margin-right: 0.76em;
	background: #4DC5BF;
}

@media screen and (max-width:769px) {
	.about {
		padding-top: 5.6rem;
	}

	.about .contents_wrapper {
		padding-bottom: 4rem;
	}

	.about__tit {
		margin-bottom: 1.5em;
		font-size: 1.62rem;
	}

	.about__tit::before {
		margin-right: 0.55em;
	}
}



/* 01 */
.about__block01 {
	display: grid;
	grid-template-columns: 35rem 1fr;
	-moz-column-gap: 10rem;
	column-gap: 10rem;
	margin-bottom: 25rem;
}

.about__block01_img_block .about__small_img {
	position: absolute;
	bottom: 0;
	right: 0;
	transform: translateX(22%) translateY(39%);
	width: 29rem;
}

.about__block01_strong {
	margin-bottom: 1.18em;
	font-size: 2.04rem;
	line-height: 1.54;
	letter-spacing: 0.015em;
}


.about__block01_text_block p {
	font-size: 1.44rem;
	letter-spacing: 0.05em;
}

.about__block01_text_block p+p {
	margin-top: 1.1em;
}

.about__block01_list {
	display: flex;
	align-items: center;
	justify-content: center;
	-moz-column-gap: 1rem;
	column-gap: 1rem;
	margin-top: 3.2rem;
}

.about__block01_list li {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: auto;
	aspect-ratio: 1/1;
	border-radius: 150%;
	background: var(--color-gradient01);
	color: #fff;
	text-align: center;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.7;
}


@media screen and (min-width:769.02px) {
	.about .heading_block {
		margin-left: 0;
		margin-bottom: 2.25rem;
	}

	.about__block01 .dots_design {
		top: -25rem;
		left: -22.8rem;
		width: 54rem;
		height: 44rem;
	}

	.about .heading_block__sub {
		margin-left: 0;
	}

	.about__block01_text_block {
		grid-column: 2/3;
	}

	.about__block01_img_block {
		grid-column: 1/2;
		grid-row: 1/10;
		position: relative;
		top: 7.3rem;
		left: -20rem;
		width: 55rem;
	}
}

@media screen and (max-width:769px) {
	.about .heading_block {
		margin-bottom: 0.34rem;
	}

	.about__block01 {
		display: flex;
		flex-direction: column;
		margin-bottom: 7.3rem;
	}

	.about__block01 .heading_block {
		order: 1;
	}

	.about__block01_strong {
		order: 2;
		font-size: 1.7rem;
		text-align: center;
		margin-bottom: 3.2rem;
	}

	.about__block01_img_block {
		order: 3;
		position: relative;
		left: -3.2%;
		width: 100vw;
		margin-bottom: 5.4rem;
	}

	.about__block01_img_block .about__small_img {
		transform: translateX(-22%) translateY(39%);
		width: 11rem;
	}

	.about__block01_text_block {
		order: 4;
	}

	.about__block01_list {
		order: 5;
		-moz-column-gap: 2rem;
		column-gap: 2rem;
		flex-wrap: wrap;
	}

	.about__block01_list li {
		flex: inherit;
		font-size: 1.25rem;
		line-height: 1.55;
		width: 15rem;
	}
}


/* 02 */
.about__block02 {
	position: relative;
}

.about__block02 .dots_design:nth-of-type(1) {
	bottom: -1rem;
	left: 0;
	width: 32rem;
	height: 37rem;
	transform: translateX(-62%);
}

.about__block02_box {
	position: relative;
	display: flex;
	justify-content: center;
	-moz-column-gap: 2.9rem;
	column-gap: 2.9rem;
	width: 100%;
	padding: 5.5rem 6.2rem 6.2rem;
	margin-bottom: 10rem;
	z-index: 10;
}

.about__block02_box::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 3.0rem;
	border-bottom-left-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
	box-shadow: -0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
	background: #fff;
	z-index: -1;
}

.about__block02_box h4 {
	padding: 0.2em 0.2em 0.25em;
	margin-bottom: 1.32rem;
	background: var(--color-gradient01);
	color: #fff;
	text-align: center;
	width: 100%;
}

.about__block02_box_lead {
	margin-bottom: 1.1em;
	text-decoration: underline;
	font-weight: 500;
}

.about__block02_box figure {
	margin-bottom: 2.2rem;
}

.about__block02_box .attention_text {
	letter-spacing: -0.025em;
	font-size: 1.17rem;
}

@media screen and (min-width:769px) {
	.about__block02 .dots_design:nth-of-type(2) {
		top: -6.2rem;
		right: -20rem;
		width: 59rem;
		height: 25rem;
	}

	.about__block02 .box_design::before {
		content: "";
		position: absolute;
		top: -17rem;
		right: -22rem;
		width: 29rem;
		height: 44rem;
		background: #45B4AE62;
	}

	.about__block02 .box_design::after {
		content: "";
		position: absolute;
		top: -7.6rem;
		right: -22rem;
		width: 50rem;
		height: 3.2rem;
		background: #AFD1E4;
	}

	.about__block02_box>div:first-of-type {
		width: 40rem;
	}

	.about__block02_box>div:nth-of-type(2) {
		flex: 1;
	}

	.about__block02_box>div:nth-of-type(2) figure {
		margin-bottom: 1.7rem;
		margin-left: 1rem;
	}
}

@media screen and (max-width:769px) {
	.about__block02 .dots_design:nth-of-type(1) {
		bottom: -8.2rem;
		transform: translateX(-18%);
	}

	.about__block02_box {
		flex-direction: column;
		padding: 2.8rem 2.0rem 3.47rem;
		row-gap: 2.8rem;
		margin-bottom: 5.5rem;
	}

	.about__block02_box::before {
		width: 125%;
	}

	.about__block02_box h4 {
		padding: 0.44em 0.2em 0.50em;
		margin-bottom: 1.25rem;
		line-height: 1.5;
	}

	.about__block02_box_lead {
		text-align: center;
		line-height: 1.5;
	}

	.about__block02_box figure {
		margin-top: 1.7rem;
		margin-bottom: 1.7rem;
	}
}


/* 03 */
.about__block03 {
	position: relative;
}

.about__block03_inner {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	-moz-column-gap: 11.5rem;
	column-gap: 11.5rem;
	margin-bottom: 7.6rem;
}

.about__block03 .dots_design:nth-of-type(1) {
	top: 96rem;
	left: -15rem;
	width: 87rem;
	height: 44rem;
}

.about__block03 .dots_design:nth-of-type(1)::before {
	content: "";
	position: absolute;
	top: 14rem;
	left: 11rem;
	width: 20rem;
	height: auto;
	aspect-ratio: 200/190;
	background: #AFD1E4;
}

.about__block03 .design {
	position: absolute;
	top: 0;
	right: 0;
	transform: translateX(96%);
	width: 17rem;
}

.about__block03_inner_img_block {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	right: -2.8rem;
}

.about__block03_inner_img_block img {
	width: 31rem;
}

.about__block03_inner_img_block .about__small_img {
	position: absolute;
	width: 15rem;
	bottom: 0;
	left: 0;
	transform: translateX(-55%) translateY(62%);
}

.about__block03_inner_contents {
	flex: 1;
}

.about__block03 .about__tit {
	margin-bottom: 1.7em;
	font-size: 1.8rem;
	letter-spacing: -0.032em;
}

.about__block03_inner_contents dt {
	padding: 0.47em 1.1em 0.50em;
	margin-top: 1.62em;
	margin-bottom: 0.62em;
	background: var(--color-gradient01);
	color: #fff;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.4;
}

.about__block03_inner_contents dd p+p {
	margin-top: 1.3em;
}

.about__block03_inner_contents dd p.attention_text {
	margin-top: 0.5em;
}



.about__block03_box {
	position: relative;
	width: 100%;
	border-radius: 3rem;
	border-bottom-right-radius: 0;
	border-bottom-left-radius: 0;
	overflow: hidden;
}

.about__block03_box::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	box-shadow: -0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
	background: #fff;
	z-index: -1;
}

.about__block03_box h3 {
	padding: 3.0rem 1.1rem 2.5rem 6.2rem;
	background: var(--color-gradient01);
	color: #fff;
}

.about__block03_box_inner {
	position: relative;
	display: flex;
	-moz-column-gap: 5.0rem;
	column-gap: 5.0rem;
	padding: 2.5rem 5.5rem 7.0rem;
}

.about__block03_box_img_block {
	width: 37rem;
	max-width: 100%;
}

.about__block03_box_img_block figcaption {
	margin-top: 0.86em;
	font-size: 0.876em;
	line-height: 1.6;
}

.about__block03_box_contents {
	flex: 1;
}

.about__block03_box_list_item {
	--color: red;
	position: relative;
}

.about__block03_box_list_item p {
	margin-bottom: 0.76em;
	letter-spacing: -0.01em;
}

.about__block03_box_list_item p:last-of-type {
	margin-bottom: 1.5em;
}

.about__block03_box_list_item figure {
	margin-bottom: 3.2rem;
}

.about__block03_box_list_item figcaption {
	margin-bottom: 0.32em;
}

.about__block03_box_list_tit {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	-moz-column-gap: 0.62em;
	column-gap: 0.62em;
	margin-bottom: 0.87em;
	padding: 0.76em 2.8em 0.76em 1em;
	background: var(--color-ivory);
	border-bottom: 0.2rem solid var(--color);
	font-size: 1.55rem;
	font-weight: 500;
}

.about__block03_box_num {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 1.5em;
	height: auto;
	aspect-ratio: 1/1;
	border-radius: 100%;
	background: var(--color);
	color: #fff;
	font-size: 1.34em;
	font-family: var(--font-D-DIN);
	line-height: 1;
}

.about__block03_box_list_tit_mark {
	content: "";
	position: absolute;
	top: 50%;
	right: 1.6rem;
	transform: translateY(-50%);
	width: 2em;
	height: auto;
	aspect-ratio: 1/1;
	border-radius: 100%;
	background: #4DC5BF;
}

.about__block03_box_list_tit_mark::before,
.about__block03_box_list_tit_mark::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-47%);
	margin: auto;
	display: block;
	width: 44%;
	height: 2px;
	background: #fff;
	transition: transform 0.16s linear;
}

.about__block03_box_list_tit_mark::before {
	transition: transform 0.32s linear;
}

.about__block03_box_list_tit_mark::after {
	transform: translateX(-50%) translateY(-47%) rotate(-90deg);
}

.js-acc_wrapper.active .about__block03_box_list_tit_mark::before {
	transform: translateX(-50%) translateY(-47%) rotate(180deg);
}

.js-acc_wrapper.active .about__block03_box_list_tit_mark::after {
	transition-delay: 0.16s;
	transform: translateX(-50%) translateY(-47%);
}


@media screen and (min-width:769px) {
	.about__block03 .dots_design:nth-of-type(2) {
		top: -15rem;
		right: -10rem;
		width: 47rem;
		height: 25rem;
	}

	.about__block03 .dots_design:nth-of-type(3) {
		top: 30rem;
		right: -25rem;
		width: 34rem;
		height: 39rem;
	}

	.about__block03_inner_contents {
		margin-top: 9.6rem;
	}

}

@media screen and (max-width:769px) {
	.about__block03 .dots_design:nth-of-type(1) {
		top: 144rem;
		left: -30rem;
		width: 62rem;
		height: 32rem;
	}

	.about__block03 .dots_design:nth-of-type(1)::before,
	.about__block03 .design {
		display: none;
	}


	.about__block03_inner {
		flex-direction: column-reverse;
		margin-bottom: 4.4rem;
	}

	.about__block03_inner_img_block {
		position: relative;
		right: -2.8rem;
		margin-left: auto;
		margin-right: 0;
		margin-bottom: 6.2rem;
	}

	.about__block03_inner_img_block img {
		width: 25rem;
	}

	.about__block03_inner_img_block .about__small_img {
		width: 11rem;
		transform: translateX(-100%) translateY(28%);
	}

	.about__block03 .about__tit {
		margin-bottom: 0.25em;
		padding-left: 0.82em;
		text-indent: -0.82em;
		font-size: 1.66rem;
	}


	.about__block03_box {
		position: relative;
		width: 110%;
		border-radius: 1.5rem;
		border-top-right-radius: 0;
		overflow: hidden;
	}

	.about__block03_box::before {}

	.about__block03_box h3 {
		padding: 1.1em 2.5rem 1.15em 2em;
		background: var(--color-gradient01);
		color: #fff;
		font-size: 1.5rem;
	}

	.about__block03_box_inner {
		flex-direction: column;
		row-gap: 2.8rem;
		padding: 1.4rem 4.4rem 5.0rem 2.5rem;
	}

	.about__block03_box_list_item p {
		margin-bottom: 0.5em;
		font-size: 0.92em;
	}

	.about__block03_box_list_item p:last-of-type {
		margin-bottom: 1.3em;
	}

	.about__block03_box_list_item figure {
		margin-bottom: 3.0rem;
	}

	.about__block03_box_list_item figcaption {
		margin-bottom: 0.32em;
		font-size: 0.92em;
		letter-spacing: -0.034em;
	}

	.about__block03_box_list_tit {
		-moz-column-gap: 0.62em;
		column-gap: 0.62em;
		margin-bottom: 0.76em;
		padding: 0.55em 2.8em 0.69em 1em;
		font-size: 1.32rem;
		line-height: 1.4;
		letter-spacing: -0.05em;
	}

	.about__block03_box_num {
		position: relative;
		top: 0.1em;
		font-size: 1.15em;
	}

	.about__block03_box_list_tit_mark {
		right: 1.0rem;
		width: 1.8em;
		height: auto;
	}
}


/*******************
	.problem
********************/
.problem {
	position: relative;
	padding: 0;
}

.problem .contents_wrapper {
	position: relative;
	width: 100%;
	max-width: 144rem;
	color: #fff;
}

.problem__contents {
	position: absolute;
	top: 12.5%;
	left: 14%;
}

.problem__contents {}

.problem__contents_list {
	position: relative;
	left: 1.8em;
}

.problem__contents_list li {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin-bottom: 1.8em;
	font-size: 1em;
	font-weight: 500;
	line-height: 1.76;
}

.problem__contents_list li::before,
.problem__contents_list li::after {
	position: absolute;
	font-size: 2.25em;
	font-weight: 300;
	line-height: 1;
}

.problem__contents_list li::before {
	content: "「";
	top: 0;
	left: 0;
	transform: translateX(-132%) translateY(-30%);
}

.problem__contents_list li::after {
	content: "」";
	bottom: 0;
	right: 0;
	transform: translateX(125%) translateY(22%);
}


.problem__last {
	position: absolute;
	bottom: 7.62%;
	left: 0;
	right: 0;
	margin: auto;
}

.problem__last_text {
	font-size: 2.44rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.44;
}

.problem__last_text[data-text="01"] {
	position: relative;
	font-size: 3.9rem;
	line-height: 1.5;
	letter-spacing: -0.015em;
	margin-bottom: 13.9rem;
}

.problem__last_text[data-text="01"] {
	content: "";
	position: absolute;
	top: calc(100% + 3.9rem);
	left: 50%;
	transform: translateX(-50%);
	aspect-ratio: 220/69;
	width: 21.5rem;
	height: auto;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	background-image: linear-gradient(180deg, rgba(255, 251, 41, 0.00) 0%, rgba(255, 251, 41, 1.00) 73%);
	background-position: top center;
}

.problem__last_text[data-text="02"] {
	margin-bottom: 0.39em;
}

.problem__last_text_strong {
	text-decoration: underline;
}

.problem__last .problem__last_strong {
	position: relative;
	margin-top: 0.17em;
	font-size: 3.9rem;
	font-weight: 700;
	text-align: center;
}

.problem__last .problem__last_strong::before,
.problem__last .problem__last_strong::after {
	content: "｜";
	position: relative;
	top: 0.1em;
	display: inline-block;
	font-size: 1.25em;
	font-weight: 700;
	line-height: 1.25;
}

.problem__last .problem__last_strong::before {
	left: 0.55em;
	transform: rotate(-35deg);
}

.problem__last .problem__last_strong::after {
	right: 0.32em;
	transform: rotate(35deg);
}

.problem__last .problem__last_strong span {
	font-weight: 400;
}

@media screen and (min-width:769px) {
	.problem__contents .heading_block {
		margin-left: 0;
		text-align: left;
	}

	.problem__contents .heading_block__sub {
		margin-left: 0;
	}
}

@media screen and (max-width:769px) {
	.problem__contents {
		top: 9.39%;
		left: 50%;
		transform: translateX(-50%);
		width: 100%;
	}

	.problem__contents .heading_block {
		margin-bottom: 3.4rem;
	}

	.problem__contents_list {
		text-align: center;
	}

	.problem__contents_list {
		left: 0;
	}

	.problem__contents_list li {
		position: relative;
		width: 80%;
		margin-left: auto;
		margin-right: auto;
		line-height: 1.62;
	}

	.problem__contents_list li::before,
	.problem__contents_list li::after {
		font-size: 2.44em;
	}

	.problem__contents_list li::before {
		transform: translateX(-100%) translateY(-30%);
	}

	.problem__contents_list li::after {
		transform: translateX(96%) translateY(34%);
	}

	.problem__last {
		bottom: 5.0%;
	}

	.problem__last_text {
		font-size: 1.4rem;
	}

	.problem__last_text[data-text="01"] {
		font-size: 1.9rem;
		letter-spacing: -0.018em;
		margin-bottom: 5.0rem;
	}

	.problem__last_text[data-text="01"]::after {
		top: calc(100% + 2.0rem);
		width: 9.6rem;
	}

	.problem__last_text[data-text="01"]>span:nth-of-type(2) {
		font-size: 2.69rem;
		display: block;
		line-height: 1.4;
		margin-top: 0.14em;
	}

	.problem__last_text[data-text="02"] {
		margin-bottom: 0.17em;
	}

	.problem__last .problem__last_strong {
		font-size: 2.28rem;
		margin-top: 0.1em;
		line-height: 1.1;
		white-space: nowrap;
	}
}


/*******************
	.web_media
********************/
.web_media__heading {
	margin-bottom: 2.5rem;
	font-size: 3.6rem;
	text-align: left;
}

.web_media__text {
	max-width: 59.6rem;
	margin-bottom: -2rem;
	line-height: 2.1;
	letter-spacing: 0.02em;
}

.web_media__block_item {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-direction: row;
}

.web_media__block_img_block {
	position: relative;
	z-index: 10;
}

.web_media__block_text_block {
	color: var(--color-white);
}

.web_media__block_text_block::after {
	content: "";
	position: absolute;
	width: 10rem;
	height: 10rem;
	background: linear-gradient(45deg, rgba(128, 128, 128, 1) 0%, rgba(51, 51, 51, 1) 99.44%);
	mix-blend-mode: multiply;
	z-index: 5;
}

.web_media__block_item:nth-of-type(2n) .web_media__block_text_block::after {
	background: linear-gradient(45deg, rgba(30, 156, 215, 1) 0%, rgba(0, 91, 151, 1) 99.44%);
}

.web_media__block_name {
	margin-bottom: 1.8rem;
	font-size: 2.5rem;
	text-align: center;
}

.web_media__block_name a {
	color: inherit;
	text-decoration: underline;
}

.web_media__block_name a:hover {
	opacity: 0.88;
	text-decoration: none;
}

.web_media__block_text {
	font-size: 1.6rem;
	line-height: 1.8;
}

.web_media {}



@media screen and (min-width:769.02px) {
	.web_media__block_item:nth-of-type(2n) {
		flex-direction: row-reverse;
	}

	.web_media__block_item:nth-of-type(n+2) {
		margin-top: -10rem;
	}

	.web_media__block_img_block {
		position: relative;
		z-index: 10;
	}

	.web_media__block_text_block {
		position: relative;
		width: 66rem;
		padding: 2.8rem 5rem 3.2rem;
		background: linear-gradient(-40deg, rgba(30, 156, 215, 1) 0%, rgba(0, 91, 151, 1) 99.44%);
	}

	.web_media__block_item:first-of-type .web_media__block_text_block {
		top: -1.7rem;
	}

	.web_media__block_item:nth-of-type(2n) .web_media__block_text_block {
		background: linear-gradient(-40deg, rgba(128, 128, 128, 1) 0%, rgba(51, 51, 51, 1) 99.44%);
	}

	.web_media__block_item:nth-of-type(2n+1) .web_media__block_text_block::after {
		bottom: 0;
		right: 0;
		transform: translateX(22%) translateY(77%);
	}

	.web_media__block_item:nth-of-type(2n) .web_media__block_text_block::after {
		bottom: 0;
		left: 0;
		transform: translateX(-22%) translateY(77%);
	}
}

@media screen and (max-width:769px) {
	.web_media {
		padding-bottom: 2rem;
	}

	.web_media__heading {
		padding: 0 3.0rem;
		margin-bottom: 1.1rem;
		font-size: 2rem;
		text-align: left;
	}

	.web_media__text {
		margin-bottom: 2.6rem;
		padding: 0 3.0rem;
		line-height: 1.7;
	}

	.web_media .contents_wrapper {
		width: 100%;
	}

	.web_media__block_item {
		position: relative;
		flex-direction: column-reverse;
		padding: 3.0rem 3.2rem 3.2rem;
		background: linear-gradient(-45deg, rgba(30, 156, 215, 1) 0%, rgba(0, 91, 151, 1) 99.44%);
	}

	.web_media__block_item:nth-of-type(2n) {
		background: linear-gradient(-45deg, rgba(128, 128, 128, 1) 0%, rgba(51, 51, 51, 1) 99.44%);
	}

	.web_media__block_item:nth-of-type(2n+1) .web_media__block_text_block::after {
		top: 0;
		left: 0;
	}

	.web_media__block_item:nth-of-type(2n) .web_media__block_text_block::after {
		top: 0;
		right: 0;
	}

	.web_media__block_name {
		font-size: 1.6rem;
		margin-bottom: 1.4rem;
		line-height: 1.4;
	}

	.web_media__block_text {
		font-size: 1.47rem;
	}

	.web_media__block_img_block {
		width: 100%;
		max-width: 450px;
		margin-bottom: 2.28rem;
	}
}




/*******************
	.merits
********************/
.merits__heading {
	margin-bottom: 6.2rem;
}

.merits__block_item {
	display: flex;
	align-items: center;
	justify-content: flex-start;
}

.merits__block_img_block {
	position: relative;
}

.merits__block_text_block {
	position: relative;
	padding: 2rem 6.2rem 3.9rem;
	color: var(--color-white);
	z-index: 10;
}

.merits__block_heading_block {
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	-moz-column-gap: 2.44rem;
	column-gap: 2.44rem;
	margin-top: 2.5rem;
	margin-bottom: 2rem;
}

.merits__block_number {
	position: relative;
	font-size: 2rem;
	font-weight: 700;
}

.merits__block_number::after {
	content: "";
	position: absolute;
	width: 20rem;
	height: 1px;
	background: var(--color-white);
	bottom: 0;
	left: 0;
	transform-origin: left bottom;
	transform: rotate(-45deg);
}

.merits__block_heading {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	line-height: 1.18;
	padding: 0.7em 0;
	font-size: 4.8rem;
}

.merits__block_tit {
	margin-bottom: 0.66em;
	font-size: 2.6rem;
	font-weight: 500;
	line-height: 1.55;
}

.merits__block_text {
	font-size: 1.8rem;
	line-height: 1.96;
}



@media screen and (min-width:769.02px) {
	.merits {
		padding-top: 7rem;
	}

	.merits__block_item:nth-of-type(2n) {
		flex-direction: row-reverse;
	}

	.merits__block_item:nth-of-type(n+2) {
		margin-top: 5.6rem;
	}

	.merits__block_text_block {
		width: 50%;
	}

	.merits__block_text_block::after {
		content: "";
		position: absolute;
		top: 0;
		right: 0;
		width: 50vw;
		min-width: 70rem;
		height: 100%;
		background: linear-gradient(-45deg, rgba(128, 128, 128, 1) 0%, rgba(51, 51, 51, 1) 99.44%);
		z-index: -1;
	}

	.merits__block_item:nth-of-type(2n) .merits__block_text_block::after {
		left: 0;
	}

	.merits__block_img_block {
		transform: translateX(-10%);
	}

	.merits__block_item:nth-of-type(2n) .merits__block_img_block {
		transform: translateX(10%);
	}
}

@media screen and (max-width:769px) {
	.merits {
		padding-top: 3.4rem;
	}

	.merits__heading {
		margin-bottom: 4.1rem;
	}

	.merits__block_item {
		position: relative;
		flex-direction: column;
	}

	.merits__block_item:nth-of-type(n+2) {
		margin-top: 3.8rem;
	}

	.merits__block_img_block {
		position: static;
	}

	.merits__block_img_block img {
		position: absolute;
		width: 24.4rem;
		z-index: -5;
	}

	.merits__block_item:nth-of-type(2n+1) .merits__block_img_block img {
		right: -6.6rem;
	}

	.merits__block_item:nth-of-type(2n) .merits__block_img_block img {
		left: -6.6rem;
	}

	.merits__block_item:nth-of-type(1) .merits__block_img_block img {
		top: -3rem;
	}

	.merits__block_item:nth-of-type(2) .merits__block_img_block img {
		top: -7rem;
	}

	.merits__block_item:nth-of-type(3) .merits__block_img_block img {
		top: -13rem;
	}

	.merits__block_item:nth-of-type(4) .merits__block_img_block img {
		top: -17.3rem;
	}

	.merits__block_item:nth-of-type(5) .merits__block_img_block img {
		top: -20rem;
	}

	.merits__block_text_block {
		position: relative;
		padding: 2rem 2rem 2.5rem;
		z-index: inherit;
	}

	.merits__block_text_block::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: var(--color-black);
		mix-blend-mode: multiply;
		z-index: -1;
	}

	.merits__block_heading_block {
		justify-content: center;
		-moz-column-gap: 3.4rem;
		column-gap: 3.4rem;
		margin-top: 1rem;
		margin-bottom: 2.5rem;
	}

	.merits__block_number {
		position: relative;
		top: 0.15rem;
		font-size: 1.4rem;
		font-weight: 500;
	}

	.merits__block_number::after {
		width: 3.8rem;
		bottom: auto;
		top: 2.55rem;
		left: calc(100% + 0.4rem);
		transform: rotate(-45deg) translateY(-50%);
	}

	.merits__block_heading {
		margin-bottom: 0;
		line-height: 1.1;
		padding: 0;
		font-size: 2.2rem;
		font-weight: 500;
	}

	.merits__block_tit {
		font-size: 1.6rem;
		text-align: center;
	}

	.merits__block_text {
		font-size: 1.4rem;
		line-height: 1.8;
	}
}



/*******************
	.service
********************/
.service {
	position: relative;
	background: #fff;
}

.service .contents_wrapper>div .dots_design:nth-of-type(1) {
	top: 100rem;
	left: -18rem;
	width: 37rem;
	height: 34rem;
}

.service .contents_wrapper>div .dots_design:nth-of-type(2) {
	top: 170rem;
	right: -44rem;
	width: 37rem;
	height: 19rem;
}

.service__bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	max-height: 130rem;
	-o-object-fit: cover;
	object-fit: cover;
}

.service .contents_wrapper {
	max-width: 98rem;
}

.service__heading {
	margin-bottom: 2.0rem;
}

.service__heading_logo {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	-moz-column-gap: 0.32em;
	column-gap: 0.32em;
	font-size: 2rem;
	margin-bottom: 1.18em;
}

.service__em_logo {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	max-width: 15rem;
	margin: 0 auto 3.0rem;
}

.service__text {
	text-align: center;
	font-weight: 500;
}



.service__box_wrapper {
	position: relative;
}

.service__box_wrapper::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%) translateY(-54%);
	width: 15rem;
	height: auto;
	aspect-ratio: 139/76;
	background-image: url(../img/text/text-check.svg);
	background-repeat: no-repeat;
	background-size: contain;
	z-index: 10;
}

.service__box {
	position: relative;
	margin: 7.6rem auto;
	border-radius: 3rem;
	border-bottom-right-radius: 0 !important;
	border-bottom-left-radius: 0 !important;
	overflow: hidden;
	background: #fff;
	box-shadow: 0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
}

.service__box_inner {
	padding: 3.4rem 5.0rem 6.6rem;
}

.service__box_tit {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 14.5rem;
	padding: 1.6em 0.2em 1.3em;
	background: var(--color-gradient01);
	color: #fff;
	text-align: center;
	font-size: 2.44rem;
}

.service__box_tit>span {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	display: block;
}



.service__block {
	width: 100%;
	margin: 11rem auto 5rem;
}

.service__block_tit {
	padding: 0.32em 1em 0.44em;
	margin-bottom: 1.25em;
	background: var(--color-gradient01);
	color: #fff;
	text-align: center;
	font-size: 2.44rem;
}

.service__block img {
	width: 100%;
}

.service__block .attention_text {
	margin-top: 1.1em;
	font-size: 1.4rem;
}

@media screen and (min-width:769.02px) {
	.service__box_tit>span::before {
		content: "";
		position: absolute;
		left: 0;
		top: 50%;
		transform: translateX(-118%) translateY(-50%);
		width: 7.6rem;
		height: auto;
		aspect-ratio: 72/70;
		background-image: url(../img/icon/icon-tit_check.svg);
		background-repeat: no-repeat;
		background-size: contain;
	}

	.service__box_inner {
		display: grid;
		-moz-column-gap: 5rem;
		column-gap: 5rem;
	}

	.service__box_text {
		grid-column: 1/2;
		text-indent: -1.44em;
		padding-left: 1.44em;
		letter-spacing: 0.028em;
		margin-bottom: 1.55em;
	}

	.service__box_text::before {
		position: relative;
		top: 0.04em;
		content: "";
		display: inline-block;
		width: 0.87em;
		height: auto;
		aspect-ratio: 1/1;
		background: var(--color-green01);
		margin-right: 0.55em;
	}

	.service__box_inner_img_block {
		grid-column: 2/3;
		grid-row: 1/10;
		width: 32.8rem;
	}

	.service__box_wrapper[data-type="02"] .service__box_text {
		grid-column: 2/3;
	}

	.service__box_wrapper[data-type="02"] .service__box_inner_img_block {
		grid-column: 1/2;
	}

	.service__box_text_sub {
		display: inline-block;
		margin-top: 0.55em;
		margin-left: 1.3em;
	}
}

@media screen and (max-width:769px) {
	.service__text {
		text-align: left;
	}

	.service__box_wrapper::before {
		width: 10.6rem;
	}

	.service__box {
		border-radius: 1rem;
		margin: 5rem auto;
	}

	.service__box_inner {
		padding: 2.2rem 2.2rem 2.5rem;
	}

	.service__box_tit {
		min-height: 10rem;
		padding: 1.9em 0.2em 1.7em;
		font-size: 1.62rem;
		letter-spacing: -0.025em;
	}

	.service__box_text {
		margin-bottom: 1.82em;
	}

	.service__box_inner_img_block {
		margin-bottom: 2.5rem;
	}

	.service__box_text_sub {
		display: inline-block;
		margin-top: 0.44em;
	}


	.service__block {
		width: 100%;
		margin: 4.4rem auto 4.0rem;
	}

	.service__block_tit {
		margin-bottom: 1.15em;
		font-size: 1.7rem;
	}

	.service__block .attention_text {
		text-align: right;
		margin-top: 0.87em;
	}
}


/*******************
	.support
********************/
.support {}

.support .contents_wrapper {
	max-width: 98rem;
}

.support .contents_wrapper>div>.dots_design:nth-of-type(1) {
	top: 100rem;
	right: -25rem;
	width: 59rem;
	height: 32rem;
}

.support .contents_wrapper>div>.dots_design:nth-of-type(2) {
	bottom: 25rem;
	left: -22rem;
	width: 59rem;
	height: 32rem;
}

.support__num {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	font-size: 15rem;
	margin-bottom: 1rem;
}

.support__num>img {
	position: relative;
	z-index: 10;
	top: 0.076em;
	width: 0.96em;
}

.support__num>span {
	position: relative;
	left: -0.22em;
	background: var(--color-gradient01);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	font-family: var(--font-D-DIN);
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1;
}

.support__lead_block {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	-moz-column-gap: 8.7rem;
	column-gap: 8.7rem;
	margin-bottom: 5rem;
}

.support__tit {
	margin-bottom: 1.8rem;
}

.support__lead_block_img_block::before,
.support__lead_block_img_block::after {
	content: "";
	position: absolute;
	display: block;
	z-index: -1;
}

.support__lead_block_img_block::before {
	top: 0;
	left: 0;
	transform: translateX(-44%) translateY(-32%);
	width: 26rem;
	height: 20rem;
	background: var(--color-gradient01);
}

.support__lead_block_img_block::after {
	bottom: 0;
	right: 0;
	transform: translateX(25%) translateY(40%);
	width: 11rem;
	height: 15rem;
	background: #A4DFDA77;
}

.support__block02 .support__lead_block_img_block::before {
	top: 0;
	left: auto;
	right: 0;
	transform: translateX(110%) translateY(-30%);
	width: 14rem;
	height: 20rem;
}

.support__block02 .support__lead_block_img_block::after {
	bottom: 0;
	left: 0;
	right: auto;
	transform: translateX(-11%) translateY(25%);
	width: 37rem;
	height: 20rem;
}

.support__lead_block_contents {
	flex: 1;
}

/* 01 */
.support__block01 {
	margin-bottom: 15rem;
}

.support__block01_list_num {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin-bottom: 0.11em;
	color: #4DC5BFaa;
	font-size: 8.0rem;
	font-family: var(--font-D-DIN);
	line-height: 1;
}

.support__block01_list_num>img {
	width: 0.76em;
}

.support__block01_list_flow {
	margin-bottom: 0.82rem;
}

.support__block01_list_flow li {
	position: relative;
	width: 100%;
	padding: 0.2em 0.2em 0.25em;
	background: #3FAFCF;
	color: #fff;
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 1.25;
	text-align: center;
	z-index: 10;
}

.support__block01_list_flow li:first-of-type {
	background: #C5594D;
}

.support__block01_list_flow li:nth-of-type(n+2) {
	margin-top: 3.4rem;
}

.support__block01_list_flow li:nth-of-type(n+2)::before {
	content: "";
	position: absolute;
	top: -3.4rem;
	left: 50%;
	transform: translateX(-50%);
	width: auto;
	height: 3.4rem;
	aspect-ratio: 34/47;
	background-image: url(../img/design/arrow01.svg);
	background-repeat: no-repeat;
	background-size: contain;
	z-index: -1;
}

.support__block01_list_flow .support__block01_list_flow_end {
	background: #B7B7B7;
}

.support__block01_list_text {
	line-height: 1.56;
}


/* 2 */
.support__block02_list_wrapper {
	margin-bottom: 7.6rem;
}

.support__block02_list_item {
	background: #fff;
	border-radius: 2.0rem;
	border-bottom-right-radius: 0 !important;
	border-bottom-left-radius: 0 !important;
	overflow: hidden;
}

.support__block02_list_item>picture img {
	width: 100%;
	height: 28rem;
	-o-object-fit: cover;
	object-fit: cover;
}

.support__block02_list_tit {
	padding: 0.45em 0.2em 0.54em;
	background: #4DC5BF;
	color: #fff;
	font-size: 2.0rem;
	text-align: center;
	line-height: 1.4;
}

.support__block02_list_text {
	padding: 0.87em 1em 1.1em;
	font-size: 1.5rem;
	line-height: 1.8;
}


.support__block02_box {
	position: relative;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	-moz-column-gap: 3.2rem;
	column-gap: 3.2rem;
	margin: 4rem auto;
	max-width: 100%;
	padding: 4rem 4.4rem 4.7rem;
	color: #fff;
	border-radius: 3.0rem;
	border-bottom-left-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
}

.support__block02_box_logo {
	width: 18rem;
}

.support__block02_box_contents {
	flex: 1;
}

.support__block02_box_tit {
	margin-bottom: 0.47em;
	text-align: left;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.6;
}

.support__block02_box_text {
	font-size: 0.969em;
	letter-spacing: -0.013em;
}


@media screen and (min-width:769.02px) {

	.support__block02 .support__lead_block {
		flex-direction: row-reverse;
		-moz-column-gap: 10.6rem;
		column-gap: 10.6rem;
	}

	.support__lead_block_contents {
		margin-top: 3.9rem;
	}

	.support__lead_block_img_block {
		position: relative;
		width: 40rem;
	}

	.support__lead_block_img_block img {
		position: relative;
		max-width: 1000%;
		width: 47rem;
		left: -7rem;
	}

	.support__block02 .support__lead_block_img_block {
		width: 47rem;
	}

	.support__block02 .support__lead_block_img_block img {
		left: auto;
		width: 56rem;
	}


	/* 1 */
	.support__block01_list {
		display: grid !important;
		grid-template-columns: repeat(3, 1fr);
		-moz-column-gap: 4.5rem;
		column-gap: 4.5rem;
		padding: 4.5rem 6.2rem 6.2rem;
		background: #fff;
		box-shadow: 0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
		border-radius: 3.0rem;
		border-bottom-left-radius: 0;
		border-bottom-right-radius: 0;
		box-sizing: border-box !important;
	}

	.support__block01_list_flow {
		min-height: 17rem;
	}

	.support__block01_list_item:nth-of-type(1) .support__block01_list_flow li:first-of-type,
	.support__block01_list_item:nth-of-type(3) .support__block01_list_flow li:first-of-type {
		color: #C5594D;
	}

	.support__block01_list_item:nth-of-type(1) .support__block01_list_flow li:first-of-type {
		width: 250%;
	}

	/* 2 */
	.support__block02_list {
		display: grid !important;
		grid-template-columns: repeat(4, 1fr);
		-moz-column-gap: 1.4rem;
		column-gap: 1.4rem;
	}
}

@media screen and (max-width:769px) {
	.support .contents_wrapper>div>.dots_design:nth-of-type(1) {
		display: none;
	}

	.support__heading {
		margin-bottom: 4.4rem;
	}

	.support__num {
		margin-top: -3.28rem;
		font-size: 10rem;
	}

	.support__block02, .support__num {
		justify-content: flex-end;
		margin-left: auto;
		margin-right: 0;
	}

	.support__tit {
		margin-bottom: 1.1rem;
		font-size: 1.6rem;
		letter-spacing: -0.01em;
	}

	.support__lead_block {
		flex-direction: column;
		margin-bottom: 2.2rem;
	}

	.support__lead_block_img_block {
		position: relative;
		width: 104%;
	}

	.support__block02 .support__lead_block_img_block {
		position: relative;
		left: -4%;
	}

	.support__lead_block_img_block::before {
		transform: translateX(-10%) translateY(-22%);
		width: 19rem;
		height: 11rem;
	}

	.support__lead_block_img_block::after {
		transform: translateX(19%) translateY(62%);
		width: 8.2rem;
		height: 11rem;
	}

	.support__block02 .support__lead_block_img_block::before {
		transform: translateX(47%) translateY(-25%) rotate(180deg);
		width: 10rem;
		height: 15rem;
	}

	.support__block02 .support__lead_block_img_block::after {
		bottom: 0;
		left: 0;
		right: auto;
		transform: translateX(-47%) translateY(20%);
		width: 25rem;
		height: 15rem;
	}

	.support__lead_block_img_block::before {}

	/* 1 */
	.support__block01 {
		margin-bottom: 5rem;
	}

	body .support__block01_list_item {
		height: auto;
		padding: 2.8rem 3.2rem 3.2rem;
		background: #fff;
		box-shadow: 0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
	}

	.support__block01_list_flow {
		margin-bottom: 1.5rem;
	}

	.support__block01_list_text {
		line-height: 1.62;
	}


	/* 2 */
	.support__block02_box {
		align-items: center;
		justify-content: center;
		flex-direction: column;
		row-gap: 2.2rem;
		padding: 4.4rem 3.47rem 4.7rem;
		border-radius: 1.5rem;
	}

	.support__block02_box_logo {
		width: 15rem;
	}

	.support__block02_box_contents {
		flex: 1;
	}

	.support__block02_box_tit {
		font-size: 1.6rem;
		text-align: center;
	}

	.support__block02_box_text {
		font-size: 0.96em;
		letter-spacing: -0.01em;
	}

	body .support__block02_list_item {
		height: auto;
		background: #fff;
		box-shadow: 0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
	}

	.support__block02_list_item>picture img {
		height: 15.5rem;
	}

}


/*******************
	.comparison
********************/
.comparison {
	position: relative;
	padding: 16rem 0 26rem;
	max-width: 200rem;
	margin: 0 auto;
	border-radius: 3.0rem;
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
	overflow: hidden;
}

.comparison__bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, rgba(124, 129, 212, 1.00) 0%, rgba(80, 200, 209, 1.00) 100%);
	-webkit-mask-image: url(../img/design/comparison__bg_path.svg);
	mask-image: url(../img/design/comparison__bg_path.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: cover;
	mask-size: cover;
	-webkit-mask-position: bottom;
	mask-position: bottom;
}

.comparison__bg::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	aspect-ratio: 1440/1136;
	background-image: url(../img/design/comparison__bg_img.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: bottom;
}

.comparison__heading {
	margin-bottom: 3.28rem;
}

.comparison .contents_wrapper {
	max-width: 100rem;
}

.comparison__table_wrapper {
	width: 100%;
	margin: 0 auto;
}

.comparison__table {
	width: 100%;
	margin: 0 auto;
	border-collapse: separate;
	border-spacing: 0.5rem;
}

.comparison__table thead th,
.comparison__table thead td {
	padding: 0.62em 0;
	background: var(--color-gray01);
	color: #fff;
	font-size: 2.0rem;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
}

.comparison__table thead th:nth-of-type(1) {
	background: var(--color-green01);
	font-size: 1.87rem;
}

.comparison__table tbody th,
.comparison__table tbody td {
	padding: 0.92em 0.2em 0.96em;
	background: #fff;
	font-size: 1.4rem;
	line-height: 1.4;
	text-align: center;
}

.comparison__table tbody th {
	font-size: 1.5rem;
	line-height: 1.3;
}

.comparison__table_mark {
	--color: #000;
	display: block;
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1.25;
	margin-bottom: 0.15em;
}

.comparison__table_mark:last-child {
	margin-bottom: 0;
}

.comparison__table tbody p {
	font-size: 1em;
	line-height: 1.25;
}

.comparison__table_mark>span {
	position: absolute;
	visibility: hidden;
}

.comparison__table strong {
	font-weight: inherit;
}

.comparison__table strong .comparison__table_mark {
	--color: var(--color-green01);
	color: var(--color);
}

.comparison__table_mark::after {
	content: "";
	position: relative;
	display: block;
	width: 2.8rem;
	height: auto;
	aspect-ratio: 1/1;
	margin: 0 auto;
	background: var(--color);
	-webkit-mask-image: url(../img/icon/icon-circle_mark.svg);
	mask-image: url(../img/icon/icon-circle_mark.svg);
	-webkit-mask-size: contain;
	mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	background-position: center center;
}

.comparison__table_mark--double_circle::after {
	-webkit-mask-image: url(../img/icon/icon-double_circle_mark.svg);
	mask-image: url(../img/icon/icon-double_circle_mark.svg);
}

.comparison__table_mark--circle::after {
	-webkit-mask-image: url(../img/icon/icon-circle_mark.svg);
	mask-image: url(../img/icon/icon-circle_mark.svg);
}

.comparison__table_mark--triangle::after {
	-webkit-mask-image: url(../img/icon/icon-triangle_mark.svg);
	mask-image: url(../img/icon/icon-triangle_mark.svg);
}

.comparison__table_mark--cross::after {
	-webkit-mask-image: url(../img/icon/icon-cross_mark.svg);
	mask-image: url(../img/icon/icon-cross_mark.svg);
}

.comparison .attention_text {
	margin-top: 0.5em;
	color: #fff;
}

@media screen and (max-width:769px) {
	.comparison {
		padding: 6.9rem 0 19rem;
		margin-bottom: -7.6rem;
	}

	.comparison__heading {
		margin-bottom: 2.8rem;
	}

	.comparison__heading .heading_block__heading {
		font-size: 2.2rem;
	}

	.comparison__bg {
		background: linear-gradient(90deg, #7C82D4 0%, #6C9CD3 100%);
		-webkit-mask-position: 15% 10%;
		mask-position: 15% 10%;
	}

	.comparison__table_outer {
		width: 106%;
		padding-right: 2.5rem;
		overflow-x: auto;
		padding-bottom: 0.5rem;
	}

	.comparison__table_outer::-webkit-scrollbar {
		height: 0.87rem;
		background-color: #fff;
	}

	.comparison__table_outer::-webkit-scrollbar-thumb {
		background-color: #FCD473;
	}

	.comparison__table_outer .comparison__table {
		position: relative;
		left: -0.4rem;
		min-width: 82rem;
	}

	.comparison__table thead th:nth-of-type(1) {
		font-size: 1.7rem;
	}

	.comparison__table thead th, .comparison__table thead td {
		font-size: 1.8rem;
	}

	.comparison__table tbody th,
	.comparison__table tbody td {
		font-size: 1.3rem;
	}

	.comparison .attention_text {
		margin-top: 1.55em;
	}
}



/*******************
	.voice
********************/
.voice {
	position: relative;
}

.voice .contents_wrapper {
	max-width: 110rem;
}

.voice .contents_wrapper>div .dots_design:nth-of-type(1) {
	top: 22rem;
	left: -22rem;
	width: 28rem;
	height: 28rem;
}

.voice__heading {
	margin-bottom: 2.5rem;
}

.voice__wrapper {
	position: relative;
}

.voice__block {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}

.voice__block_inner {}

.voice__block_contents {
	padding: 2.5rem 2.2rem 0;
}

.voice__block_img_box {
	margin: 0 auto 0.2rem;
}

.voice__block_img_box img {
	width: 100%;
}

.voice__block_tit {
	margin: 0 auto 1.5rem;
	color: var(--color-green01);
	font-size: 2rem;
	text-align: center;
	line-height: 1.47;
}

.voice__block_text {
	font-size: 1.5rem;
	letter-spacing: 0.05em;
}

.voice__block_name {
	font-weight: 500;
}

.js-voice__switch {
	display: none;
}

@media screen and (min-width:769px) {
	.voice__block_inner:nth-of-type(2) {
		margin-top: 5rem;
	}

	.voice__block_inner:nth-of-type(3) {
		margin-top: 10rem;
	}
}

@media screen and (max-width:769px) {
	.voice__wrapper {
		height: 76rem;
		overflow: hidden;
	}

	.voice__wrapper.active {
		height: auto;
		padding-bottom: 10rem;
	}

	.voice__wrapper::after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		display: block;
		width: 110%;
		height: 28rem;
		background-image: linear-gradient(180deg, rgba(250, 248, 246, 0.00) 0%, rgba(250, 248, 246, 1.00) 59%);
		background-position: center center;
	}

	.voice__wrapper.active::after {
		display: none;
	}

	.voice .js-voice__switch {
		position: absolute;
		bottom: 10rem;
		left: 50%;
		transform: translateX(-50%);
		display: flex;
		align-items: center;
		justify-content: center;
		width: 25rem;
		max-width: 100%;
		height: 5rem;
		margin: 0 auto;
		box-shadow: 0.4rem 0.4rem 1.0rem rgba(0, 0, 0, 0.1);
		background: var(--color-gradient01);
		color: #fff;
		font-size: 1.62rem;
		font-weight: 700;
		z-index: 10;
		cursor: pointer;
	}

	.voice__wrapper.active .js-voice__switch {
		bottom: 3.28rem;
		transform: translateX(-50%);
	}

	.voice__wrapper.active .js-voice__switch>span:nth-of-type(1) {
		display: none;
	}

	.voice .js-voice__switch>span:nth-of-type(2) {
		display: none;
	}

	.voice__wrapper.active .js-voice__switch>span:nth-of-type(2) {
		display: inherit;
	}

	.voice__block {
		grid-template-columns: 1fr;
		width: 92%;
		margin-left: auto;
		margin-right: auto;
		row-gap: 4.4rem;
	}

	.voice__block_contents {
		padding: 1.8rem 0 1.1rem;
	}

	.voice__block_img_box img {
		height: 24.4rem;
		-o-object-fit: cover;
		object-fit: cover;
		-o-object-position: top;
		object-position: top;
	}
}




/*******************
	.faq
********************/
.faq {
	position: relative;
	padding: 0;
	z-index: 10;
}

.faq .contents_wrapper {
	position: relative;
	max-width: 76rem;
	padding: 10rem 0 15rem;
	z-index: 10;
}

.faq .contents_wrapper::before {
	content: "";
	position: absolute;
	top: 0;
	right: -16rem;
	width: 100vw;
	height: 100%;
	background: #fff;
	box-shadow: 0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.15);
	z-index: -1;
}

.faq .contents_wrapper::after {
	content: "";
	position: absolute;
	top: 4rem;
	right: -16rem;
	transform: translateX(87%) translateY(25%);
	width: 18rem;
	height: 16rem;
	z-index: -5;
	background: var(--color-gradient01);
}

.faq .contents_wrapper>img {
	position: absolute;
	top: 0;
	right: -16rem;
	width: 22rem;
	transform: translateX(39%) translateY(-50%);
}

.faq_block dl {
	width: 100%;
}

.faq__block .acc_wrapper {
	margin: 0;
}


.faq__contents {}

.faq__question {
	position: relative;
	cursor: pointer;
	background: #f0ebe4;
}

.faq__question:hover {
	-webkit-filter: brightness(1.028);
	filter: brightness(1.028);
}

.faq__answer {
	border-radius: 0;
	border: 0;
}


.faq__contents_inner {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	-moz-column-gap: 1.1em;
	column-gap: 1.1em;
	padding: 1.25em 3.4em 1.3em 1.3em;
	font-size: 1.5rem;
	margin-bottom: 0.92em;
}

.faq__contents_inner p {
	font-weight: inherit;
	letter-spacing: 0.025em;
}

.faq__question .faq__contents_inner::before {
	content: "";
	display: block;
	min-width: 1.25em;
	height: auto;
	aspect-ratio: 16/14;
	background-image: url(../img/text/text-Q.svg);
	background-repeat: no-repeat;
	background-size: contain;
}

.faq__question .faq__contents_inner {}

.faq__question .faq__contents_inner p {
	font-weight: 500;
	line-height: 1.44;
}

.faq__answer .faq__contents_inner {
	align-items: flex-start;
	padding: 0 0 1.5rem;
	font-weight: 400;
}



@media screen and (min-width:769.02px) {}


@media screen and (max-width:769px) {
	.faq .contents_wrapper {
		padding: 6.2rem 0 7rem;
	}

	.faq .contents_wrapper::before {
		content: "";
		position: absolute;
		top: 0;
		right: -0.44rem;
		z-index: -1;
		box-shadow: 0.2rem 0.2rem 1rem rgba(0, 0, 0, 0.05);
	}

	.faq__block {
		width: 92%;
		margin: 0 auto;
	}

	.faq__contents_inner {
		padding: 0.87em 3.4em 0.92em 1.3em;
		margin-bottom: 0.56em;
	}
}





/*******************
	.contact
********************/
.contact {
	position: relative;
	padding: 25rem 0 8.7rem;
	margin-top: -13rem;
	color: #fff;
}

.contact::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	background: var(--color-gradient01);
	border-top-right-radius: 3.0rem;
}

.contact .contents_wrapper {
	position: relative;
	max-width: 69rem;
}

.contact__text {
	margin-bottom: 3.4rem;
	text-align: center;
}

.contact__text .attention_mark {
	color: #E53838;
	top: 0.32em;
	font-size: 2.2em;
	line-height: 0.5;
}

.contact__heading {
	margin-bottom: 2rem;
	text-align: center;
	line-height: 1.5;
}



@media screen and (max-width:769px) {
	.contact {
		padding: 10rem 0 6.2rem;
		margin-top: -5.4rem;
	}

	.contact::before {
		border-top-right-radius: 1.5rem;
	}

	.contact__text {
		margin-bottom: 2.9rem;
	}
}


/**********
   contactForm
***********/
#contactForm {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}

#contactForm ::-webkit-input-placeholder {
	color: #b3b3b3;
}

#contactForm ::-moz-placeholder {
	color: #b3b3b3;
}

#contactForm :-ms-input-placeholder {
	color: #b3b3b3;
}

#contactForm ::placeholder {
	color: #b3b3b3;
}

#contactForm input[type="text"],
#contactForm input[type="time"],
#contactForm input[type="mail"],
#contactForm select,
#contactForm textarea {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 100%;
	max-width: 100%;
	padding: 0.5em 1.5em 0.56em 1.18em;
	outline: none;
	border-radius: 0.76rem;
	border: 1px solid #AEA7A5;
	background: #fff;
	font-feature-settings: "salt";
	color: var(--color-black01);
}

#contactForm input,
#contactForm select,
#contactForm textarea {
	font-size: 1.6rem;
	font-weight: 500;
	font-family: var(--font-base);
}

#contactForm .form-inner {
	margin-top: 0.82em;
}

#contactForm select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	cursor: pointer;
}

#contactForm .form-select_wrapper {
	position: relative;
}

#contactForm .form-select_wrapper::after {
	content: "";
	bottom: 1.3rem;
	right: 1.5rem;
	transform: translateY(-47%) rotate(45deg);
	position: absolute;
	width: 1rem;
	height: auto;
	aspect-ratio: 1/1;
	border: 2.0px solid var(--color-black01);
	border-top: 0;
	border-left: 0;
}

#contactForm input[type=checkbox] {
	position: absolute;
	top: 0;
	visibility: hidden;
	pointer-events: none;
}

#contactForm .checkbox_item {
	box-sizing: border-box;
	cursor: pointer;
	display: inline-block;
	padding: 0.32em 2.2em;
	position: relative;
	width: auto;
}

#contactForm .checkbox_item::before {
	background: #fff;
	border: 1px solid #AEA7A5;
	content: '';
	display: block;
	width: 1.5em;
	height: auto;
	aspect-ratio: 1/1;
	position: absolute;
	top: 0.54em;
	left: 0;
}

#contactForm .checkbox_item::after {
	border-right: 3px solid #E53838;
	border-bottom: 3px solid #E53838;
	content: '';
	display: block;
	height: 1.4em;
	width: 0.69em;
	opacity: 0;
	position: absolute;
	top: 0.2em;
	left: 0.7em;
	transform: rotate(45deg);
}

#contactForm input[type=checkbox]:checked+.checkbox_item::after {
	opacity: 1;
}

#contactForm .checkbox_item {}

#contactForm textarea {
	height: 25rem;
	padding-top: 1em;
	line-height: 1.5;
}

#contactForm .form-wrap dd {
	flex: 1;
}

#contactForm .form-contents_title {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	-moz-column-gap: 0.5em;
	column-gap: 0.5em;
	width: 100%;
	margin-top: 1.5em;
	margin-bottom: 0.76em;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.025em;
}

#contactForm .form-contents_title::before {
	content: "";
	position: relative;
	top: 0.04em;
	display: block;
	width: 0.82em;
	height: auto;
	aspect-ratio: 1/1;
	background: #FCD473;
}

#contactForm .form-contents_title::after,
.form_required_text::after {
	content: "";
	position: relative;
	display: inline-block;
	white-space: nowrap;
	color: #fff;
	font-size: 1.4em;
	margin-left: 0;
	line-height: 1;
}

#contactForm .required .form-contents_title::after,
.form_required_text::after {
	content: "*";
	color: #E53838;
}

#contactForm .form-contents_title .attention_text {
	display: inline-block;
	font-size: 0.87em;
	margin: 0.2em 0 -0.2em;
}

#contactForm .form-contents_title .attention_text:first-of-type {
	margin-top: 0.5em;
}

#contactForm .form-contents_check {
	cursor: pointer;
}

#contactForm .confirm01-inner {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	padding-right: 0;
	margin: 3.2rem auto;
	text-align: center;
}

#contactForm .confirm01-inner label {
	padding-right: 0;
}

.form_scroll_box {
	width: 100%;
	height: 15em;
	padding: 1.3em 1.1em 4.7em 1.5em;
	overflow-y: scroll;
	background: #fff;
	color: var(--color-black01);
	font-size: 0.87em;
}

.form_scroll_box_num01 {
	padding-top: 1.6rem;
}

.form_scroll_box {}

.form_scroll_box_num01>li+li {
	padding-top: 1.5rem;
}

.form_scroll_box_text {
	line-height: 1.82;
}

.form_scroll_box_text.right {
	text-align: right;
}

.form_scroll_box_text+.form_scroll_box_text {
	padding-top: 2em;
}

.form_scroll_box a {
	color: #3dae35;
	text-decoration: underline;
}

.form_scroll_box a:hover {
	opacity: 1;
	text-decoration: none;
}

/*** form-datepicker ***/
.js-form-datepicker .formError {
	display: none !important;
}

.js-form-datepicker.error-show .formError {
	display: block !important;
}




/* contact btn */
.form_btn_block {
	display: flex;
	align-items: center;
	justify-content: center;
	-moz-column-gap: 5rem;
	column-gap: 5rem;
	margin: 5.0rem auto 2.2rem;
}

.form_btn_block .contact_btn {
	position: relative;
	width: 28rem;
	height: 3.4em;
	margin: 0 auto;
	border: none !important;
	border-radius: 1rem !important;
	font-size: 2.0rem;
}

.form_btn_block .submit_btn {
	position: relative;
	width: 25rem;
}

.form_btn_block .return_btn {
	width: 25rem;
}

.form_btn_block.flex_base .contact_btn {
	margin: 0;
}

#contactForm .form_btn_block .contact_btn input,
.form_btn_block .contact_btn a {
	--bg_color: #FCD473;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding-bottom: 0.1em;
	margin: 0 auto;
	background: var(--bg_color);
	border: 3.0px solid var(--bg_color);
	border-radius: 0.76rem !important;
	-webkit-appearance: none;
	box-shadow: 0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
	font-weight: 500;
	font-size: 1em;
	font-weight: 700;
	color: var(--color-black01);
	cursor: pointer;
	transition: 0s;
	opacity: 1 !important;
}


.form_btn_block .contact_btn:hover {
	opacity: 1;
}

#contactForm .form_btn_block .contact_btn:hover input,
.form_btn_block .contact_btn:hover a {
	background: #fff;
	-webkit-filter: brightness(1.1);
	filter: brightness(1.1);
}

#contactForm .form_btn_block .submit_btn input {
	--bg_color: #FCD473;
}

#contactForm .form_btn_block .return_btn input,
.form_btn_block .return_btn a {
	--bg_color: #eeeeee;
}

#contactForm .form_btn_block .return_btn input:hover,
.form_btn_block .return_btn a:hover {}



/* error */
#contactForm .formError {
	position: static !important;
	margin: 0 !important;
	pointer-events: none;
}

#contactForm .formErrorContent {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0rem auto 0.62rem;
	color: #fff;
	background: #E53838;
	border-radius: 0.55rem;
}

#contactForm .formError .formErrorContent:after {
	display: none;
}

#contactForm .form-mail .formErrorContent span {
	display: none;
}

#contactForm .form-mail .formErrorContent span:last-of-type {
	display: inherit;
}



@media screen and (min-width:769.02px) {

	#contactForm input#zip,
	#contactForm .form-select_wrapper {
		width: 28rem;
	}

	.form_btn_block .contact_btn:last-of-type:first-of-type {
		width: 32rem;
	}
}


@media screen and (max-width:769px) {
	#contactForm input#zip {
		width: 20rem;
	}

	#contactForm {
		width: 93.2%;
	}

	#contactForm textarea {
		height: 17rem;
	}

	#contactForm .form-contents_title {
		font-size: 1.44rem;
		letter-spacing: -0.02em;
	}

	#contactForm .form_btn_block {
		flex-direction: column-reverse;
		row-gap: 2.0rem;
		margin: 4rem auto 2.5rem;
	}

	#contactForm .form_btn_block .contact_btn {
		font-size: 1.7rem;
	}

	.form_btn_block .contact_btn {
		width: 29rem;
	}
}





/********************

   contact page

*********************/
.contact_group {
	background: var(--color-gradient01);
	color: #fff;
}

.contact_group .main_contents {
	padding-top: 8.7rem;
	padding-bottom: 11.5rem;
	min-height: calc(100vh - 15rem);
}

.contact_group #contactForm {
	max-width: 96rem;
}

.contact_group .page_tit {
	font-size: 4.7rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 1.5rem;
}

.contact_group .page_lead {
	font-size: 1.9rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 4.7rem;
}


@media screen and (max-width:769px) {
	.contact_group #body_inner {
		margin-bottom: 0;
	}

	.contact_group .main_contents {
		padding-top: 5.6rem;
		padding-bottom: 8.7rem;
	}

	.contact_group .page_tit {
		font-size: 2.9rem;
		margin-bottom: 1.1rem;
	}

	.contact_group .page_lead {
		font-size: 1.55rem;
		margin-bottom: 3.8rem;
	}
}

#contactForm .form_btn_block .contact_btn {
	margin: 0;
}



/**************

   confirm page

***************/
.p-confirm .form_loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	height: 100lvh;
	background: #000000cc;
	z-index: 9999;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s;
}

.p-confirm .form_loading.active {
	opacity: 1;
	pointer-events: all;
}

.p-confirm .form_loading__inner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-54%);
	display: block;
}

.p-confirm .form_loading__bars {
	display: block;
	margin-bottom: 1.1rem;
}

.p-confirm .form_loading__bars span,
.p-confirm .form_loading__bars::before,
.p-confirm .form_loading__bars::after {
	content: "";
	display: block;
	background: var(--color-gradient01);
	width: 15rem;
	height: 0.62rem;
	margin-top: 1.18rem;
	-webkit-animation: form_load 1.8s ease infinite;
	animation: form_load 1.8s ease infinite;
	border-radius: 1rem;
	-webkit-filter: brightness(1.7);
	filter: brightness(1.7);
}

.p-confirm .form_loading__bars span {
	-webkit-animation-delay: 150ms;
	animation-delay: 150ms;
}

.p-confirm .form_loading__bars::after {
	-webkit-animation-delay: 280ms;
	animation-delay: 280ms;
}

@-webkit-keyframes form_load {
	50% {
		width: 0.7rem;
		margin-right: 14.3rem;
		opacity: 1;
		-webkit-filter: brightness(1);
		filter: brightness(1);
	}
}

@keyframes form_load {
	50% {
		width: 0.7rem;
		margin-right: 14.3rem;
		opacity: 1;
		-webkit-filter: brightness(1);
		filter: brightness(1);
	}
}

.p-confirm .form_loading__text {
	text-align: center;
	color: #ffffffdd;
	font-size: 2.25rem;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.22em;
}



.p-confirm #contactForm dl {
	max-width: 69rem;
	padding: 5.5rem 5.5rem 6.2rem;
	margin: 0 auto;
	border: 1px solid #AEA7A5;
	border-radius: 1rem;
	background: #fff;
	color: var(--color-black01);
}

.p-confirm #contactForm .form-wrap {
	border-bottom: 1px solid var(--color-black01);
	padding: 2.2rem 0.25rem 2.5rem;
}

.p-confirm #contactForm .form-wrap:first-of-type {
	border-top: 1px solid var(--color-black01);
}

/* 非表示　*/
.p-confirm #contactForm input:not([type="submit"]),
.p-confirm #contactForm .form-inner,
.p-confirm #contactForm .form-select_wrapper,
.p-confirm #contactForm textarea,
.p-confirm #contactForm select,
.p-confirm #contactForm .form-preferred_date_block__date_wrapper::after,
.p-confirm #contactForm .form-preferred_date_block__time_wrapper::after,
.p-confirm #contactForm [data-name="mail_confirm"],
.p-confirm #contactForm .checkbox_item {
	background: transparent;
	color: #fff;
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
}

.p-confirm .form-inner {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-direction: column;
	height: 100%;
}

.p-confirm .message_wrap .form-inner {
	min-height: 5rem;
}

.p-confirm #contactForm .form-contents_title {
	margin-top: 0;
}

.p-confirm #contactForm .form-wrap dd {
	max-width: 100%;
}

.p-confirm #contactForm .form-contents_title::after {
	display: none;
}



#contactForm .confirm_input_content {
	display: block;
	font-size: 1.8rem;
}

#contactForm textarea~.confirm_input_content {
	word-break: break-all;
}


@media screen and (max-width:769px) {
	#contactForm .confirm_input_content {
		font-size: 1.6rem;
	}

	.p-confirm #contactForm dl {
		padding: 2.0rem 1.8rem 2.5rem;
		border-radius: 0.62rem;
	}

	.p-confirm .message_wrap .form-inner {
		min-height: 3.2rem;
	}
}



/**************

   thanks page

***************/
.p-thanks .main_contents {
	margin-top: 10vh;
}

.p-thanks .contact__heading {
	margin-bottom: 3.2rem;
}

@media screen and (min-width:769.02px) {
	.p-thanks .form_btn_block {
		margin-top: 5rem;
	}

	.p-thanks .contact__text {
		font-size: 1.6rem;
	}
}