@charset "utf-8";

/*====================================================================================

		#top layout

====================================================================================*/

/*===============================================================

		#top #contents .main_img layout

===============================================================*/

#top #contents .main_img {
	height: 794px;
	background: url("../img/main_bg.png") center bottom / cover no-repeat;
	overflow-x: hidden;
}

#top #contents .main_img .swiper-slide {
	width: 570px;
	height: 346px;
}

#top #contents .main_img .swiper-slide img {
	height: 100%;
	border-radius: 20px;
}


#top #contents .main_img .heading {
	padding: 50px 40px 0;
}

#top #contents .main_img .heading .inner {
	max-width: 1080px;
	margin: 0 auto;
}

#top #contents .main_img .heading .inner h2 {
	max-width: 800px;
	margin: 0 0 20px;
	text-align: left;
	color: #fff;
	font-size: 54px;
	font-weight: 700;
	line-height: 1.4;
}

#top #contents .main_img .heading .inner h2 + p {
	color: #fff;
	font-size: 16px;
	font-weight: 700;
}


@media screen and (max-width: 768px){
	#top #contents .main_img {
		height: auto;
		padding: 100px 0 30%;
		background: url("../img/sp/main_bg.png") center bottom / cover no-repeat;
	}
	
	#top #contents .main_img .swiper-wrapper {
		padding: 0 0 0 15px;
	}
	
	#top #contents .main_img .swiper-slide {
		width: auto;
		height: 40vh;
	}
	
	#top #contents .main_img .swiper-slide img {
		height: 100%;
		border-radius: 20px;
		object-fit: cover;
		object-position: right center;
	}
	
	#top #contents .main_img .slide_03 img {
		object-position: 12% center;
	}
	
	
	#top #contents .main_img .heading {
		padding: 2vh 6vw 0;
	}
	
	#top #contents .main_img .heading .inner {
		max-width: inherit;
		padding: 0;
	}
	
	#top #contents .main_img .heading .inner h2 {
		margin: 0 0 1vh;
		color: #fff;
		font-size: 9vw;
		font-weight: 700;
		line-height: 1.4;
	}
	
	#top #contents .main_img .heading .inner h2 + p {
		color: #fff;
		font-size: 3.7vw;
		font-weight: 700;
		line-height: 1.7;
	}
}



/*===============================================================

		#top #contents .choice layout

===============================================================*/

#top #contents .choice {
	margin: 95px 0 0;
	background: url("../../img/top/bg01.png") right top / 93px auto no-repeat;
}

#top #contents .choice .inner {
	max-width: 1250px;
	padding: 0 10px;
	display: flex;
	justify-content: space-between;
}

#top #contents .choice .inner .image {
	width: 54.268%;
	max-width: 667.5px;
}

#top #contents .choice .inner .image p.img {
	max-width: 100%;
}

#top #contents .choice .inner .image p:nth-of-type(2) {
	margin: 20px 0 15px;
	text-align: center;
	color: var(--logo_green);
	font-size: 20px;
	font-weight: 700;
}

#top #contents .choice .inner .image p.btn {
	width: 360px;
	margin: 0 auto;
}

#top #contents .choice .inner .image p.btn a {
	width: 100%;
	padding: 25px 20px;
	background-color: #fff;
	border: solid 1px var(--logo_green);
	border-radius: 60px;
	box-shadow: 5px 7px 0 var(--logo_green);
	display: inline-block;
	text-align: center;
	color: var(--logo_green);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.0;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#top #contents .choice .inner .image p.btn a:hover {
	transform: translateY(4px);
	box-shadow: 5px 3px 0 var(--logo_green);
}


#top #contents .choice .inner .detail {
	width: 45%;
	max-width: 554px;
}

#top #contents .choice .inner .detail h3 {
	margin: 0 0 50px;
	display: flex;
	justify-content: center;
	color: var(--logo_green);
	font-size: min(60px, 5.5vw);
	font-weight: 700;
	line-height: 1.4;
}

#top #contents .choice .inner .detail h3 + p {
	position: relative;
	text-align: center;
	color: var(--logo_green);
	font-size: min(24px, 2.4vw);
	font-weight: 700;
	line-height: 1.7;
}

#top #contents .choice .inner .detail h3 + p::before {
	content: '';
	width: 3px;
	height: 100%;
	background-color: var(--logo_green);
	border-radius: 3px;
	position: absolute;
	left: 10%;
	top: 0;
	transform: rotate(-20deg);
}

#top #contents .choice .inner .detail h3 + p::after {
	content: '';
	width: 3px;
	height: 100%;
	background-color: var(--logo_green);
	border-radius: 3px;
	position: absolute;
	right: 10%;
	top: 0;
	transform: rotate(20deg);
}

#top #contents .choice .inner .detail ul {
	margin: 30px 0 0;
	display: flex;
	gap: 0 5px;
}

#top #contents .choice .inner .detail ul:nth-of-type(1) {
	justify-content: center;
}

#top #contents .choice .inner .detail ul:nth-of-type(2) {
	justify-content: space-between;
}

#top #contents .choice .inner .detail ul li {
	width: calc(100% / 4);
	text-align: center;
	font-size: min(14px, 1.4vw);
	font-weight: 700;
	line-height: 1.5;
}

#top #contents .choice .inner .detail ul li a {
	display: block;
}

#top #contents .choice .inner .detail ul li a .img {
	width: 90%;
	max-width: 98px;
	margin: 0 auto;
	position: relative;
}

#top #contents .choice .inner .detail ul li a .img .outer-circle {
	width: 36px;
	height: 36px;
	position: absolute;
	right: 0;
	bottom: 0;
}

#top #contents .choice .inner .detail ul li a .img .outer-circle .inner-circle {
	width: 9px;
	height: 9px;
}

#top #contents .choice .inner .detail ul li a .img .outer-circle .arrow {
	width: 18px;
	height: 18px;
}

#top #contents .choice .inner .detail ul li a:hover .img .outer-circle .inner-circle {
	width: 36px;
	height: 36px;
}



#top #contents .choice .inner .detail ul li a dl dt {
	margin: 10px 0;
	font-size: min(18px, 1.8vw);
}


@media screen and (max-width: 768px){
	#top #contents .choice {
		margin: 5vh 0 0;
		background: none;
	}
	
	#top #contents .choice .inner {
		max-width: inherit;
		padding: 0 10px;
		display: block;
	}
	
	#top #contents .choice .inner .image {
		width: auto;
		max-width: inherit;
		/*margin: 0 0 6vh;*/
		margin: 0;
	}
	
	#top #contents .choice .inner .image p.img {
		max-width: 100%;
	}
	
	#top #contents .choice .inner .image p:nth-of-type(2) {
		margin: 20px 0 15px;
		display: none;
		font-size: 4.7vw;
	}
	
	#top #contents .choice .inner .image p.btn {
		width: 90%;
		display: none;
	}
	
	#top #contents .choice .inner .image p.btn a {
		padding: 25px 20px;
		font-size: 4.7vw;
	}
	
	#top #contents .choice .inner .image p.btn a:hover {
		transform: translateY(0);
		box-shadow: 5px 7px 0 var(--logo_green);
	}
	
	
	#top #contents .choice .inner .detail {
		width: auto;
		max-width: inherit;
		display: none;
	}
	
	#top #contents .choice .inner .detail h3 {
		margin: 0 0 30px;
		font-size: 9vw;
	}
	
	#top #contents .choice .inner .detail h3 + p {
		font-size: 6vw;
	}
	
	#top #contents .choice .inner .detail h3 + p::before {
		left: 20px;
	}
	
	#top #contents .choice .inner .detail h3 + p::after {
		right: 20px;
	}
	
	#top #contents .choice .inner .detail ul {
		margin: 30px 0 0;
		display: flex;
		flex-flow: row wrap;
		gap: 30px 0;
	}
	
	#top #contents .choice .inner .detail ul:nth-of-type(1) {
		justify-content: space-between;
	}
	
	#top #contents .choice .inner .detail ul:nth-of-type(2) {
		justify-content: space-between;
	}
	
	#top #contents .choice .inner .detail ul li {
		width: calc(100% / 3);
		font-size: 3.2vw;
	}
	
	#top #contents .choice .inner .detail ul li a dl dt {
		font-size: 3.7vw;
	}
}



/*===============================================================

		#top #contents .whats layout

===============================================================*/

#top #contents .whats {
	margin: 250px 0 0;
}

#top #contents .whats .inner {
	max-width: 1280px;
	padding: 0 40px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0 40px;
}

#top #contents .whats .inner .heading {
	width: 324px;
	flex-shrink: 0;
	position: sticky;
	top: 120px;
}

#top #contents .whats .inner .heading h3 {
	margin: 0 0 40px;
	text-align: center;
}

#top #contents .whats .inner .heading h3 img {
	max-width: 316px;
}

#top #contents .whats .inner .heading h3 span {
	width: 100%;
	display: block;
	text-align: center;
	color: var(--logo_green);
	font-weight: 700;
	line-height: 1.4;
}

#top #contents .whats .inner .heading h3 span:nth-of-type(1) {
	font-size: 56px;
	letter-spacing: 0;
}

#top #contents .whats .inner .heading h3 span:nth-of-type(2) {
	margin: 30px 0 0;
	font-size: 24px;
	letter-spacing: -6%;
}

#top #contents .whats .inner .heading ul li {
	margin: 0 0 10px;
}

#top #contents .whats .inner .heading ul li a {
	width: 100%;
	padding: 15px 28px;
	background-color: #fff;
	border-radius: 64px;
	display: inline-flex;
	justify-content: space-between;
	align-items: center;
	font-weight: 700;
	letter-spacing: 0;
}


#top #contents .whats .inner .detail {
	width: 59.5%;
	max-width: 714px;
}

#top #contents .whats .inner .detail .trigger_01 {
	display: none;
}

#top #contents .whats .inner .detail section {
	margin: 0 0 25px;
	padding: 60px 0 70px;
	background-color: var(--beige);
	border-radius: 20px;
}

#top #contents .whats .inner .detail .detail_01 {
	padding: 60px 0 0;
	position: relative;
}

#top #contents .whats .inner .detail .detail_01::before {
	content: "";
	width: 123px;
	height: 103px;
	background: url("../../img/top/img10.png") left top / 100% auto no-repeat;
	position: absolute;
	left: 47%;
	top: -103px;
	z-index: 1;
}

#top #contents .whats .inner .detail section h4 {
	margin: -120px min(50px, 5vw) 20px min(90px, 7vw);
	padding: 120px 0 0;
	color: var(--logo_green);
	font-size: 24px;
	font-weight: 700;
	line-height: 1.4;
}

#top #contents .whats .inner .detail section h4 + p {
	margin: 0 min(50px, 5vw) 45px min(90px, 7vw);
}

#top #contents .whats .inner .detail .detail_01 p.img_01 {
	width: 88.936%;
	max-width: 635px;
	margin: 0 auto;
}

#top #contents .whats .inner .detail .detail_01 p.img_02 {
	margin: -70px 0 0;
}

#top #contents .whats .inner .detail .detail_01 ul {
	margin: -5px 0 0;
	padding: 25px 20px 35px;
	background-color: var(--green_02);
	border-radius: 0 0 20px 20px;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	align-items: center;
	gap: 15px;
}

#top #contents .whats .inner .detail .detail_01 ul li {
	width: 270px;
}

#top #contents .whats .inner .detail .detail_01 ul li a {
	width: 100%;
	padding: 15px 25px 15px 15px;
	background-color: #fff;
	border: solid 1px var(--logo_green);
	border-radius: 50px;
	/*display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0 15px;*/
	display: block;
	position: relative;
	text-align: center;
	color: var(--logo_green);
	font-size: 16px;
	font-weight: 700;
	line-height: 1.0;
}

#top #contents .whats .inner .detail .detail_01 ul li a .outer-circle {
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}


#top #contents .whats .inner .detail .detail_02 ul {
	padding: 0 min(40px, 4vw) 0 min(50px, 5vw);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0 25px;
}


#top #contents .whats .inner .detail .detail_03 ul {
	padding: 0 min(50px, 5vw);
}

#top #contents .whats .inner .detail .detail_03 ul li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0 15px;
}

#top #contents .whats .inner .detail .detail_03 ul li:nth-child(1) {
	margin: 0 0 22px;
}

#top #contents .whats .inner .detail .detail_03 ul li:nth-child(2) {
	margin: 0 0 34px;
}

#top #contents .whats .inner .detail .detail_03 ul li p {
	width: 41.74%;
	text-align: center;
}

#top #contents .whats .inner .detail .detail_03 ul li:nth-child(1) p img {
	width: 175px;
}

#top #contents .whats .inner .detail .detail_03 ul li:nth-child(3) p img {
	width: 148px;
}

#top #contents .whats .inner .detail .detail_03 ul li dl {
	width: 55.65%;
}

#top #contents .whats .inner .detail .detail_03 ul li dl dt {
	margin: 0 0 10px;
	display: flex;
	align-items: center;
	gap: 0 10px;
	color: var(--logo_green);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.4;
}

#top #contents .whats .inner .detail .detail_03 ul li dl dt span {
	width: 40px;
	height: 40px;
	background-color: var(--logo_green);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: #fff;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.0;
}


@media screen and (max-width: 975px){
	#top #contents .whats .inner .detail .detail_01 p.img_02 {
		margin: -40px 0 0;
	}
}


@media screen and (max-width: 768px){
	#top #contents .whats {
		margin: 5vh 0 0;
		background: none;
	}
	
	#top #contents .whats .inner {
		max-width: inherit;
		padding: 0 20px;
		display: block;
	}
	
	#top #contents .whats .inner .heading {
		width: auto;
		max-width: inherit;
		margin: 0 0 6vh;
		position: static;
	}
	
	#top #contents .whats .inner .heading h3 {
		margin: 0 0 40px;
		text-align: center;
	}
	
	#top #contents .whats .inner .heading h3 img {
		width: 90%;
		max-width: 316px;
	}
	
	#top #contents .whats .inner .heading h3 span:nth-of-type(1) {
		font-size: min(56px, 13vw);
	}
	
	#top #contents .whats .inner .heading h3 span:nth-of-type(2) {
		margin: 20px 0 0;
		font-size: min(24px, 6vw);
	}
	
	#top #contents .whats .inner .heading ul {
		display: none;
	}
	
	
	#top #contents .whats .inner .detail {
		width: auto;
		max-width: inherit;
	}
	
	#top #contents .whats .inner .detail .trigger_01 {
		width: 100%;
		margin: 0 0 15px;
		padding: 15px 28px;
		background-color: #fff;
		border-radius: 64px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		position: relative;
		z-index: 2;
		font-weight: 700;
		letter-spacing: 0;
	}
	
	#top #contents .whats .inner .detail .trigger_01 .arrow_01 {
		transition: none;
	}
	
	#top #contents .whats .inner .detail .trigger_01.is-active .arrow_01 {
		transform: rotate(-180deg);
	}
	
	#top #contents .whats .inner .detail section {
		margin: 0 0 25px;
		padding: 4vh 0 5vh;
	}
	
	#top #contents .whats .inner .detail .detail_01 {
		padding: 4vh 0 0;
	}
	
	#top #contents .whats .inner .detail .detail_01::before {
		display: none;
	}
	
	#top #contents .whats .inner .detail section h4 {
		margin: 0 min(20px, 5vw) 20px;
		padding: 0 0 0;
		font-size: min(24px, 4.5vw);
		line-height: 1.4;
	}
	
	#top #contents .whats .inner .detail section h4 + p {
		margin: 0 min(20px, 5vw) 20px;
	}
	
	#top #contents .whats .inner .detail .detail_01 p.img_01 {
		width: 94%;
		max-width: 635px;
		margin: 3vh auto 0;
	}
	
	#top #contents .whats .inner .detail .detail_01 p.img_02 {
		margin: 0;
	}
	
	#top #contents .whats .inner .detail .detail_01 ul {
		padding: 25px min(20px, 5vw) 35px;
	}
	
	#top #contents .whats .inner .detail .detail_01 ul li {
		width: 100%;
	}
	
	#top #contents .whats .inner .detail .detail_01 ul li a {
		display: block;
		position: relative;
		text-align: center;
		font-size: 3.7vw;
	}
	
	#top #contents .whats .inner .detail .detail_01 ul li a .outer-circle {
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
	}
	
	
	#top #contents .whats .inner .detail .detail_02 ul {
		padding: 0 min(20px, 5vw);
		flex-flow: column wrap;
		justify-content: center;
		gap: 4vh 0;
	}
	
	
	#top #contents .whats .inner .detail .detail_03 ul {
		padding: 0 min(20px, 5vw);
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li {
		flex-flow: column wrap;
		justify-content: center;
		gap: 2vh 0;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li:nth-child(1) {
		margin: 0 0 4vh;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li:nth-child(2) {
		margin: 0 0 4vh;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li p {
		width: 60%;
		text-align: center;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li:nth-child(1) p img {
		width: 175px;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li:nth-child(3) p img {
		width: 148px;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li dl {
		width: 100%;
	}
	
	#top #contents .whats .inner .detail .detail_03 ul li dl dt {
		margin: 0 0 10px;s
		gap: 0 10px;
		font-size: min(20px, 4.2vw);
	}
}



/*===============================================================

		#top #contents .voice layout

===============================================================*/

#top #contents .voice {
	margin: 120px 0 130px;
}

#top #contents .voice .inner {
	padding: 0;
}

#top #contents .voice .inner h3 {
	margin: 0 0 30px;
	text-align: center;
	font-size: 32px;
	font-weight: 700;
}

#top #contents .voice .inner h3 span {
	color: var(--logo_green);
	line-height: 1.0;
}

#top #contents .voice .inner h3 .en {
	margin: 0 0 10px;
	display: block;
	font-size: 32px;
	font-weight: 800;
	letter-spacing: 0;
}

#top #contents .voice .inner h3 .txt {
	margin: 0 0 10px;
	display: inline-block;
	position: relative;
	font-size: 18px;
}

#top #contents .voice .inner h3 .txt::before {
	content: '';
	width: 3px;
	height: 150%;
	background-color: var(--logo_green);
	border-radius: 3px;
	position: absolute;
	left: -25px;
	top: -3px;
	transform: rotate(-20deg);
}

#top #contents .voice .inner h3 .txt::after {
	content: '';
	width: 3px;
	height: 150%;
	background-color: var(--logo_green);
	border-radius: 3px;
	position: absolute;
	right: -25px;
	top: -3px;
	transform: rotate(20deg);
}


#top #contents .voice .inner .swiper_02 {
	padding: 0 25px;
	position: relative;
	overflow: hidden;
}

#top #contents .voice .inner .swiper_02 .swiper-button-prev,
#top #contents .voice .inner .swiper_02 .swiper-button-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: all 0.3s;
	z-index: 10;
	cursor: pointer;
}

#top #contents .voice .inner .swiper_02 .swiper-button-prev {
	left: 5px;
}

#top #contents .voice .inner .swiper_02 .swiper-button-next {
	right: 5px;
}

#top #contents .voice .inner .swiper_02 .swiper-button-prev:hover {
	transform: scale(1.1) translateY(-50%);
	transform-origin: top center;
}

#top #contents .voice .inner .swiper_02 .swiper-button-next:hover {
	transform: scale(1.1) translateY(-50%);
	transform-origin: top center;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper {
	max-width: 800px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .img {
	width: 31.25%;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .img p {
	width: 94%;
	max-width: 216px;
	margin: 0 auto 15px;
	padding: 100px 0 0;
	position: relative;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .img p::before {
	content: "";
	width: 162.5px;
	height: 139px;
	background: url("../../img/top/voice_flag.png") left top / 100% auto no-repeat;
	position: absolute;
	left: calc(50% - 81px);
	top: 0;
	z-index: -1;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .img ul {
	display: flex;
	justify-content: center;
	align-items: center;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .img ul li {
	width: calc(50% - 2px);
	padding: 6px 0 8px;
	background-color: #fff;
	border: solid 1px #E5E5E5;
	border-radius: 30px;
	text-align: center;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.0;
	letter-spacing: 0;
}


#top #contents .voice .inner .swiper_02 .slide_wrapper .detail {
	width: 66.25%;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl {
	padding: 70px 30px 30px;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl dt {
	margin: 0 0 25px;
	position: relative;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.5;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl dt::before {
	content: "“";
	position: absolute;
	left: -33px;
	top: -40px;
	color: #BFC0C0;
	font-size: 64px;
	font-weight: 700;
	line-height: 1.0;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl dt::after {
	content: "”";
	position: absolute;
	right: -33px;
	top: -40px;
	color: #BFC0C0;
	font-size: 64px;
	font-weight: 700;
	line-height: 1.0;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn {
	margin: 0 0 0 30px;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a {
	width: 290px;
	padding: 19px 15px 21px 25px;
	background-color: #fff;
	border: solid 1px #E5E5E5;
	border-radius: 50px;
	position: relative;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0 15px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.0;
}
#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a .outer-circle {
	width: 28px;
	height: 28px;
	background-color: var(--green_04);
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a .outer-circle .inner-circle {
	width: 8px;
	height: 8px;
}

#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a:hover .outer-circle {
	background-color: var(--logo_green);
}

/* mark */
#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a:hover .outer-circle .inner-circle {
	width: 28px;
	height: 28px;
}


@media screen and (max-width: 915px){
	#top #contents .voice .inner .swiper_02 .slide_wrapper {
		max-width: 640px;
	}
}


@media screen and (max-width: 768px){
	#top #contents .voice {
		margin: 12vh 0 0;
		background: none;
	}
	
	#top #contents .voice .inner h3 {
		margin: 0 0 30px;
		font-size: min(32px, 7vw);
	}
	
	#top #contents .voice .inner h3 .en {
		font-size: min(32px, 7vw);
	}
	
	#top #contents .voice .inner h3 .txt {
		font-size: min(18px, 4vw);
	}
	
	
	#top #contents .voice .inner .swiper_02 {
		padding: 0;
	}
	
	#top #contents .voice .inner .swiper_02 .swiper-button-prev,
	#top #contents .voice .inner .swiper_02 .swiper-button-next {
		position: absolute;
		top: 30%;
		transform: translateY(-50%);
		z-index: 10;
	}
	
	#top #contents .voice .inner .swiper_02 .swiper-button-prev {
		left: 10px;
	}
	
	#top #contents .voice .inner .swiper_02 .swiper-button-next {
		right: 10px;
	}
	
	#top #contents .voice .inner .swiper_02 .swiper-button-prev:hover,
	#top #contents .voice .inner .swiper_02 .swiper-button-next:hover {
		transform: translateY(-50%);
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper {
		max-width: inherit;
		display: block;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .img {
		width: auto;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .img p {
		width: 60%;
		max-width: 216px;
		margin: 0 auto 15px;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .img ul {
		justify-content: center;
		gap: 0 5px;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .img ul li {
		width: auto;
		padding: 6px 15px 8px;
		display: inline-block;
		font-size: 3.0vw;
	}
	
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail {
		width: auto;
		padding: 0 50px;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl {
		padding: 40px 0 30px;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl dt {
		margin: 0 0 20px;
		font-size: min(26px, 4.5vw);
		line-height: 2.4;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl dt::before {
		left: -25px;
		top: -20px;
		font-size: 50px;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail dl dt::after {
		right: -25px;
		top: -20px;
		font-size: 50px;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn {
		margin: 0;
	}
	
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a {
		width: 100%;
		padding: 19px 15px 21px 25px;
		background-color: #fff;
		border: solid 1px #E5E5E5;
		border-radius: 50px;
		position: relative;
		display: inline-flex;
		justify-content: center;
		align-items: center;
		gap: 0 15px;
		font-size: 15px;
		font-weight: 700;
		line-height: 1.0;
	}
	#top #contents .voice .inner .swiper_02 .slide_wrapper .detail .btn a .outer-circle {
		background-color: var(--logo_green);
	}
}



/*===============================================================

		#top #contents .showroom layout

===============================================================*/

#top #contents .showroom {
	padding: 0 20px;
}

#top #contents .showroom .inner {
	max-width: 1092px;
	padding: 45px min(45px, 4vw) 60px;
	background-color: #fff;
	border-radius: 36px;
	position: relative;
}

#top #contents .showroom .inner::before {
	content: "";
	width: 177px;
	height: 178px;
	background: url("../../img/top/img18.svg") left top / cover no-repeat;
	position: absolute;
	right: 90px;
	top: -56px;
	z-index: 2;
}

#top #contents .showroom .inner h3 {
	margin: -120px 0 40px;
	padding: 120px 0 0;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.0;
}

#top #contents .showroom .inner h3 .en {
	margin: 0 0 20px;
	display: block;
	color: var(--logo_green);
	font-size: 32px;
	font-weight: 800;
	letter-spacing: 0;
}

#top #contents .showroom .inner h3 + p {
	margin: 0 0 40px;
	text-align: center;
	font-size: 24px;
	font-weight: 700;
	line-height: 2.5;
}

#top #contents .showroom .inner ul {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}

#top #contents .showroom .inner ul li {
	width: 31.4%;
	max-width: 314px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.4;
}

#top #contents .showroom .inner ul li dl dt {
	margin: 18px 0 15px;
}

#top #contents .showroom .inner ul li dl dd.address {
	margin: 0 0 15px;
	display: inline-flex;
	align-items: center;
	gap: 0 10px;
	font-size: 14px;
	letter-spacing: 0;
}

#top #contents .showroom .inner ul li dl dd.address span {
	padding: 3px 10px 5px;
	background-color: #fff;
	border: solid 1px var(--logo_green);
	border-radius: 20px;
	display: block;
	color: var(--logo_green);
	font-size: 12px;
	line-height: 1.0;
	transition: all 0.3s;
}

#top #contents .showroom .inner ul li a:hover img {
	opacity: 0.8;
}

#top #contents .showroom .inner ul li dl dd.address span:hover {
	background-color: var(--logo_green);
	color: #fff;
}


@media screen and (max-width: 768px){
	#top #contents .showroom {
		margin: 12vh 0 0;
		padding: 0 20px;
	}
	
	#top #contents .showroom .inner {
		max-width: inherit;
		padding: 80px 20px 60px;
		border-radius: 20px;
	}
	
	#top #contents .showroom .inner::before {
		width: 100px;
		height: 100px;
		right: auto;
		left: calc(50% - 50px);
		top: -50px;
	}
	
	#top #contents .showroom .inner h3 {
		margin: -80px 0 40px;
		padding: 80px 0 0;
		text-align: center;
		font-size: min(32px, 7vw);
	}
	
	#top #contents .showroom .inner h3 .en {
		margin: 0 0 10px;
		font-size: min(26px, 5vw);
		letter-spacing: 0.05em;
	}
	
	#top #contents .showroom .inner h3 + p {
		margin: 0 20px 20px;
		text-align: left;
		font-size: min(22px, 4.4vw);
		line-height: 2.4;
	}
	
	#top #contents .showroom .inner ul {
		display: flex;
		flex-flow: column wrap;
		justify-content: flex-start;
		gap: 4vh 0;
	}
	
	#top #contents .showroom .inner ul li {
		width: auto;
		max-width: inherit;
		text-align: center;
		font-size: min(22px, 4.4vw);
	}
	
	#top #contents .showroom .inner ul li p {
		width: 80%;
		max-width: 314px;
		margin: 0 auto;
	}
	
	#top #contents .showroom .inner ul li dl dt {
		margin: 15px 0 15px;
		font-weight: 700;
	}
	
	#top #contents .showroom .inner ul li dl dd.address {
		text-align: left;
		gap: 0 10px;
		font-size: min(15px, 3.6vw);
		font-weight: 700;
	}
	
	#top #contents .showroom .inner ul li dl dd.address a {
		font-size: min(12px, 3.0vw);
	}
	
	#top #contents .showroom .inner ul li dl dd.tel {
		font-size: min(15px, 3.6vw);
		font-weight: 700;
	}
}



/*===============================================================

		#top #contents .roop layout

===============================================================*/

#top #contents .roop {
	margin: 110px 0 40px;
	overflow: hidden;
}

#top #contents .roop .swiper-wrapper {
	align-items: center;
	transition-timing-function: linear;
}

/*
#top #contents .roop .roop_slider {
	align-items: center;
	transition-timing-function: linear;
}
*/
#top #contents .roop .slide_item {
	display: flex;
	justify-content: center;
	align-items: center;
}

#top #contents .roop .slide_01 {
	width: 201px;
}

#top #contents .roop .slide_02 {
	width: 307px;
}

#top #contents .roop .slide_03 {
	width: 125px;
}


@media screen and (max-width: 768px){
	#top #contents .roop {
		margin: 6vh 0;
	}
	
	#top #contents .roop .slide_01 {
		width: 35%;
	}
	
	#top #contents .roop .slide_02 {
		width: 50%;
	}
	
	#top #contents .roop .slide_03 {
		width: 25%;
	}
}





/*====================================================================================

		#about layout

====================================================================================*/

#about #contents  {
	overflow-x: hidden;
}


/*===============================================================

		#about #contents .main_img layout

===============================================================*/

#about #contents .main_img {
	position: relative;
	z-index: 1;
}

#about #contents .main_img .inner h2 {
	text-align: left;
}


@media screen and (max-width: 768px){
	#about #contents .main_img .inner h2 {
		text-align: center;
	}
}



/*===============================================================

		#about #contents .catch layout

===============================================================*/

#about #contents .catch {
	padding: 40px 40px 90px;
	position: relative;
	z-index: 2;
}

#about #contents .catch::before {
	content: "";
	width: 131px;
	height: 137px;
	background: url("../../img/about/bg01.png") left top / cover no-repeat;
	position: absolute;
	left: 40px;
	bottom: -50px;
	z-index: 1;
}

#about #contents .catch .inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
}

#about #contents .catch .inner::after {
	content: "";
	width: 136px;
	height: 186px;
	background: url("../../img/about/img02.png") left top / cover no-repeat;
	position: absolute;
	left: 350px;
	bottom: -250px;
	z-index: 2;
}

#about #contents .catch .inner .txt {
	width: 50%;
	letter-spacing: 0;
	position: relative;
	z-index: 2;
}

#about #contents .catch .inner .txt h3 {
	margin: 0 0 20px;
	color: var(--logo_green);
	font-size: min(42px, 3.5vw);
	font-weight: 700;
	line-height: 1.5;
}

#about #contents .catch .inner .txt h3 + p {
	color: var(--logo_green);
	font-size: min(24px, 2.0vw);
	font-weight: 700;
}

#about #contents .catch .inner .img {
	width: 60%;
	max-width: 630px;
	position: absolute;
	right: -90px;
	top: -290px;
}


@media screen and (max-width: 768px){
	#about #contents .catch {
		padding: 0 20px 30px;
	}
	
	#about #contents .catch::before {
		width: 45px;
		height: 64px;
		background: url("../../img/about/sp/bg01.png") left top / 100% auto no-repeat;
		left: auto;
		right: 0;
		bottom: -20px;
	}
	
	#about #contents .catch .inner {
		padding: 0 0 3vh;
		flex-flow: column-reverse nowrap;
		align-items: flex-start;
	}
	
	#about #contents .catch .inner::after {
		width: 20%;
		height: 96px;
		background: url("../../img/about/img02.png") left top / 100% auto no-repeat;
		left: auto;
		bottom: auto;
		right: 4%;
		top: 51%;
	}
	
	#about #contents .catch .inner .txt {
		width: auto;
	}
	
	#about #contents .catch .inner .txt h3 {
		margin: 0 0 20px;
		color: var(--logo_green);
		font-size: 6vw;
		font-weight: 700;
		line-height: 1.5;
	}
	
	#about #contents .catch .inner .txt h3 + p {
		color: var(--logo_green);
		font-size: 4.7vw;
		font-weight: 700;
	}
	
	#about #contents .catch .inner .img {
		width: auto;
		margin: -40px 0 30px;
		position: static;
	}
}



/*===============================================================

		#about #contents .reason layout

===============================================================*/

#about #contents .reason {
	padding: 200px 0 80px;
	background-color: #FBF5E3;
	position: relative;
	z-index: 1;
	overflow-x: hidden;
}

#about #contents .reason section {
	margin: 0 0 100px;
	padding: 0 40px;
}

#about #contents .reason section .inner {
	max-width: 1080px;
}

#about #contents .reason .detail .inner {
	display: flex;
	justify-content: space-between;
}

#about #contents .reason .detail .inner .box {
	width: 50%;
	max-width: 536px;
}

#about #contents .reason .detail .inner h3 {
	margin: 0 0 25px;
	font-size: min(32px, 3vw);
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0;
}

#about #contents .reason .detail .inner h3 .num {
	margin: -20px 0 30px;
	display: block;
	color: #FBF5E3;
	font-size: min(133px, 13vw);
	text-shadow: 
		 1px  1px 0px #008c3e,
		-1px  1px 0px #008c3e,
		 1px -1px 0px #008c3e,
		-1px -1px 0px #008c3e,
		 1px  0px 0px #008c3e,
		 0px  1px 0px #008c3e,
		-1px  0px 0px #008c3e,
		 0px -1px 0px #008c3e;
	line-height: 1.0;
}

#about #contents .reason .detail .inner h3 .txt {
	display: block;
	color: var(--logo_green);
	font-size: min(18px, 1.8vw);
	font-weight: 700;
}

#about #contents .reason .detail .inner h3 + p {
	margin: 0 0 40px;
	font-size: min(16px, 1.6vw);
	font-weight: 500;
	line-height: 2.0;
}

#about #contents .reason .detail .inner .img {
	flex-shrink: 0;
}

#about #contents .reason .reason_01 .inner .img {
	width: 50%;
	max-width: 540px;
	margin: 0 -50px 0 0;
}

#about #contents .reason .reason_02 .inner .img {
	width: 52.686%;
	max-width: 569px;
	margin: 0 -80px 0 0;
}

#about #contents .reason .reason_03 .inner .img {
	width: 49.213%;
	max-width: 532px;
	margin: 0 -30px 0 0;
}

#about #contents .reason .detail .inner .img p.sp_heading {
	display: none;
}

#about #contents .reason .reason_02 > .btn_01 {
	width: 300px;
	margin: 20px auto 0;
}


@media screen and (max-width: 768px){
	#about #contents .reason {
		padding: 4vh 0 1px;
	}
	
	#about #contents .reason section {
		margin: 0 0 6vh;
		padding: 0 20px;
	}
	
	#about #contents .reason section .inner {
		max-width: inherit;
	}
	
	#about #contents .reason .detail .inner {
		flex-flow: column-reverse nowrap;
		justify-content: space-between;
	}
	
	#about #contents .reason .detail .inner .box {
		width: auto;
		max-width: inherit;
		margin: 0 0 40px;
	}
	
	#about #contents .reason .detail .inner h3 {
		margin: 0 0 25px;
		text-align: center;
		font-size: 4.5vw;
	}
	
	#about #contents .reason .detail .inner h3 .num,
	#about #contents .reason .detail .inner h3 .txt {
		display: none;
	}
	
	#about #contents .reason .detail .inner h3 + p {
		margin: 0 0 40px;
		font-size: 3.7vw;
	}
	
	#about #contents .reason .detail .inner .img {
		width: auto;
		max-width: inherit;
	}
	
	#about #contents .reason .reason_01 .inner .img,
	#about #contents .reason .reason_02 .inner .img,
	#about #contents .reason .reason_03 .inner .img {
		margin: 0 0 40px;
	}
	
	#about #contents .reason .detail .inner .img p.sp_heading {
		display: block;
		text-align: center;
	}
	
	#about #contents .reason .detail .inner .img p.sp_heading .num {
		margin: 0 0 20px;
		display: block;
		color: #FBF5E3;
		font-size: 30vw;
		text-shadow: 
			 1px  1px 0px #008c3e,
			-1px  1px 0px #008c3e,
			 1px -1px 0px #008c3e,
			-1px -1px 0px #008c3e,
			 1px  0px 0px #008c3e,
			 0px  1px 0px #008c3e,
			-1px  0px 0px #008c3e,
			 0px -1px 0px #008c3e;
		line-height: 1.0;
	}
	
	#about #contents .reason .detail .inner .img p.sp_heading .txt {
		margin: 0 0 20px;
		display: block;
		color: var(--logo_green);
		font-size: 4.5vw;
		font-weight: 700;
	}
	
	#about #contents .reason .reason_02 > .btn_01 {
		width: 80%;
		max-width: 300px;
	}
	
	#about #contents .reason .reason_02 > .btn_01 a {
		padding: 15px 30px 18px 0;
		line-height: 1.5;
		position: relative;
	}
	
	#about #contents .reason .reason_02 > .btn_01 a .outer-circle {
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
	}
}


#about #contents .reason section aside {
	max-width: 1070px;
	margin: 60px auto 90px;
	padding: 50px min(75px, 6vw) 60px;
	background-color: #7DBB35;
	border-radius: 20px;
	position: relative;
}

#about #contents .reason section aside p.pickup {
	width: 90px;
	height: 90px;
	background-color: var(--logo_green);
	border-radius: 50%;
	position: absolute;
	left: min(80px, 6vw);
	top: -30px;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0;
}

#about #contents .reason section aside h4 {
	margin: 0 auto 45px;
	text-align: center;
}

#about #contents .reason section aside .box {
	padding: 30px min(50px, 5vw) 35px;
	background-color: #fff;
	border-radius: 20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0 min(60px, 6vw);
}

#about #contents .reason section aside .box p.img {
	width: 35.577%;
	max-width: 296px;
}

#about #contents .reason section aside .box .txt {
	width: 57.472%;
	max-width: 473px;
}

#about #contents .reason section aside .box .txt dl dt {
	margin: 0 0 10px;
}

#about #contents .reason section aside .box .txt dl dd {
	margin: 0 0 20px;
	font-size: min(16px, 1.6vw);
	line-height: 2.4;
}

#about #contents .reason section aside .box .txt dl dd span {
	font-size: min(12px, 1.1vw);
}
#about #contents .reason section aside .box .txt dl dd .txt-s {
	display: block;
    line-height: 1.5;
    text-indent: -1.5em;
    padding: 0 0 0 1.5em;
}
#about #contents .reason section aside .box .txt dl dd .txt01-s {
    margin: 10px 0 0;
}

#about #contents .reason section aside .box .txt .btn_01 {
	width: 300px;
}

#about #contents .reason section aside .box .txt .btn_01 a {
	padding: 15px 15px 18px 25px;
}


@media screen and (max-width: 768px){
	#about #contents .reason section aside {
		max-width: inherit;
		margin: 0 auto 6vh;
		padding: 60px 10px 30px;
		border-radius: 10px;
	}
	
	#about #contents .reason section aside p.pickup {
		display: none;
	}
	
	#about #contents .reason section aside h4 {
		margin: 0 auto 20px;
	}
	
	#about #contents .reason section aside .box {
		padding: 25px 20px 40px;
		border-radius: 10px;
		display: block;
	}
	
	#about #contents .reason section aside .box p.img {
		width: 96%;
		margin: 0 auto;
		max-width: inherit;
	}
	
	#about #contents .reason section aside .box .txt {
		width: auto;
		max-width: inherit;
	}
	
	#about #contents .reason section aside .box .txt dl dt {
		width: 70%;
		margin: 20px auto 15px;
	}
	
	#about #contents .reason section aside .box .txt dl dd {
		margin: 0 0 40px;
		font-size: min(16px, 3.7vw);
		line-height: 2.0;
	}
	
	#about #contents .reason section aside .box .txt dl dd span {
		font-size: min(12px, 2.8vw);
	}
	#about #contents .reason section aside .box .txt dl dd .txt-s {
        text-indent: -2.0em;
        padding: 0 0 0 2.0em;
    }
	#about #contents .reason section aside .box .txt .btn_01 {
		width: 90%;
	}
	
	#about #contents .reason section aside .box .txt .btn_01 a {
		padding: 10px 15px 12px;
		line-height: 1.5;
		position: relative;
	}
	
	#about #contents .reason section aside .box .txt .btn_01 a .outer-circle {
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
	}
}


#about #contents .reason section .plan {
	max-width: 1080px;
	margin: 0 auto 60px;
	padding: 0;
}

#about #contents .reason section .plan h4 {
	margin: 0 0 65px;
	text-align: center;
	color: var(--logo_green);
	font-size: 18px;
	font-weight: 700;
}

#about #contents .reason section .plan h4 em {
	font-size: 24px;
	font-style: normal;
}

#about #contents .reason section .plan ul {
	display: flex;
	justify-content: space-between;
	gap: 0 10px;
}

#about #contents .reason section .plan ul li {
	width: calc(100% / 3);
	max-width: 350px;
	padding: 50px 10px 30px;
	background-color: #fff;
	border-radius: 18px;
	position: relative;
}

#about #contents .reason section .plan ul li p.num {
	width: 70px;
	height: 70px;
	background-color: var(--logo_green);
	border-radius: 50%;
	position: absolute;
	left: calc(50% - 35px);
	top: -35px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.1;
}

#about #contents .reason section .plan ul li p.num span {
	display: block;
	font-size: 30px;
}

#about #contents .reason section .plan ul li dl dt {
	margin: 0 auto 20px;
	text-align: center;
	font-size: min(14px, 1.2vw);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.5;
}

#about #contents .reason section .plan ul li dl dt > span {
	display: inline-flex;
	align-items: center;
	gap: 0 5px;
}

#about #contents .reason section .plan ul li dl dt span .color {
	color: var(--logo_green);
}

#about #contents .reason section .plan ul li dl dt em {
	font-size: min(27px, 2.4vw);
	font-style: normal;
	letter-spacing: 0.05;
}

#about #contents .reason section .plan ul li dl dt b {
	font-size: min(17px, 1.5vw);
}

#about #contents .reason section .plan ul li dl dd {
	width: 71.429%;
	max-width: 250px;
	margin: 0 auto;
}


@media screen and (max-width: 768px){
	#about #contents .reason section .plan {
		max-width: inherit;
		margin: 0 auto 4vh;
		padding: 0;
		display: none;
	}
	
	#about #contents .reason section .plan h4 {
		margin: 0 0 65px;
		text-align: center;
		color: var(--logo_green);
		font-size: min(18px, 3.8vw);
	}
	
	#about #contents .reason section .plan h4 em {
		font-size: min(24px, 5vw);
		line-height: 1.3;
	}
	
	#about #contents .reason section .plan ul {
		flex-flow: column nowrap;
		gap: 50px 0;
	}
	
	#about #contents .reason section .plan ul li {
		width: auto;
		max-width: inherit;
		padding: 50px 10px 30px;
	}
	
	#about #contents .reason section .plan ul li dl dt {
		font-size: min(14px, 3.2vw);
	}
	
	#about #contents .reason section .plan ul li dl dt > span {
		gap: 0 2px;
	}
	
	#about #contents .reason section .plan ul li dl dt em {
		font-size: min(27px, 6vw);
	}
	
	#about #contents .reason section .plan ul li dl dt b {
		font-size: min(17px, 3.8vw);
	}
	
	#about #contents .reason section .plan ul li dl dd {
		width: 80%;
		max-width: 250px;
		margin: 0 auto;
	}
}



/*===============================================================

		#about #contents .showroom layout

===============================================================*/

#about #contents .reason .showroom {
	margin: 40px 0 0;
	padding: 0 20px;
}

#about #contents .showroom .inner {
	max-width: 1092px;
	padding: 45px min(45px, 4vw) 60px;
	background-color: #fff;
	border-radius: 36px;
	position: relative;
}

#about #contents .showroom .inner::before {
	content: "";
	width: 177px;
	height: 178px;
	background: url("../../img/top/img18.svg") left top / cover no-repeat;
	position: absolute;
	right: 90px;
	top: -30px;
	z-index: 2;
}

#about #contents .showroom .inner h3 {
	margin: 0 0 40px;
	text-align: center;
	font-size: 24px;
	font-weight: 700;
	line-height: 2.1;
}

#about #contents .showroom .inner ul {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}

#about #contents .showroom .inner ul li {
	width: 31.4%;
	max-width: 314px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.4;
}

#about #contents .showroom .inner ul li dl dt {
	margin: 18px 0 15px;
	font-weight: 700;
}

#about #contents .showroom .inner ul li dl dd.address {
	margin: 0 0 15px;
	display: inline-flex;
	align-items: center;
	gap: 0 10px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0;
}

#about #contents .showroom .inner ul li dl dd.address span {
	padding: 3px 10px 5px;
	background-color: #fff;
	border: solid 1px var(--logo_green);
	border-radius: 20px;
	display: block;
	color: var(--logo_green);
	font-size: 12px;
	line-height: 1.0;
	transition: all 0.3s;
}

#about #contents .showroom .inner ul li a:hover img {
	opacity: 0.8;
}

#about #contents .showroom .inner ul li dl dd.address span:hover {
	background-color: var(--logo_green);
	color: #fff;
}


@media screen and (max-width: 768px){
	#about #contents .reason .showroom {
		margin: 4vh 0 6vh;
		padding: 0 20px;
	}
	
	#about #contents .showroom .inner {
		max-width: inherit;
		padding: 80px 20px 60px;
		border-radius: 20px;
	}
	
	#about #contents .showroom .inner::before {
		width: 100px;
		height: 100px;
		right: auto;
		left: calc(50% - 50px);
		top: -50px;
	}
	
	#about #contents .showroom .inner h3 {
		margin: 0 20px 20px;
		text-align: left;
		font-size: min(22px, 4.4vw);
		line-height: 2.4;
	}
	
	#about #contents .showroom .inner ul {
		display: flex;
		flex-flow: column wrap;
		justify-content: flex-start;
		gap: 4vh 0;
	}
	
	#about #contents .showroom .inner ul li {
		width: auto;
		max-width: inherit;
		text-align: center;
		font-size: min(18px, 4.3vw);
	}
	
	#about #contents .showroom .inner ul li p {
		width: 80%;
		max-width: 314px;
		margin: 0 auto;
	}
	
	#about #contents .showroom .inner ul li dl dt {
		margin: 15px 0 15px;
	}
	
	#about #contents .showroom .inner ul li dl dd.address {
		text-align: left;
		gap: 0 10px;
		font-size: min(15px, 3.6vw);
		font-weight: 700;
	}
	
	#about #contents .showroom .inner ul li dl dd.address a {
		font-size: min(12px, 3.0vw);
	}
	
	#about #contents .showroom .inner ul li dl dd.tel {
		font-size: min(15px, 3.6vw);
		font-weight: 700;
	}
}



/*===============================================================

		#about #contents .message layout

===============================================================*/

#about #contents .message {
	padding: 115px 40px 120px;
	background: url("../../img/about/bg02.png") left top / 100% auto no-repeat #D8E9A9;
}

#about #contents .message h3 {
	margin: 0 0 40px;
	text-align: center;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.0;
}

#about #contents .message h3 .en {
	margin: 0 0 20px;
	display: block;
	color: var(--logo_green);
	font-size: 32px;
	font-weight: 800;
	letter-spacing: 0;
}

#about #contents .message .inner {
	max-width: 1040px;
	display: flex;
	justify-content: space-between;
}

#about #contents .message .inner p.img {
	width: 46.827%;
	max-width: 487px;
}

#about #contents .message .inner .txt {
	width: 46.154%;
	max-width: 480px;
}

#about #contents .message .inner .txt p {
	margin: 0 auto 40px;
	text-align: center;
}

#about #contents .message .inner .txt p img {
	max-width: 290px;
}

#about #contents .message .inner .txt p span {
	margin: 10px 0 0;
	display: block;
	color: var(--logo_green);
	font-size: min(33px, 3.2vw);
	font-weight: 700;
	letter-spacing: 0;
}

#about #contents .message .inner .txt dl dt {
	margin: 0 auto 20px;
	color: var(--logo_green);
	font-size: min(24px, 2.4vw);
	font-weight: 700;
	letter-spacing: 0;
}

#about #contents .message .inner .txt dl dd {
	font-size: min(16px, 1.6vw);
	line-height: 2.5;
}


@media screen and (max-width: 768px){
	#about #contents .message {
		padding: 10vh 20px 12vh;
		background: #D8E9A9;
	}
	
	#about #contents .message h3 {
		margin: 0 0 20px;
		text-align: center;
		font-size: min(32px, 7vw);
	}
	
	#about #contents .message h3 .en {
		margin: 0 0 10px;
		font-size: min(32px, 7vw);
	}
	
	#about #contents .message .inner {
		max-width: inherit;
		display: block;
	}
	
	#about #contents .message .inner p.img {
		width: auto;
		max-width: inherit;
		margin: 0 0 40px;
	}
	
	#about #contents .message .inner .txt {
		width: auto;
		max-width: inherit;
	}
	
	#about #contents .message .inner .txt p {
		margin: 0 auto 30px;
	}
	
	#about #contents .message .inner .txt p img {
		width: 65%;
		max-width: inherit;
	}
	
	#about #contents .message .inner .txt p span {
		margin: 10px 0 0;
		font-size: 6.2vw;
	}
	
	#about #contents .message .inner .txt dl dt {
		margin: 0 auto 20px;
		text-align: center;
		font-size: min(24px, 5vw);
	}
	
	#about #contents .message .inner .txt dl dd {
		font-size: min(16px, 3.7vw);
		line-height: 2.0;
	}
}



/*===============================================================

		#about footer layout

===============================================================*/

#about footer {
	margin: 0;
	background: url("../img/footer_bg02.png") left top / 100% auto no-repeat var(--green_03);
}



@media screen and (max-width: 768px){
	#about footer {
		margin: 0;
		background: url("../img/sp/footer_bg02.png") left top / 100% auto no-repeat var(--green_03);
	}
}





/*====================================================================================

		#products layout

====================================================================================*/

/*===============================================================

		#products #contents .catch layout

===============================================================*/

#products #contents .catch {
	padding: 0 20px;
}

#products #contents .catch .inner {
	max-width: 1338px;
	margin: 0 auto;
	position: relative;
}

#products #contents .catch .inner p.txt {
	position: absolute;
	left: min(45px, 3vw);
	top: 20px;
	color: var(--logo_green);
	font-size: min(32px, 2.6vw);
	font-weight: 700;
	letter-spacing: 0;
}


@media screen and (max-width: 768px){
	#products #contents .catch {
		padding: 0;
		overflow: hidden;
	}
	
	#products #contents .catch .inner {
		max-width: inherit;
	}
	
	#products #contents .catch .inner p.img {
		width: 170%;
		margin-left: -6%;
		overflow: hidden;
	}
	
	#products #contents .catch .inner p.txt {
		margin: 5vh 20px;
		position: static;
		font-size: min(32px, 6vw);
	}
}



/*===============================================================

		#products #contents .list layout

===============================================================*/

#products #contents .list {
	margin: 160px 0 100px;
	padding: 0 20px;
}

#products #contents .list .inner {
	max-width: 1280px;
	padding: 0;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0 min(50px, 5vw);
}

#products #contents .list .inner .page_nav {
	width: 270px;
	flex-shrink: 0;
	position: sticky;
	top: 120px;
}

#products #contents .list .inner .page_nav ul li {
	margin: 0 0 10px;
}

#products #contents .list .inner .page_nav ul li a {
	width: 100%;
	padding: 15px 28px;
	background-color: #fff;
	border-radius: 64px;
	display: inline-flex;
	justify-content: space-between;
	align-items: center;
	font-weight: 700;
	letter-spacing: 0;
}

#products #contents .list .inner .page_nav p {
	width: 235px;
	margin: 75px auto 0;
}


/*==================== .detail ====================*/

#products #contents .list .inner .wrapper {
	width: 74.22%;
	max-width: 952px;
}

#products #contents .list .inner .detail {
	margin: 0 0 80px;
	padding: calc(100%*412/1904) min(40px, 4vw) 80px min(60px, 6vw);
	border-radius: 20px;
}

#products #contents .list .inner .detail h3 {
	margin: -120px 0 30px;
	padding: 160px 0 0;
	text-align: center;
	font-size: min(36px, 3.6vw);
	font-weight: 700;
	line-height: 1.0;
	letter-spacing: 0.05em;
}

#products #contents .list .inner .detail h3 .en {
	margin: 20px 0 0;
	display: block;
	color: var(--logo_green);
	font-size: min(20px, 2.0vw);
	font-weight: 800;
	letter-spacing: 0;
}

#products #contents .list .inner .detail .heading {
	margin: 0 0 50px;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
}

#products #contents .list .inner .detail .heading p.img {
	width: 40%;
}

#products #contents .list .inner .detail .heading dl {
	width: 55%;
	padding: 0 10px;
}

#products #contents .list .inner .detail .heading dl dt {
	margin: 0 0 20px;
	font-size: min(22px, 2.2vw);
	font-weight: 800;
	letter-spacing: 0;
}

#products #contents .list .inner .detail .heading dl dt span {
	display: block;
	font-size: min(16px, 1.6vw);
	line-height: 2.1;
}

#products #contents .list .inner .detail .heading dl dd {
	font-size: min(16px, 1.6vw);
	line-height: 2.1;
	letter-spacing: 0;
}

#products #contents .list .inner .detail .heading dl dd em {
	color: var(--logo_green);
	font-weight: 500;
}


@media screen and (max-width: 768px){
	#products #contents .list {
		margin: 0;
		padding: 0 10px;
		background: none;
	}
	
	#products #contents .list .inner {
		max-width: inherit;
		display: block;
	}
	
	#products #contents .list .inner .page_nav {
		display: none;
	}
	
	
	/*==================== .detail ====================*/
	
	#products #contents .list .inner .wrapper {
		width: auto;
		max-width: inherit;
	}
	
	#products #contents .list .inner .detail {
		margin: 0 0 6vh;
		padding: calc(100%*268/700) 20px 40px;
	}
	
	#products #contents .list .inner .detail h3 {
		margin: -80px 0 30px;
		padding: 110px 0 0;
		font-size: min(36px, 7vw);
	}
	
	#products #contents .list .inner .detail h3 .en {
		margin: 15px 0 0;
		font-size: min(20px, 4vw);
	}
	
	#products #contents .list .inner .detail .heading {
		margin: 0 0 5vh;
		flex-direction: column;
		gap: 3vh 0;
	}
	
	#products #contents .list .inner .detail .heading p.img {
		width: 50%;
		margin: 0 auto;
	}
	
	#products #contents .list .inner .detail .heading dl {
		width: auto;
		padding: 0;
	}
	
	#products #contents .list .inner .detail .heading dl dt {
		font-size: min(22px, 4.5vw);
	}
	
	#products #contents .list .inner .detail .heading dl dt span {
		font-size: min(16px, 3.7vw);
	}
	
	#products #contents .list .inner .detail .heading dl dd {
		font-size: min(16px, 3.7vw);
	}
}



/*==================== .products_01 ====================*/

#products #contents .list .inner .products_01 {
	background: url("../../img/products/img03.jpg") left top / 100% auto no-repeat var(--beige);
}

#products #contents .list .inner .products_01 ul.example {
	margin: 0 0 90px;
	display: flex;
	justify-content: space-between;
	gap: 0 15px;
}

#products #contents .list .inner .products_01 ul.example li {
	width: calc(100% / 3);
	padding: 20px 0 30px;
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}

#products #contents .list .inner .products_01 ul.example li dl dt {
	margin: 0 0 20px;
	text-align: center;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}

#products #contents .list .inner .products_01 ul.example li dl dt span {
	display: block;
	color: var(--logo_green);
	font-size: min(24px, 2.4vw);
}

#products #contents .list .inner .products_01 ul.example li dl dd.img {
	margin: 0 0 20px;
	text-align: center;
}

#products #contents .list .inner .products_01 ul.example li dl dd.txt {
	margin: 0 20px;
	font-size: min(16px, 1.6vw);
	letter-spacing: 0;
}


#products #contents .list .inner .products_01 section h4 {
	margin: 0 0 40px;
	text-align: center;
	font-size: min(36px, 3.6vw);
	font-weight: 700;
	line-height: 1.0;
	letter-spacing: 0.05em;
}

#products #contents .list .inner .products_01 section h4 .green {
	margin: 0 0 15px;
	display: block;
	color: var(--logo_green);
	font-size: min(20px, 2.0vw);
	font-weight: 700;
	letter-spacing: 0;
}

#products #contents .list .inner .products_01 section h4 .en {
	margin: 20px 0 0;
	display: block;
	color: var(--logo_green);
	font-size: min(20px, 2.0vw);
	font-weight: 800;
	letter-spacing: 0;
}

#products #contents .list .inner .products_01 section h4 .ja {
  font-family: "Zen Maru Gothic", serif;
}

#products #contents .list .inner .products_01 section .box {
	margin: 0 0 10px;
	padding: 0 min(30px, 3vw);
	display: flex;
	justify-content: space-between;
	gap: 0 15px;
}

#products #contents .list .inner .products_01 section .box p.img {
	width: 39.9%;
	max-width: 300px;
}

#products #contents .list .inner .products_01 section .box p.txt {
	width: 55.3%;
	max-width: 415px;
	margin: 0 0 20px;
	font-size: min(16px, 1.6vw);
	line-height: 2.0;
}

#products #contents .list .inner .products_01 section .box p.txt span {
	display: inline-block;
	font-size: 12px;
	line-height: 1.5;
}
#products #contents .list .inner .products_01 section .box p.txt .txt-s{
    text-indent: -1.5em;
    padding: 0 0 0 1.5em;
}

#products #contents .list .inner .products_01 section .point {
	margin: 0 0 60px;
	padding: 30px min(40px, 4vw);
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 25px;
}

#products #contents .list .inner .products_01 section .point ol li {
	margin: 0 0 20px;
	display: flex;
	align-items: center;
	gap: 30px min(30px, 3vw);
	font-size: min(20px, 2.0vw);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}

#products #contents .list .inner .products_01 section .point ol li em {
	color: var(--logo_green);
}

#products #contents .list .inner .products_01 section .point p.img {
	width: 22.5%;
	max-width: 161px;
	flex-shrink: 0;
}

#products #contents .list .inner .products_01 section .btn_02 {
	width: 360px;
	margin: 0 auto;
}

#products #contents .list .inner .products_01 section .btn_02 a {
	width: 100%;
	padding: 25px 20px;
	background-color: #fff;
	border: solid 1px var(--logo_green);
	border-radius: 60px;
	box-shadow: 5px 7px 0 var(--logo_green);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0 10px;
	text-align: center;
	color: var(--logo_green);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.0;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#products #contents .list .inner .products_01 section .btn_02 a:hover {
	transform: translateY(4px);
	box-shadow: 5px 3px 0 var(--logo_green);
}


@media screen and (max-width: 1200px){
	#products #contents .list .inner .products_01 ul.example {
		flex-flow: column wrap;
		gap: 15px 0;
	}
	
	#products #contents .list .inner .products_01 ul.example li {
		width: auto;
	}
}


@media screen and (max-width: 768px){
	#products #contents .list .inner .products_01 {
		background: url("../../img/products/sp/img03.jpg") left top / 100% auto no-repeat var(--beige);
	}
	
	#products #contents .list .inner .products_01 .heading p.img {
		transform: translateX(-10px);
	}
	
	#products #contents .list .inner .products_01 ul.example {
		margin: 0 0 6vh;
	}
	
	#products #contents .list .inner .products_01 ul.example li {
		padding: 20px;
	}
	
	#products #contents .list .inner .products_01 ul.example li dl dt {
		margin: 0 0 20px;
		text-align: center;
		font-size: min(14px, 3.2vw);
		font-weight: 700;
		line-height: 1.5;
		letter-spacing: 0;
	}
	
	#products #contents .list .inner .products_01 ul.example li dl dt span {
		display: block;
		color: var(--logo_green);
		font-size: min(24px, 6vw);
	}
	
	#products #contents .list .inner .products_01 ul.example li dl dd.img {
		margin: 0 0 20px;
		text-align: center;
	}
	
	#products #contents .list .inner .products_01 ul.example li dl dd.txt {
		margin: 0;
		font-size: min(16px, 3.7vw);
	}
	#products #contents .list .inner .products_01 section .box p.txt .txt-s{
        text-indent: -2.0em;
        padding: 0 0 0 2.0em;
    }
	
	#products #contents .list .inner .products_01 section h4 {
		font-size: min(36px, 6vw);
	}
	
	#products #contents .list .inner .products_01 section h4 .green {
		font-size: min(20px, 4vw);
	}
	
	#products #contents .list .inner .products_01 section h4 .en {
		font-size: min(14px, 3.2vw);
	}
	
	#products #contents .list .inner .products_01 section .box {
		margin: 0 0 6vh;
		padding: 0 min(30px, 3vw);
		display: block;
	}
	
	#products #contents .list .inner .products_01 section .box p.img {
		width: auto;
		max-width: inherit;
		margin: 0 0 20px;
	}
	
	#products #contents .list .inner .products_01 section .box p.txt {
		width: auto;
		max-width: inherit;
		font-size: min(16px, 3.7vw);
	}
	
	#products #contents .list .inner .products_01 section .point {
		margin: 0 0 4vh;
		padding: 20px 15px;
		display: block;
	}
	
	#products #contents .list .inner .products_01 section .point ol li {
		margin: 0 0 20px;
		align-items: flex-start;
		gap: 20px 10px;
		font-size: min(20px, 4.0vw);
	}
	
	#products #contents .list .inner .products_01 section .point ol li img {
		transform: translateY(-6px);
	}
	
	#products #contents .list .inner .products_01 section .point p.img {
		width: 60%;
		max-width: 161px;
		margin: 0 auto;
	}
	
	#products #contents .list .inner .products_01 section .btn_02 {
		width: 90%;
	}
	
	#products #contents .list .inner .products_01 section .btn_02 a {
		padding: 15px 0;
		position: relative;
		font-size: 3.7vw;
		line-height: 1.5;
	}
	
	#products #contents .list .inner .products_01 section .btn_02 a:hover {
		transform: translateY(0);
		box-shadow: 5px 7px 0 var(--logo_green);
	}
	
	#products #contents .list .inner .products_01 section .btn_02 svg {
		position: absolute;
		right: 20px;
		top: 50%;
		transform: translateY(-50%);
	}
}




/*==================== .products_02 ====================*/

#products #contents .list .inner .products_02 {
	background: url("../../img/products/img10.jpg") left top / 100% auto no-repeat var(--beige);
}

#products #contents .list .inner .products_02 .plan .title {
	margin: 0 0 40px;
	text-align: center;
}

#products #contents .list .inner .products_02 .plan h4 {
	display: inline-block;
	position: relative;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}

#products #contents .list .inner .products_02 .plan h4::before {
	content: "";
	width: 77px;
	height: 95px;
	background: url("../../img/products/img12.png") left top / 100% auto no-repeat;
	position: absolute;
	left: -120px;
	top: -20px;
}

#products #contents .list .inner .products_02 .plan h4::after {
	content: "";
	width: 48px;
	height: 93px;
	background: url("../../img/products/img13.svg") left top / 100% auto no-repeat;
	position: absolute;
	right: -90px;
	top: -20px;
}

#products #contents .list .inner .products_02 .plan h4 > span {
	display: block;
	color: var(--logo_green);
	font-size: min(24px, 2.4vw);
}

#products #contents .list .inner .products_02 .plan h4 span .line {
	display: inline-block;
	position: relative;
}

#products #contents .list .inner .products_02 .plan h4 span .line::after {
	content: "";
	width: 100%;
	height: 4px;
	background: url("../../img/products/bg01.svg") left top / auto repeat-x;
	position: absolute;
	left: 0;
	bottom: -3px;
}

#products #contents .list .inner .products_02 .plan ul {
	display: flex;
	justify-content: space-between;
	gap: 0 15px;
}

#products #contents .list .inner .products_02 .plan ul li {
	width: calc(100% / 2);
	padding: 20px 0 30px;
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}

#products #contents .list .inner .products_02 .plan ul li dl dt {
	margin: 0 0 20px;
	text-align: center;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}

#products #contents .list .inner .products_02 .plan ul li dl dt span {
	display: block;
	color: var(--logo_green);
	font-size: min(24px, 2.4vw);
}

#products #contents .list .inner .products_02 .plan ul li dl dd.img {
	margin: 0 0 20px;
	text-align: center;
}

#products #contents .list .inner .products_02 .plan ul li dl dd.txt {
	margin: 0 min(50px, 5vw);
	font-size: min(16px, 1.6vw);
	letter-spacing: 0;
}


@media screen and (max-width: 1000px){
	#products #contents .list .inner .products_02 .plan ul li dl dd.txt {
		margin: 0 min(20px, 3vw);
	}
}


@media screen and (max-width: 920px){
	#products #contents .list .inner .products_02 .plan h4::before {
		left: -90px;
	}
	
	#products #contents .list .inner .products_02 .plan h4::after {
		right: -60px;
	}
}


@media screen and (max-width: 768px){
	#products #contents .list .inner .products_02 {
		background: url("../../img/products/sp/img10.jpg") left top / 100% auto no-repeat var(--beige);
	}
	
	#products #contents .list .inner .products_02 .plan {
		padding: 40px 0 0;
	}
	
	#products #contents .list .inner .products_02 .plan .title {
		margin: 0 0 40px;
		text-align: center;
	}
	
	#products #contents .list .inner .products_02 .plan h4 {
		font-size: min(14px, 3.2vw);
	}
	
	#products #contents .list .inner .products_02 .plan h4::before {
		width: 50px;
		height: 62px;
		left: -10px;
		top: -40px;
	}
	
	#products #contents .list .inner .products_02 .plan h4::after {
		width: 35px;
		height: 68px;
		right: -10px;
		top: -45px;
	}
	
	#products #contents .list .inner .products_02 .plan h4 > span {
		font-size: min(24px, 5.5vw);
	}
	
	#products #contents .list .inner .products_02 .plan ul {
		flex-flow: column wrap;
		gap: 15px 0;
	}
	
	#products #contents .list .inner .products_02 .plan ul li {
		width: auto;
		padding: 20px;
	}
	
	#products #contents .list .inner .products_02 .plan ul li dl dt {
		margin: 0 0 20px;
		text-align: center;
		font-size: min(14px, 3.2vw);
		font-weight: 700;
		line-height: 1.5;
		letter-spacing: 0;
	}
	
	#products #contents .list .inner .products_02 .plan ul li dl dt span {
		display: block;
		color: var(--logo_green);
		font-size: min(24px, 6vw);
	}
	
	#products #contents .list .inner .products_02 .plan ul li dl dd.img {
		margin: 0 0 20px;
		text-align: center;
	}
	
	#products #contents .list .inner .products_02 .plan ul li dl dd.txt {
		margin: 0;
		font-size: min(16px, 3.7vw);
	}
}



/*==================== .products_03 ====================*/

#products #contents .list .inner .products_03 {
	background: url("../../img/products/img16.jpg") left top / 100% auto no-repeat var(--beige);
}

#products #contents .list .inner .products_03 .point {
	margin: 0 0 60px;
}

#products #contents .list .inner .products_03 .point ul {
	display: flex;
	justify-content: space-between;
	gap: 0 15px;
}

#products #contents .list .inner .products_03 .point ul li {
	width: calc(100% / 2);
	padding: 20px 0 30px;
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}

#products #contents .list .inner .products_03 .plan ul li {
	width: 100%;
	padding: 40px 0;
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}

#products #contents .list .inner .products_03 .point ul li dl dt,
#products #contents .list .inner .products_03 .plan ul li dl dt {
	margin: 0 0 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	color: var(--logo_green);
	font-size: min(24px, 2.2vw);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}

#products #contents .list .inner .products_03 .point ul li dl dd.img {
	width: 80%;
	max-width: 206px;
	margin: 0 auto 20px;
	text-align: center;
}

#products #contents .list .inner .products_03 .plan ul li dl dd.img {
	width: 80%;
	max-width: 494px;
	margin: 0 auto 20px;
	text-align: center;
}

#products #contents .list .inner .products_03 .point ul li dl dd.txt {
	margin: 0 20px;
	font-size: min(16px, 1.6vw);
	letter-spacing: 0;
}

#products #contents .list .inner .products_03 .plan ul li dl dd.txt {
	margin: 0 min(80px, 6vw);
	font-size: min(16px, 1.6vw);
	letter-spacing: 0;
}


#products #contents .list .inner .products_03 .plan .title {
	margin: 0 0 40px;
	text-align: center;
}

#products #contents .list .inner .products_03 .plan h4 {
	display: inline-block;
	position: relative;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}

#products #contents .list .inner .products_03 .plan h4::before {
	content: "";
	width: 77px;
	height: 95px;
	background: url("../../img/products/img12.png") left top / 100% auto no-repeat;
	position: absolute;
	left: -120px;
	top: -20px;
}

#products #contents .list .inner .products_03 .plan h4::after {
	content: "";
	width: 48px;
	height: 93px;
	background: url("../../img/products/img13.svg") left top / 100% auto no-repeat;
	position: absolute;
	right: -90px;
	top: -20px;
}

#products #contents .list .inner .products_03 .plan h4 > span {
	display: block;
	color: var(--logo_green);
	font-size: min(24px, 2.4vw);
}

#products #contents .list .inner .products_03 .plan h4 span .line {
	display: inline-block;
	position: relative;
}

#products #contents .list .inner .products_03 .plan h4 span .line::after {
	content: "";
	width: 100%;
	height: 4px;
	background: url("../../img/products/bg01.svg") left top / auto repeat-x;
	position: absolute;
	left: 0;
	bottom: -3px;
}


@media screen and (max-width: 1040px){
	#products #contents .list .inner .products_03 .plan h4::before {
		left: -90px;
	}
	
	#products #contents .list .inner .products_03 .plan h4::after {
		right: -60px;
	}
}

@media screen and (max-width: 960px){
	#products #contents .list .inner .products_03 .plan h4 br.pc_none {
		display: inline;
	}
	
	#products #contents .list .inner .products_03 .plan h4::before {
		left: -100px;
		top: auto;
		bottom: 0;
	}
	
	#products #contents .list .inner .products_03 .plan h4::after {
		right: -70px;
		top: auto;
		bottom: 0;
	}
}


@media screen and (max-width: 768px){
	#products #contents .list .inner .products_03 {
		background: url("../../img/products/sp/img16.jpg") left top / 100% auto no-repeat var(--beige);
	}
	
	#products #contents .list .inner .products_03 .point {
		margin: 0 0 40px;
	}
	
	#products #contents .list .inner .products_03 .plan {
		padding: 40px 0 0;
	}
	
	#products #contents .list .inner .products_03 .plan .title {
		margin: 0 0 40px;
		text-align: center;
	}
	
	#products #contents .list .inner .products_03 .plan h4 {
		font-size: min(14px, 3.2vw);
	}
	
	#products #contents .list .inner .products_03 .plan h4::before {
		width: 50px;
		height: 62px;
		left: -60px;
	}
	
	#products #contents .list .inner .products_03 .plan h4::after {
		width: 35px;
		height: 68px;
		right: -60px;
	}
	
	#products #contents .list .inner .products_03 .plan h4 > span {
		font-size: min(24px, 5.5vw);
	}
	
	#products #contents .list .inner .products_03 .point ul {
		flex-flow: column wrap;
		gap: 15px 0;
	}
	
	#products #contents .list .inner .products_03 .point ul li {
		width: auto;
		padding: 20px;
	}
	
	#products #contents .list .inner .products_03 .plan ul li {
		padding: 20px 0;
	}
	
	#products #contents .list .inner .products_03 .point ul li dl dt,
	#products #contents .list .inner .products_03 .plan ul li dl dt {
		margin: 0 0 20px;
		text-align: center;
		color: var(--logo_green);
		font-size: min(24px, 5vw);
		font-weight: 700;
		line-height: 1.5;
		letter-spacing: 0;
	}
	
	#products #contents .list .inner .products_03 .point ul li dl dd.img {
		width: 80%;
		max-width: 206px;
	}
	
	#products #contents .list .inner .products_03 .plan ul li dl dd.img {
		width: 90%;
		max-width: 494px;
	}
	
	#products #contents .list .inner .products_03 .point ul li dl dd.txt {
		margin: 0;
		font-size: min(16px, 3.7vw);
	}
	
	#products #contents .list .inner .products_03 .plan ul li dl dd.txt {
		margin: 0 20px;
		font-size: min(16px, 3.7vw);
	}
}



/*==================== .products_04 ====================*/

#products #contents .list .inner .products_04 {
	margin: 0 0 80px;
	padding: 50px min(40px, 4vw) 80px min(60px, 6vw);
	background: #fff;
}

#products #contents .list .inner .products_04 h3 {
	margin: -120px 0 60px;
}

#products #contents .list .inner .products_04 h3 .green {
	margin: 0 0 20px;
	display: block;
	color: var(--logo_green);
	font-size: min(20px, 2.0vw);
	font-weight: 700;
	letter-spacing: 0;
}

#products #contents .list .inner .products_04 ul.item {
	margin: 0 0 80px;
	padding: 40px min(60px, 4vw);
	background-color: #FFFAEC;
	border-radius: 14px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px min(40px, 4vw);
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}

#products #contents .list .inner .products_04 ul.item li .name {
	margin: 0 0 20px;
	display: flex;
	align-items: center;
	gap: 0 10px;
}

#products #contents .list .inner .products_04 ul.item li .name p.img {
	width: 45%;
	max-width: 120px;
}

#products #contents .list .inner .products_04 ul.item li .name p.txt {
	font-size: min(24px, 2.0vw);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: 0;
}

#products #contents .list .inner .products_04 ul.item li .name p.txt .en {
	margin: 10px 0 0;
	display: block;
	color: var(--logo_green);
	font-size: min(16px, 1.6vw);
}

#products #contents .list .inner .products_04 ul.item li dl dt {
	margin: 0 0 10px;
	font-size: min(18px, 1.8vw);
	font-weight: 700;
	letter-spacing: 0;
}

#products #contents .list .inner .products_04 ul.item li dl dd {
	font-size: min(16px, 1.6vw);
	letter-spacing: 0;
}


#products #contents .list .inner .products_04 .plan .title {
	margin: 0 0 30px;
	text-align: center;
}

#products #contents .list .inner .products_04 .plan h4 {
	display: inline-block;
	position: relative;
	color: var(--logo_green);
	font-weight: 700;
	letter-spacing: 0;
}

#products #contents .list .inner .products_04 .plan h4::before {
	content: "";
	width: 69px;
	height: 94px;
	background: url("../../img/products/img24.png") left top / 100% auto no-repeat;
	position: absolute;
	left: -100px;
	top: -20px;
}

#products #contents .list .inner .products_04 .plan h4::after {
	content: "";
	width: 48px;
	height: 93px;
	background: url("../../img/products/img13.svg") left top / 100% auto no-repeat;
	position: absolute;
	right: -70px;
	top: 10px;
}

#products #contents .list .inner .products_04 .plan h4 > span {
	display: block;
	font-size: min(24px, 2.4vw);
}

#products #contents .list .inner .products_04 .plan ul {
	padding: 65px min(40px, 3vw);
	background-color: #FFFAEC;
	border-radius: 14px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0 min(35px, 3vw);
	box-shadow: 0 3px 12px rgba(0,0,0,0.16);
}

#products #contents .list .inner .products_04 .plan ul li {
	
}

#products #contents .list .inner .products_04 .plan ul li dl dt {
	margin: 0 auto 20px;
	/*
	display: flex;
	flex-flow: column nowrap;
	justify-content: center;
	align-items: center;
	*/
	text-align: center;
	font-size: min(14px, 1.2vw);
	letter-spacing: 0;
	line-height: 1.5;
}

#products #contents .list .inner .products_04 .plan ul li dl dt .txt {
	display: inline-flex;
	align-items: center;
}

#products #contents .list .inner .products_04 .plan ul li dl dt .name {
	margin: 10px -20px 0;
	display: inline-flex;
	align-items: center;
	gap: 0 5px;
	font-weight: 700;
	line-height: 1.1;
}

#products #contents .list .inner .products_04 .plan ul li dl dt .name .color {
	color: var(--logo_green);
}

#products #contents .list .inner .products_04 .plan ul li dl dt em {
	font-size: min(24px, 2.0vw);
	font-style: normal;
	letter-spacing: 0.05;
}

#products #contents .list .inner .products_04 .plan ul li dl dt b {
	font-size: min(18px, 1.5vw);
}

#products #contents .list .inner .products_04 .plan ul li dl dd {
	width: 100%;
	max-width: 220px;
	margin: 0 auto;
}


@media screen and (max-width: 1100px){
	#products #contents .list .inner .products_04 .plan ul {
		grid-template-columns: 1fr;
		gap: 40px 0;
	}
}

@media screen and (max-width: 1040px){
	#products #contents .list .inner .products_04 .plan h4 br.pc_none {
		display: inline;
	}
	
	#products #contents .list .inner .products_04 .plan h4::before {
		left: -90px;
		top: 0;
	}
	
	#products #contents .list .inner .products_04 .plan h4::after {
		right: -60px;
		top: 0;
	}
}


@media screen and (max-width: 1000px){
	#products #contents .list .inner .products_04 ul.item {
		grid-template-columns: 1fr;
		gap: 40px 0;
	}
}


@media screen and (max-width: 768px){
	#products #contents .list .inner .products_04 {
		margin: 0 0 6vh;
		padding: 20px 20px 40px;
	}
	
	#products #contents .list .inner .products_04 h3 {
		margin: -80px 0 40px;
	}
	
	#products #contents .list .inner .products_04 h3 .green {
		margin: 0 0 20px;
		font-size: min(20px, 4.0vw);
	}
	
	#products #contents .list .inner .products_04 ul.item {
		padding: 30px 20px;
		gap: 4vh 0;
	}
	
	#products #contents .list .inner .products_04 ul.item li .name {
		gap: 0 15px;
	}
	
	#products #contents .list .inner .products_04 ul.item li .name p.img {
		width: 35%;
		max-width: 120px;
	}
	
	#products #contents .list .inner .products_04 ul.item li .name p.txt {
		font-size: min(24px, 4.7vw);
	}
	
	#products #contents .list .inner .products_04 ul.item li .name p.txt .en {
		font-size: min(16px, 3.7vw);
	}
	
	#products #contents .list .inner .products_04 ul.item li dl dt {
		font-size: min(18px, 4.2vw);
	}
	
	#products #contents .list .inner .products_04 ul.item li dl dd {
		font-size: min(16px, 3.7vw);
	}
	
	
	#products #contents .list .inner .products_04 .plan .title {
		margin: 0 0 30px;
		text-align: center;
	}
	
	#products #contents .list .inner .products_04 .plan h4 {
		font-size: min(14px, 3.2vw);
	}
	
	#products #contents .list .inner .products_04 .plan h4::before {
		width: 60px;
		height: 82px;
		left: -40px;
	}
	
	#products #contents .list .inner .products_04 .plan h4::after {
		width: 40px;
		height: 78px;
		right: -40px;
		top: 5%;
	}
	
	#products #contents .list .inner .products_04 .plan h4 > span {
		font-size: min(24px, 5.5vw);
		line-height: 1.5;
	}
	
	
	#products #contents .list .inner .products_04 .plan ul {
		padding: 30px 20px;
		gap: 4vh 0;
	}
	
	#products #contents .list .inner .products_04 .plan ul li {
		width: auto;
		max-width: inherit;
	}
	
	#products #contents .list .inner .products_04 .plan ul li dl dt {
		font-size: min(14px, 3.2vw);
	}
	
	#products #contents .list .inner .products_04 .plan ul li dl dt .name {
		gap: 0 2px;
	}
	
	#products #contents .list .inner .products_04 .plan ul li dl dt em {
		font-size: min(27px, 6vw);
	}
	
	#products #contents .list .inner .products_04 .plan ul li dl dt b {
		font-size: min(17px, 3.8vw);
	}
	
	#products #contents .list .inner .products_04 .plan ul li dl dd {
		width: 80%;
		max-width: 250px;
		margin: 0 auto;
	}
}



/*===============================================================

		#products #contents .roop_products layout

===============================================================*/

#products #contents .roop_products {
	width: 100%;
	margin: 0;
	overflow: hidden;
}

#products #contents .roop_products p {
	margin: 0 0 40px;
	text-align: center;
	color: var(--logo_green);
	font-size: min(30px, 2.8vw);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.5;
}

#products #contents .roop_products p span {
	font-size: min(40px, 3.6vw);
}


@media screen and (max-width: 768px){
	#products #contents .roop_products {
		display: block;
	}
	
	#products #contents .roop_products p {
		margin: 0 0 20px;
		font-size: min(30px, 5vw);
		line-height: 1.8;
	}
	
	#products #contents .roop_products p span {
		font-size: min(40px, 7vw);
	}
}



/*===============================================================

		#products footer layout

===============================================================*/

@media screen and (max-width: 768px){
	#products footer {
		margin: 4vh 0 0;
	}
}





/*====================================================================================

		#voices layout

====================================================================================*/

/*===============================================================

		#voices #contents .list layout

===============================================================*/

#voices #contents .list {
	margin: 80px 0 100px;
	padding: 0 20px;
}

#voices #contents .list .inner {
	max-width: 1280px;
	padding: 0;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0 min(50px, 5vw);
}

#voices #contents .list .inner .page_nav {
	width: 270px;
	flex-shrink: 0;
	position: sticky;
	top: 120px;
}

#voices #contents .list .inner .page_nav ul li {
	margin: 0 0 10px;
}

#voices #contents .list .inner .page_nav ul li a {
	width: 100%;
	padding: 15px 28px;
	background-color: #fff;
	border-radius: 64px;
	display: inline-flex;
	justify-content: space-between;
	align-items: center;
	font-weight: 700;
	letter-spacing: 0;
}

#voices #contents .list .inner .page_nav p {
	width: 125px;
	margin: 75px 0 0 auto;
}


/*==================== .detail ====================*/

#voices #contents .list .inner .wrapper {
	width: 74.22%;
	max-width: 952px;
}

#voices #contents .list .inner .detail {
	margin: 0 0 80px;
	padding: 120px 0 0;
	background-color: #FFFAEC;
	border-radius: 20px;
	position: relative;
}

#voices #contents .list .inner .detail h3 {
	margin: -120px 0 0;
	padding: 120px 0 0;
	position: absolute;
	left: 0;
	top: 0;
}

#voices #contents .list .inner .detail h3 span {
	padding: 18px 30px 20px;
	background-color: var(--logo_green);
	border-radius: 20px 0 20px 0;
	display: inline-block;
	color: #fff;
	font-size: min(24px, 2.4vw);
	font-weight: 700;
	line-height: 1.5;
}

#voices #contents .list .inner .detail .photo {
	width: 90%;
	max-width: 526px;
	margin: 0 auto 30px;
}

#voices #contents .list .inner .detail .photo img {
	border-radius: 10px;
}

#voices #contents .list .inner .detail .table_box {
	width: 90%;
	max-width: 526px;
	margin: 0 auto 130px;
}

#voices #contents .list .inner .detail .table_box table {
	width: 100%;
	border-collapse: separate;
	border-radius: 10px;
	font-size: min(16px, 1.6vw);
}

#voices #contents .list .inner .detail .table_box table th {
	width: 25%;
	padding: 12px 0;
	background-color: var(--green_03);
	border: solid 1px #fff;
	font-weight: 700;
}

#voices #contents .list .inner .detail .table_box table td {
	width: 75%;
	padding: 12px 20px;
	background-color: #fff;
	border: solid 1px #fff;
}

#voices #contents .list .inner .detail .table_box table tr:nth-of-type(1) th {
	border-radius: 10px 0 0 0;
}

#voices #contents .list .inner .detail .table_box table tr:nth-of-type(1) td {
	border-radius: 0 10px 0 0;
}

#voices #contents .list .inner .detail .table_box table tr:nth-last-of-type(1) td {
	border-radius: 0 0 10px 0;
}

#voices #contents .list .inner .detail .table_box table tr:nth-last-of-type(1) th {
	border-radius: 0 0 0 10px;
}

#voices #contents .list .inner .detail .table_box table td em {
	color: var(--logo_green);
}


#voices #contents .list .inner .detail .comment {
	padding: 50px min(60px, 6vw) 30px min(90px, 8vw);
	background-color: var(--light_green);
	border-radius: 0 0 20px 20px;
	display: flex;
	justify-content: center;
	gap: 0 min(75px, 6vw);
	position: relative;
}

#voices #contents .list .inner .detail .comment::before {
	content: "";
	border-style: solid;
	border-width: 0 25px 50px 25px;
	border-color: transparent transparent var(--light_green) transparent;
	position: absolute;
	left: calc(50% - 25px);
	top: -49px;
}

#voices #contents .list .inner .detail .comment p.img {
	width: 157px;
	flex-shrink: 0;
}

#voices #contents .list .inner .detail .comment dl dt {
	margin: 0 0 20px;
	padding: 0 20px;
	position: relative;
	font-size: min(24px, 2.4vw);
	font-weight: 700;
	line-height: 1.7;
}

#voices #contents .list .inner .detail .comment dl dt::before {
	content: "“";
	position: absolute;
	left: -15px;
	top: -10px;
	color: #BFC0C0;
	font-size: 43px;
	font-weight: 700;
	line-height: 1.0;
}

#voices #contents .list .inner .detail .comment dl dt::after {
	content: "”";
	position: absolute;
	right: -10px;
	top: -10px;
	color: #BFC0C0;
	font-size: 43px;
	font-weight: 700;
	line-height: 1.0;
}

#voices #contents .list .inner .detail .comment dl dd {
	font-size: min(16px, 1.6vw);
}


@media screen and (max-width: 768px){
	#voices #contents .list {
		margin: 6vh 0 0;
		padding: 0 10px;
		background: none;
	}
	
	#voices #contents .list .inner {
		max-width: inherit;
		display: block;
	}
	
	#voices #contents .list .inner .page_nav {
		display: none;
	}
	
	
	/*==================== .detail ====================*/
	
	#voices #contents .list .inner .wrapper {
		width: auto;
		max-width: inherit;
	}
	
	#voices #contents .list .inner .detail {
		margin: 0 0 6vh;
		padding: 100px 0 0;
	}
	
	#voices #contents .list .inner .detail h3 {
		margin: -80px 0 0;
		padding: 80px 0 0;
	}
	
	#voices #contents .list .inner .detail h3 span {
		padding: 15px 15px 18px 30px;
		font-size: min(24px, 4.2vw);
	}
	
	#voices #contents .list .inner .detail .photo {
		width: auto;
		max-width: inherit;
		margin: 0 20px 30px;
	}
	
	#voices #contents .list .inner .detail .photo img {
		border-radius: 10px;
	}
	
	#voices #contents .list .inner .detail .table_box {
		width: auto;
		max-width: inherit;
		margin: 0 20px 60px;
	}
	
	#voices #contents .list .inner .detail .table_box table {
		font-size: min(14px, 3.3vw);
	}
	
	#voices #contents .list .inner .detail .table_box table th {
		width: 27%;
		padding: 12px 5px;
	}
	
	#voices #contents .list .inner .detail .table_box table td {
		width: 73%;
		padding: 12px 15px;
	}
	
	
	#voices #contents .list .inner .detail .comment {
		padding: 40px 20px;
		display: block;
	}
	
	#voices #contents .list .inner .detail .comment::before {
		border-width: 0 15px 30px 15px;
		left: calc(50% - 15px);
		top: -29px;
	}
	
	#voices #contents .list .inner .detail .comment p.img {
		width: 35%;
		max-width: 157px;
		margin: 0 auto 30px;
	}
	
	#voices #contents .list .inner .detail .comment dl dt {
		font-size: min(24px, 4.2vw);
	}
	
	#voices #contents .list .inner .detail .comment dl dt::before {
		left: 0;
		top: -10px;
		font-size: 30px;
	}
	
	#voices #contents .list .inner .detail .comment dl dt::after {
		right: 0;
		top: -10px;
		font-size: 30px;
	}
	
	#voices #contents .list .inner .detail .comment dl dd {
		font-size: min(16px, 3.7vw);
	}
}





/*====================================================================================

		#contact layout

====================================================================================*/

/*===============================================================

		#contact #contents .form layout

===============================================================*/

#contact #contents .form {
	margin: 40px 0 0;
	padding: 0 40px;
}

#contact #contents .form .inner {
	max-width: 1120px;
	padding: 50px 40px 80px;
	background-color: #fff;
	border-radius: 25px;
}

#contact #contents .form .inner .for_tel {
	margin: 0 0 80px;
	text-align: center;
	line-height: 1.0;
}

#contact #contents .form .inner .for_tel p:nth-of-type(1) {
	margin: 0 0 20px;
	font-size: 20px;
	font-weight: 700;
}

#contact #contents .form .inner .for_tel p:nth-of-type(2) a {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0 20px;
	font-size: min(46px, 4vw);
	font-weight: 900;
	letter-spacing: 0;
}

#contact #contents .form .inner .for_tel p:nth-of-type(2) a img {
	width: 22px;
	margin: 0 auto;
}

#contact #contents .form .inner .for_tel p:nth-of-type(2) .hours {
	margin: 15px 0 0;
	display: block;
	font-size: min(15px, 1.5vw);
}

#contact #contents .form .inner .form-area{
    max-width: 900px;
    margin: 0 auto;
}
#contact #contents .form .inner .form-area dl{
    max-width: 632px;
    margin: 0 auto;
}
#contact #contents .form .inner .form-area dl dt{
    font-size: 16px;
    font-weight: bold;
    padding: 12px 0 0;
}
#contact #contents .form .inner .form-area dl dt .req{
    display: inline-block;
    background: #00BF30;
    font-size: 12px;
    color: #fff;
    margin: 0 8px 0 0;
    padding: 2px 10px;
    border-radius: 4px;
}
#contact #contents .form .inner .form-area dl dt .optional{
    display: inline-block;
    background: #C2C2C2;
    font-size: 12px;
    color: #fff;
    margin: 0 8px 0 0;
    padding: 2px 10px;
    border-radius: 4px;
}
#contact #contents .form .inner .form-area dl dd{
    padding: 10px 0 12px;
    font-size: 16px;
}
#contact #contents .form .inner .form-area dl dd .horizon{
    display: flex;
    font-weight: bold;
}
#contact #contents .form .inner .form-area dl dd .txt01{
    font-weight: bold;
    margin: 5px 0 10px;
}
#contact #contents .form .inner .form-area dl dd .error{
    font-weight: normal;
    color: #B00002;
}
#contact #contents .form .inner .form-area dl dd input[type=text],
#contact #contents .form .inner .form-area dl dd input[type=email]{
    width: 80%;
    border: 1px solid #F0EDDF;
    border-radius: 8px;
    padding: 15px;
    font-size: 16px;
    font-weight: normal;
    box-sizing: border-box;
    background: #FFFBF2;
}
#contact #contents .form .inner .form-area dl dd input[type=text]::placeholder,
#contact #contents .form .inner .form-area dl dd input[type=email]::placeholder{
    color: #C2C2C2;
}
#contact #contents .form .inner .form-area dl dd textarea{
    width: 100%;
    height: 200px;
    border: 1px solid #F0EDDF;
    border-radius: 8px;
    padding: 15px;
    font-size: 16px;
    font-weight: normal;
    box-sizing: border-box;
    background: #FFFBF2;
}
#contact #contents .form .inner .form-area dl dd textarea::placeholder{
    color: #C2C2C2;
}

#contact #contents .form .inner .form-area .dd-radio label{
    margin: 0 20px 0 0;
}
#contact #contents .form .inner .form-area .dd-radio input[type=radio]{
    -webkit-appearance: none;
    height: 18px;
    width: 18px;
    border: 1px solid #00BF30;
    border-radius: 50%;   
    position: relative;
    margin: 5px 10px 0 0;
}
#contact #contents .form .inner .form-area .dd-radio input[type=radio]:before {
    content: "";
    display: block;
    position: absolute;
    width: 60%;
    height: 60%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
}
#contact #contents .form .inner .form-area .dd-radio input[type=radio]:checked:before {
    background: #00BF30;
}
#contact #contents .form .inner .form-area .btn-list{
    border-top: 1px solid #C2C2C2;
    margin: 35px 0 0;
    padding: 50px 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#contact #contents .form .inner .form-area .btn-list .btn-list__item{
    margin: 0 10px 10px;
    max-width: 350px;
    width: 100%;
}
#contact #contents .form .inner .form-area .btn-list .btn-list__item input[type=submit]{
    display: block;
    max-width: 350px;
    width: 100%;
    padding: 20px 10px;
    border-radius: 35px;
    box-sizing: border-box;
    border: 2px solid #003B92;
    background: #003B92;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    cursor: pointer;
    transition: 0.3s;
}
#contact #contents .form .inner .form-area .btn-list .btn-list__item.btn-list__item--back input[type=submit]{
    border: 2px solid #aaa;
    background: #aaa;
}
#contact #contents .form .inner .form-area .catch{
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    margin: 0 0 1.0em;
}
#contact #contents .form .inner .form-area .txt02{
    text-align: center;
    font-size: 16px;
    margin: 0 0 1.5em;
}
#contact #contents .form .inner .form-area .btn{
	width: 360px;
	margin: 0 auto;
}
#contact #contents .form .inner .form-area .btn a{
	width: 100%;
	padding: 25px 20px;
	background-color: #fff;
	border: solid 1px var(--logo_green);
	border-radius: 60px;
	box-shadow: 5px 7px 0 var(--logo_green);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0 10px;
	text-align: center;
	color: var(--logo_green);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.0;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}


@media screen and (min-width: 769px){
    #contact #contents .form .inner .form-area .btn-list .btn-list__item input[type=submit]:hover{
        background: #fff;
        color: #003B92;
    }   
    #contact #contents .form .inner .form-area .btn-list .btn-list__item.btn-list__item--back input[type=submit]:hover{
        background: #fff;
        color: #aaa;
    }
    #contact #contents .form .inner .form-area .btn a:hover{
        transform: translateY(4px);
        box-shadow: 5px 3px 0 var(--logo_green);
    }
}

@media screen and (max-width: 768px){
	#contact #contents .form {
		margin: 40px 0 0;
		padding: 0 10px;
	}
	
	#contact #contents .form .inner {
		max-width: inherit;
		padding: 8vh 20px;
		background-color: #fff;
		border-radius: 25px;
	}
	
	#contact #contents .form .inner .for_tel {
		margin: 0 0 6vh;
	}
	
	#contact #contents .form .inner .for_tel p:nth-of-type(1) {
		font-size: min(20px, 4vw);
	}
	
	#contact #contents .form .inner .for_tel p:nth-of-type(2) a {
		gap: 0 15px;
		font-size: min(46px, 9vw);
	}
	
	#contact #contents .form .inner .for_tel p:nth-of-type(2) a img {
		width: 4.2vw;
	}
	
	#contact #contents .form .inner .for_tel p:nth-of-type(2) .hours {
		margin: 15px 0 0;
		display: block;
		font-size: min(15px, 3.5vw);
	}
    #contact #contents .form .inner .form-area dl dd input[type=text],
    #contact #contents .form .inner .form-area dl dd input[type=email]{
        width: 100%;
    }
    
    #contact #contents .form .inner .form-area .btn-list .btn-list__item.btn-list__item--send{
        order: 1;
    }
    #contact #contents .form .inner .form-area .btn-list .btn-list__item.btn-list__item--back{
        order: 2;
    }
}