@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Kosugi+Maru&display=swap');

@font-face {
    font-family: 'Noto Sans JP';
	font-display: block;
    font-style: normal;
    font-weight: 400;
	src: url('../fonts/NotoSansJP/NotoSansJP-Regular.woff2') format('woff2'),
		 url('../fonts/NotoSansJP/NotoSansJP-Regular.woff') format('woff');
}
@font-face {
    font-family: 'Noto Sans JP';
	font-display: block;
    font-style: normal;
    font-weight: 700;
	src: url('../fonts/NotoSansJP/NotoSansJP-Bold.woff2') format('woff2'),
		 url('../fonts/NotoSansJP/NotoSansJP-Bold.woff') format('woff');
}
@font-face {
    font-family: 'Noto Sans JP';
	font-display: block;
    font-style: normal;
    font-weight: 500;
	src: url('../fonts/NotoSansJP/NotoSansJP-Medium.woff2') format('woff2'),
		 url('../fonts/NotoSansJP/NotoSansJP-Medium.woff') format('woff');
}

:root {
	--font-base: "Noto Sans JP",  "Hiragino Sans", "Hiragino Kaku Gothic ProN", 'メイリオ',  Meiryo, sans-serif;
	--color-black01: #000000;
	--color-black02: #262626;
	--color-blue: #23a0c1;
	--color-green: #00a384;
	--color-whitesmoke: #ececec;
	--color-white: #ffffff;
	--color-red: #ce214a;
	--color-yellow: #f7ce5e;
	--color-navy: #255e84;
	--header-height: 122px;
	--fixed_bottom-height: 0;
}

@media screen and (max-width:769px) {
	:root {
		--header-height: 6rem;
		--fixed_bottom-height: 6.44rem;
	}
}

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

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

html {
	font-size: 62.5%;
	overflow: inherit!important;
}
body {
	width: 100%;
	height: auto;
	background-color: var(--color-whitesmoke);
	position: relative;
	left: 0;
	top: 0;
	color: var(--color-black02);
	font-size: 1.6rem;
	font-family: var(--font-base);
	font-weight: 400;
	line-height: 1.66;
	overflow: auto;
	font-feature-settings: "palt";
}

h2 {
	font-family: "Kosugi Maru", sans-serif;
	font-size: 3.28rem;
	font-weight: 500;
	line-height: 1.6;
}
h3 {
	font-family: "Kosugi Maru", sans-serif;
	font-size: 2.1rem;
	font-weight: 600;
	line-height: 1.62;
}
p {
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.85;
}

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

a {
	outline: none;
}
button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}
a,button {
	text-decoration: none;
	-webkit-transition: opacity .32s ease , color .25s ease , background-color .25s ease;
	transition: opacity .32s ease , color .25s ease , background-color .25s ease;
	color: #333;
}
a:hover, button:hover {
	opacity: 0.56;
}

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

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

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

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




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

   common

*********************/
/*****   class   *****/

.wf-loading {
    opacity: 0;
}


#body_inner {
	width: 100%;
	min-width: 1280px;
	height: auto;
	margin: 0 auto;
	overflow-x: hidden;
}

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

.main_section h1 {
	font-family: "dnp-shuei-mincho-pr6n", sans-serif;
	font-size:70px;
	margin-bottom: 15px;
	color:#42aac5;
}

.works.main_section h1, .qanda.main_section h1, .contact.main_section h1{
	color: #333;
	font-family: 'Noto Sans JP';
}

.works.main_section h1 .color-green {
	
}

.qanda {
	padding: 7rem 0 7.3rem;
}

.qanda.main_section h1 {
	letter-spacing:10px;
	font-size:80px;
}

.qanda.main_section h1 .sub_head {
	letter-spacing:0;
}

.qanda.main_section h1 .smaller_h1 {
	display:block;
	font-size:32px;
	line-height:1;
}

.qanda.main_section h1 .smaller_h1 {
	font-size:60px;
	display:inline;
}

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

.heading {
	text-align: center;
	margin-bottom: 4rem;
	font-size: 4.2rem;
	line-height: 1.39;
}

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

.sp_only {
	display: none;
}


h2.heading {
	position:relative;
}

#feature h2.heading:before {
	position:absolute;
	right:0;
	top:0;
	width:429px;
	height:164px;
	background-image: url(../img/SVG/breeze1.svg);
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	content:"";
}



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

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

	body {
		font-size: 1.4rem;
	}

	.main_section h1 {
		font-size: 3.8rem;
	}

	.qanda.main_section h1 {
    font-size: 3.8rem;
    /* margin-bottom: 3rem; */
    /* line-height:1.2; */
}

	.qanda.main_section h1 span {
	font-size:3.8rem;
}

.qanda.main_section h1 .smaller_h1 {
	font-size:3rem;
}
	
	h2 {
		font-size: 2.1rem;
		margin-bottom: 1rem;
	}
	h3 {
		font-size: 1.5rem;
		margin-bottom: 1rem;
	}
	p {
		font-size: 1.4rem;
	}

	img {
		width: 100%;
		margin: auto;
	}

	#body_inner {
		width: 100%;
		min-width: 0px;
	}

    .sp_only {
        display: block;
    }
    
    .pc_only {
        display: none!important;
    }


	.to_contact_btn {
    margin: 0 auto;
    padding: 3.2rem 0rem;
    border-radius: 1.8rem;
    z-index: 10;
		min-width:auto!important;
    justify-content: center;
		width:100%!important;
		margin-top:2rem;
}

	.to_contact_btn img {
		width:68%!important;
	}

	.to_contact_btn.pc_only {
	display:block!important;
		text-align:center;
		margin-top:2rem;
}

	.contact_lead_section.pc_only,
	.consult_box.pc_only{
		display:block!important;
	}

	.contact_lead_section {
    padding: 2.5rem 0 2.5rem!important;
    background: #fff;
}

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

	.heading {
		margin-bottom: 1.8rem;
		font-size: 1.8rem;
	}

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

	h2.heading:before {
	bottom: -23px;
	width: 42%;
	height: 6px;
	background-image: url(../img2024/icon-img/SVG/line-h2_sp.svg);
	transform: translateX(-50%);
}
}


/********************
   parts
*********************/
.color-green {
	color: var(--color-green);
}

.color-yellow {
	color: var(--color-yellow);
}


.visual_img img {
	width: 100%;
	height: auto;
	max-height: 73rem;
	object-fit: cover;
}



/***   .consult_box   ***/
.consult_box {
	position: relative;
	width: 48rem;
	max-width: 100%;
	border-radius: 1.4rem;
	padding: 2.8rem 1rem 2.5rem;
	margin: 2.5rem auto 2.6rem;
	background: var(--color-green);
	color: #fff;
}

.consult_box__inner {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	column-gap: 2rem;
	margin-bottom: 0.4rem;
}

.consult_box__illust {

}
.consult_box__text {
	margin-top: 0.2em;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.73;
	text-align: left;
}

.consult_box__text a {
	display: block;
    margin-bottom: 1rem;
    color: #fff;
    text-align: center;
    font-size: 2.4rem;
    letter-spacing: 0.04em;
    font-weight: 700;
    line-height: 1.3;
}

.consult_box__lead {
	display: block;
	margin-bottom: 1.8rem;
	color: #fff;
	text-align: center;
	font-size: 2.8rem;
	letter-spacing: 0.04em;
	font-weight: 700;
	line-height:1.3;
}

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

.consult_box_list__item {
	position: relative;
	padding: 0.1rem 2.2rem;
}
.consult_box_list__item:nth-of-type(n+2)::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-44%);
	width: 1px;
	height: 73%;
	background: #fff;
}

@media screen and (max-width:769px) {
	.consult_box {
		padding: 1.5rem 1rem 1rem;
        margin: 2.5rem auto 0.5rem;
		max-width:80%;
	}
	.consult_box__inner {
		margin-bottom: 0;
		column-gap: 1rem;
	}
	.consult_box__illust {
		width: 4.7rem;
	}
	.consult_box__text {
		font-size: 1.19rem;
	}

	.consult_box__text a.consult_box__lead,
	 .consult_box__inner a.consult_box__lead {
		font-size: 1.5rem;
		margin-bottom: 1.1rem;
	}

	.consult_box_list__item {
		padding: 0.05rem 1.7rem;
	}
	.consult_box_list__item img {
		width: auto;
		height: 1.4rem;
	}
}



/***   .work_list_block   ***/
.work_list_block_wrapper {
	width: 100%;
	margin: 0 auto 0;
	overflow: hidden;
	padding-bottom:3rem;
}
.work_list_block {
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	column-gap: 30px;
	width: 1240px;
}


@media screen and (max-width:769px) {
	.work_list_block img {
		width: auto;
		height: 69px;
	}
}


/***   to_contact_btn   ****/
.to_contact_btn {
	position: relative;
	display: flex;
	width: fit-content;
	margin: 0 auto;
	padding: 3.2rem 0rem;
	border-radius: 1.8rem;
	z-index: 10;
	min-width:580px;
	justify-content: center;
}
.to_contact_btn img {
	width:400px;
}



.to_contact_btn::before,
.to_contact_btn::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background : linear-gradient(180deg, rgba(165, 203, 11, 1) 0%, rgba(0, 148, 66, 1) 50% , rgba(165, 203, 11, 1) 100%);
	border: 0.7rem solid #fff;
	border-radius: 1.8rem;
	z-index: -1;

    /*アニメーション用*/
	background-position: 0% 0%;
    background-size: auto 200%;
    transition: background-position 0.37s ease;
}
.to_contact_btn::after {
	background: transparent;
	border: 0.2rem solid #2aa239;
}

.to_contact_btn:hover {
	opacity: 1;
}
.to_contact_btn:hover::before {
	background-position: 0% -232%;
}




/***   .return_top   ***/
.return_top__observer {
	--observer_adjust: 170vh;
	position: absolute;
	top: var(--observer_adjust);
	left: 50%;
	width: 1px;
	height: calc(100% - var(--observer_adjust) - 10px);
	background: transparent;
	pointer-events: none;
}


.return_top__btn a {
	--size: 5.6rem;
	position: fixed;
	bottom: 2.8rem;
	right: 2.9rem;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--size);
	height: var(--size);
	background-image: url(../img/SVG/return_top_btn.svg);
	background-size: contain;
	background-repeat: no-repeat;
}
.return_top__btn {
	position: relative;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.37s ease-in-out;
	z-index: 9995;
}
.return_top__btn.active {
	opacity: 1;
	pointer-events: all;
}


@media screen and (max-width:769px) {
	.return_top__btn a {
		--size: 3.9rem;
		bottom: 1.8rem;
		right: 1.5rem;
	}
}




/******************   
	animation   
*******************/
/*****   アコーディオン   *****/
.js-acc_switch {
	position: relative;
	cursor: pointer;
}
.js-acc_switch::after {
	--size: 1.1rem;
	--border: 0.25rem solid #fff;
	content: "";
	position: absolute;
	top: 50%;
	right: 2.8rem;
	transform: translateY(-87%) rotate(45deg);
	transform-origin: center 62%;
	background: transparent;
	width: var(--size);
	height: var(--size);
	border: var(--border);
	border-top: 0;
	border-left: 0;
	transition: 0.44s;
}
.acc_wrapper.active .js-acc_switch::after {
	transform: translateY(-69%) rotate(-135deg);
}

.js-acc_block {
	display: none;
}

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


/***   slider    ***/
.slider {
	display: none;
	opacity: 0;
}
.slider.slick-initialized {
	display: block;
	opacity: 1;
}

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



@media screen and (max-width:769px) {
	/* sp_slider */
	.slider_sp {
		display: none;
		opacity: 0;
	}
	.slider_sp.slick-initialized {
		display: block;
		opacity: 1;
	}
	.slick-dotted.slick-slider.slider_sp {
		position: relative;
		width: 100vw;
		left: 50%;
		transform: translateX(-50%);
	}
	.slider_sp .slick-slide {
		margin: 0 0.55rem;
	}

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

	body .slick-arrow {
		--size: 3.1rem;
		--adjust: 4.4rem;
		position: absolute;
		top: 47%;
		font-size: 0;
		line-height: 0;
		width: var(--size);
		height: calc(var(--size) * (1/1));
		background-size: contain;
		background-repeat: no-repeat;
		z-index: 5000;
	}
	body .slick-arrow::before {
		display: none;
	}
	body .slick-arrow.slick-prev {
		left: var(--adjust);
		transform: translateX(-100%) translateY(-50%) rotate(180deg);
		background-image: url(../img/design/slider_arrow.svg);
		background-size: contain;
		background-repeat: no-repeat;
	}
	body .slick-arrow.slick-next {
		right: var(--adjust);
		transform: translateX(100%) translateY(-50%);
		background-image: url(../img/design/slider_arrow.svg);
		background-size: contain;
		background-repeat: no-repeat;
	}
	


	.slick-dotted.slick-slider.slider_sp .slick-dots li,
	.slick-dotted.slick-slider.slider_sp .slick-dots li button,
	.slick-dotted.slick-slider.slider_sp .slick-dots li button::before {
		--size: 0.5rem;
		width: var(--size);
		height: var(--size);
		padding: 0;
		border-radius: var(--size);
		opacity: 1;
		font-size: 0;
	}
	.slick-dotted.slick-slider.slider_sp .slick-dots li {
		margin: 0 0.32rem;
	}
	.slick-dotted.slick-slider.slider_sp .slick-dots li button::before{
		background: #D9D9D9;
	}
	.slick-dotted.slick-slider.slider_sp .slick-dots li:hover button::before {
		opacity: 0.6;
	}
	.slick-dotted.slick-slider.slider_sp .slick-dots li.slick-active button::before{
		background: var(--color-green);
	}
	
}


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

   header

*********************/
#header {
	top: 0;
	left: 0;
	width: 100%;
	height: var(--header-height);
	color: #262626;
	z-index: 9990;
	position: absolute;
}


#header .header__inner {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	max-width: 100%;
	height: 100%;
	min-height:122px;
	padding: 0;
}

#header.second_header {
	background-size: cover;
	background-repeat: no-repeat;
	background-image: url(../img/SVG/bg-header-sec.svg);
	height: 15vw;
	background-position-y: bottom;
}

#header.second_header .header__inner {
    display: flex;
    height: 100%;
    min-height: 130px;
    align-items: flex-start;
    max-width: 100%;
    padding: 0 4vw;
}

#header .logo {
	margin:0;
	padding-top: 2vw;
	width: 36vw;
	padding-right: 2vw;
}

#header .logo a {
	/* background:#FFF;*/
	/* padding:5px 20px;*/
	display:inline-block;
	border-radius:2px;
	margin-top:0.5rem;
}

#header .logo img {
	width: auto;
}


#header .header__block {
	display: flex;
	justify-content: flex-end;
	width: 100%;
	height: calc(100% - 30px);
}

#header .header__block .pic_block {
	position:relative;
	width: 100%;
	height: 100%;
}

#header .header__block .pic_block:before {
		  content: "";
		  position: absolute;
		  left: 4vw;
		  top: -11vw;
		  width: 36vw;
		  height: 36vw;
		  background-size: contain;
		  background-repeat: no-repeat;
		  background-image: url(../img/core-img/bg-earth-sec@2x.png);
		  overflow-y: hidden;
}

#header .header__block .pic_block .pic1 {
			  content: "";
			  position: absolute;
			  left: 2vw;
			  top:2vw;
			  width:10vw;
			  overflow: hidden;
}

#header .header__block .pic_block .pic2 {
			  content: "";
			  position: absolute;
			  left:12vw;
			  top:1vw;
			  width:6vw;
			  overflow: hidden;
}




.hamburger_btn {
	--hamburger-size: var(--header-height);
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--hamburger-size);
	height: var(--hamburger-size);
	background: transparent;
	z-index: 9992;
}
.hamburger_btn {
	position: relative;
	top: 0;
	right: 2rem;
	margin-left: -2rem;
	cursor: pointer;
}
.hamburger_btn span,
.hamburger_btn::before,
.hamburger_btn::after {
	--color: #fff;
	--position: 0;
	content: "";
	position: absolute;
	top: var(--position);
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	display: block;
	width: 45%;
	height: 0.37rem;
	background: #FFFFFF;
	margin-top: 50%;
	transition: top 0.28s 0.28s, transform 0.28s,opacity 0.62s , background 0.5s;
}

.hamburger_btn span {
	--position: 0;
}
.hamburger_btn::before {
	--position: -1.5rem;
}
.hamburger_btn::after {
	--position: 1.5rem;
}

.hamburger_cancel_btn {
	--hamburger-size: 4rem;
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--hamburger-size);
	height: var(--hamburger-size);
	background: transparent;
	top: 0.82rem;
	right: 0.69rem;
	cursor: pointer;
}
.hamburger_cancel_btn::before,
.hamburger_cancel_btn::after {
	--color: #fff;
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	display: block;
	width: 69%;
	height: 0.19rem;
	background: var(--color);
}
.hamburger_cancel_btn::before {
	transform: translateY(-50%) translateX(-50%) rotate(45deg);
}
.hamburger_cancel_btn::after {
	transform: translateY(-50%) translateX(-50%) rotate(-45deg);
}

.hamburger_nav {
	position: absolute;
	top: calc(100% - 1.1rem);
	right: -0.82rem;
	min-width: 28rem;
	padding: 1.6rem  1.3rem 2.1rem;
	border-radius: 1rem;
	background: #00946b;
	transform: tra;
	opacity: 0;
	pointer-events: none;
	transform-origin: right;
	transform: rotateY(-77deg);
	transition: transform 0.92s , opacity 0.7s;
}

#header.hamburger-active .hamburger_nav {
	opacity: 1;
	pointer-events: all;
	transform: rotateY(0deg);
}

.hamburger_nav__heading {
	text-align: center;
	font-size: 1.8rem;
	border-bottom: 0.15rem solid #fff;
	padding-bottom: 0.59em;
	margin: 0;
	color:#FFF;
}

.hamburger_link_list {
	display: block;
}
.hamburger_link_list__item {
	padding: 0;
	border-bottom: 0.15rem solid #fff;
}
.hamburger_link_list__inner {
	display: block;
	padding: 0.54em 0 0.56em;
	width: 100%;
	color: #fff;
	font-size: 1.8rem;
	text-align: center;
}



@media screen and (min-width:769.02px) {
	#header {
		min-width: 1280px;
	}

}

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

	.secondary .wrap_head .text {
    width: 100%!important;
}

	.secondary .wrap_head .pic {
		position:absolute;
		right:0;
		width: 36%!important;
}

	.secondary .wrap_head {
    margin-bottom: 3rem!important;
}

#header.second_header .header__inner {
    padding: 0 ;
}
	
#header.second_header {
    height: 21vw;
}
#header .logo {
    padding-top: 1vw;
    width: 48vw;
}

.secondary .wrap_head .lead {
    font-size: 1.8rem!important;
	margin-bottom:0
}
	.qanda.main_section h1 {
    letter-spacing: 10px;
    font-size: 3.8rem!important;
}
	
#header .header__to_contact {
width: 6rem;
        height: 3.28rem;
        border-radius: 29px;
        margin: 0;
        font-size: 1.125rem;
        padding-left: 0;
        position: absolute;
        right: 25vw;
}

#header .header__block {
    column-gap: 1.6rem;
    margin: 0;
}

#header .header__to_contact:before {
		content:none;
}
	
	#header .logo img {
		height: auto;
		width:auto;
	}

#header {
    /* position: fixed; */
    top: 0;
    left: 0;
    width: 100%;
    height: 6rem;
    color: #262626;
    z-index: 9990;
}
	
	#header .header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 120rem;
	height: 100%;
	min-height:auto;
}

	#header .site_tit_block .site_lead {
		font-size: 1.4rem;
		line-height: 1.32;
	}


	#header .pic_block img {
	width:8vw;
}

.p-confirm #header .header__to_contact,
	.p-thanks #header .header__to_contact {
	right: 10vw;
}

	.hamburger_btn {
		right: 0;
	}
	.hamburger_btn span,
	.hamburger_btn::before,
	.hamburger_btn::after {
		height: 0.25rem;
	}
	
	.hamburger_btn span {
		--position: 0;
	}
	.hamburger_btn::before {
		--position: -1rem;
	}
	.hamburger_btn::after {
		--position: 1rem;
	}


	.hamburger_nav {
		top: calc(100% + 1rem);
		right: 0;
	}
	.hamburger_nav__heading {
		font-size: 1.6rem;
		color:#FFF;
	}
	.hamburger_link_list__inner {
		font-size: 1.6rem;
	}
}



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

   fixed_bottom

*********************/
.fixed_bottom {
	display: none;
}

@media screen and (max-width:769px) {
	.fixed_bottom {
		position: fixed;
		bottom: 0;
		left: 0;
		display: block;
		width: 100%;
		height: var(--fixed_bottom-height);
		background: #0072bf;
		z-index: 9992;
	}
	.fixed_bottom__block {
		display: flex;
		align-items: center;
		justify-content: space-between;
		height: 100%;
		padding-bottom: 0.2rem;
	}

	.fixed_bottom__logo img {
		width: auto;
		height: 2rem;
	}
	.fixed_bottom_list {
		display: flex;
		align-items: center;
		justify-content: center;
		column-gap: 1.8rem;
	}
	.fixed_bottom_list__inner {
		display: block;
		min-width: 4rem;
		height: 4rem;
	}
	.fixed_bottom_list__inner img {
		width: auto;
		height: 100%;
	}
}


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

   main
   
*********************/


/*******************
	.fv
********************/
.fv {
	margin-bottom: 0rem;
	overflow: hidden;
}
.fv_wrapper {
	position: relative;
	background: #009974;
	display: flex;
	justify-content: center;
}

.fv_wrapper:after {
	  content: "";
	  position: absolute;
	  left: 0;
	  bottom: -6vw;
	  width: 103%;
	  height: 12vw;
	  background-size: contain;
	  background-repeat: no-repeat;
	  background-image: url(../img/SVG/bg-line-header.svg);
	  z-index: 0;
}

.fv_wrapper .float_pic1 {
	position:absolute;
	left:38%;
	top:4%;
	width: 36vw;
	min-width:490px;
}

.fv_wrapper .float_pic2 {
	position:absolute;
	left: 56%;
	top: 51%;
	transform: translateX(-50%);
	width:13vw;
	min-width:210px;
}

.fv_wrapper .float_pic3 {
	position:absolute;
	left: 69%;
	top: 71%;
	transform: translateX(-50%);
	width:8vw;
	min-width: 110px;
}

/* 
.fv_wrapper:before {
	  content: "";
	  position: absolute;
	  right: 0;
	  top: -6vw;
	  width: 103%;
	  height: 20vw;
	  background-size: contain;
	  background-repeat: no-repeat;
	  background-image: url(../img/bg-img/bg-header-secondary.png);
	  z-index: 0;
}
*/

.fv_wrapper .limited {
	position:absolute;
	left:calc(50% - 430px);
	top:220px;
	transform: translateX(-50%);
}

.fv_wrapper .limited img {
	width:256px;
	height:263px;
}
.fv_wrapper .radio {
	position:absolute;
	left:calc(50% + 470px);
	transform: translateX(-50%);
	top:170px;
}

.fv_wrapper .radio img {
	width:275px;
	height:203px;
	min-width:275px;
}

.fv_wrapper .period {
	position:absolute;
	left:50%;
	transform: translateX(-50%);
	bottom:10rem;
	color:#FFF;
	font-size:2rem;
}

.fv_wrapper .period span {
	font-size:3.875rem;
	font-weight:500;
}
.fv_wrapper .copy-area {
	width:58%;
	padding: 3vw 4vw 3rem 3vw;
}

.fv_wrapper .copy-area p {
	margin-bottom: 2.5vw;
}

.fv_wrapper .copy-area .btn {
	background:#ffd56e;
	position:relative;
	height: 52px;
	border-radius: 26px;
	line-height: 1;
	font-size:1.7rem;
	padding:18px;
	border: 0;
}

.fv_wrapper .copy-area . .btn:before {
		    position: absolute;
	    left: 8px;
	    top: 8px;
	    width: 34px;
	    height: 34px;
	    background-image: url(../img/SVG/arrow-btn1.svg);
	    content: "";
	    background-size: cover;
	    background-repeat: no-repeat;
}

.fv_wrapper .copy-area .header-bottom {
	display:flex;
	/* align-items: center; */
	/* flex-wrap: wrap; */
	/* justify-content: center; */
}

.fv_wrapper .pic-area {
	width:42%;
}

.fv_wrapper .pic-area img {
	aspect-ratio: 596 / 800;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fv_wrapper .copy-area .logo {
	width: 95%;
	max-width: 854px;
	margin-bottom: 60px;
	position: relative;
}

.fv_wrapper .copy-area .logo img {
	width:100%;
}

.fv_wrapper .copy-area .logo:after {
	position:absolute;
	width:100%;
	max-width: 880px;
	bottom:-36px;
	left:0;
	height:8px;
	content:"";
	background-size: contain;
	background-repeat: no-repeat;
	background-image: url(../img/SVG/b-logo-header.svg);
}

.fv_wrapper .copy-area .tagline {
	color:#FFF;
	position:relative;
	padding-top: 1vw;
	font-size: clamp(1.5rem, 1.5vw, 3rem);
	width: 59%;
}

.fv_wrapper .copy-area .tagline:before {
	  content: "";
	  position: absolute;
	  left: 0;
	  top: -17px;
	  width: 100%;
	  height: 100%;
	  background-size: contain;
	  background-repeat: no-repeat;
	  background-image: url(../img/SVG/bg-tagline.svg);
}

.fv_wrapper .copy-area h2 {
	font-size: clamp(4.5rem, 3.5vw, 7rem);
	color:#FFF;
	font-weight:500;
	line-height:1.5;
	padding: 15px 0;
}

.fv_wrapper .copy-area .notion{

}


.fv_wrapper .copy-area p {
	font-size: clamp(1.65rem, 1.2vw, 4rem)!important;
	color:#f9f9f9;
}

.fv_wrapper .copy-area p span a {
	margin-top:1.5rem;
	color:#d0fef5;
	display:block;
	/* font-size: clamp(1.2rem, 1vw, 2.5rem) !important; */
	text-decoration-line:underline;
}

.fv__bg {
	position: relative;
	display: flex;
	align-items: center;
	margin-right: -0.1rem;
}
.fv__bg,
.fv__bg * {
	height: 100%;
}
.fv__bg:first-of-type {
	position: absolute;
	top: 0;
	left: 0;
}

.fv__bg img {
	width: auto;
	height: 100%;
	object-fit: cover;
	object-position: center top;
}

.fv__bg_wrapper .fv__bg:nth-of-type(n+2) {
	will-change: transform;
	transition: 0s;
	transform: translateX(0);
	z-index: 10;
}
.fv__bg_wrapper.active .fv__bg:nth-of-type(n+2){
	animation: auto_slider 50s linear 0s infinite;
}


@keyframes auto_slider {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(calc(-100% + 0.1rem));
	}
}

.home .page_tit {
    width: 100%;
    max-width: 1082px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    padding: 170px 0 150px;
}

.home .page_tit picture {
	width:100%;
}

.home .page_tit img {
    width: 100%;
    max-width: 1082px;
}
.fv_wrapper .copy-area .btn:before {
	    content:none;
}

@media screen and (min-width:769.02px) {
	.fv__inner {
		position: absolute;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
		width: 100%;
	}
}

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

	.fv_wrapper {
		flex-direction: column;
	}

	.fv_wrapper:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -1.2vw;
    width: 104%;
    height: 12vw;
}

	.fv_wrapper .copy-area {
    width: 100%;
    padding: 37px 15px 60px 15px;
}

	.fv_wrapper .copy-area .logo {
    width: 98%;
    margin-bottom: 45px;
}
	.fv_wrapper .copy-area h2 {
    font-size: clamp(1.7em, 3.5vw, 2rem);
    padding: 10px 0;
    text-align: center;
}

	.fv_wrapper .copy-area p {
    font-size: 1.5rem!important;
    margin-bottom: 1.8rem;
}

	
.fv_wrapper .copy-area .notion{

    text-align: center;
}


	.fv_wrapper .float_pic2 {
    left: auto;
    right: 4%;
    top: 21%;
    width: 26vw;
    min-width: 70px;
}

	.fv_wrapper .float_pic3 {
    left: auto;
    right:2%;
    top: 27%;
    width: 12vw;
    min-width: 57px;
}

	.fv_wrapper .pic-area {
    width: 100%;
}

	.fv_wrapper .pic-area img {
		aspect-ratio: 4/3;
		max-width: 100%;
	}

		.fv_wrapper {
		/* margin-bottom: 2.5rem;*/
		display: flex;
		flex-direction: column-reverse;
	}

	.fv_wrapper .float_pic1 {
    position: absolute;
    left: 75%;
    top: 9%;
    width: 50vw;
    min-width: 280px;
}


	.fv_wrapper .radio {
position: absolute;
        left: calc(50%);
        transform: translateX(-50%);
        top: auto;
        bottom: calc(15px - -3vw);
        width: 66%;
}

	.fv_wrapper .radio img {
    width: 100%;
    height: auto;
    aspect-ratio: 20/4;
		min-width:auto;
}
	.fv_wrapper .period {
        bottom: calc(58% - 54vw);
        font-size: 1.5rem;
        width: 100%;
        text-align: center;
}

.fv_wrapper .period span {
	font-size:2rem;
}

	.fv_wrapper .limited {
		display:none;
}
	.fv {
		margin-bottom: -1.4rem;
	}
	.fv_wrapper {
		/* margin-bottom: 2.5rem;*/
		display: flex;
		flex-direction: column-reverse;
	}
	.fv__inner {
		position: relative;
	}

	.fv__bg_wrapper {
		height: 25rem;
	}

	.home .page_tit {
width: calc(100% - 40px);
        margin-left: auto;
        margin-right: auto;
        margin-top: 0;
		padding: 40px 0 23vw;
    }


	/* 

	.fv_wrapper .copy-area .btn {
	height: 36px;
	border-radius: 18px;
	line-height: 1;
	font-size:1.25rem;
	padding: 12px 0;
	border: 0;
}
*/
	fv_wrapper .copy-area p span {
		text-align:center;
	}
		

.fv_wrapper .copy-area .header-bottom {
    justify-content: center;
}

	.fv_wrapper .copy-area .header-bottom .subsc {
		width:96%;
		margin:10px 0 30px 0;
		text-align: center;
	}

	.fv_wrapper .copy-area .btn {
    height: auto;
    font-size: 1.5rem;
    padding: 15px 30px;
    min-width: 250px;
    margin-bottom: 20px;
}
	
}



/*******************
	.contact_lead_section
********************/
.contact_lead_section {
	padding: 4.5rem 0 2.5rem;
	background: #fff;
}

.contact_lead_section .consult_box {
	width: 50rem;
	padding: 1.5rem 2rem 1.32rem;
}
.contact_lead_section .consult_box__inner {
	margin: 0 auto;
	align-items: center;
}
.contact_lead_section .consult_box__illust img {
	width: 8.9rem;
}


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

.feature .contents_wrapper:before  {
    position: absolute;
    left: 1vw;
    bottom: -10rem;
    width: 506px;
    height: 147px;
    background-image: url(../img/SVG/breeze2.svg);
    background-size: contain;
    background-repeat: no-repeat;
    pointer-events: none;
    content: "";
}

.feature__box {
	width: 100%;
	max-width: 91.7rem;
	margin: 0 auto;
	padding: 5.1rem 1rem 5.4rem;
	background: #fff;
}

.main_section .bnr.fixed {
    position: fixed;
}

.main_section .bnr {
    right: 6px;
    top: 100px;
    z-index: 99;
}

.fading {
    transition: opacity 0.3s 
ease;
    transform: translateZ(0) rotate(0.0001deg);
    opacity: 0.92;
}

@media screen and (min-width:769.02px) {
	.feature__text {
		margin-bottom: 3.7rem;
		line-height: 1.96;
	}
}

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

.feature {
	padding: 3.4rem 0 0;
}
	
	.feature__box {
		padding: 2rem 1.62rem 2.5rem;
		background: #fff;
	}

	.feature .feature__heading img {
    width: 96%!important;
}

#feature h2.heading:before {
    position: absolute;
    right: -75px;
    top: auto!important;
    bottom: -42px!important;
    width: 120px;
    height: 49px;
}

.feature .contents_wrapper:before {
    position: absolute;
    left: -18px;
    width: 140px;
    height: 50px;
}
	
    .feature .feature-content h3 {
        font-size:2rem;
        padding-left: 0;
    }




	
.feature .feature-content .text {
    width: 100%;
    padding-left: 0!important;
}



	.feature .feature-content h3:before {
    left: 0;
    top: 0;
    width: 100px;
    height: 100px;
    background-image: url(../img/SVG/promise1.svg);
}

	.fading {
		display:none;
	}



}

/*******************
	.feature
********************/

.feature {
	padding: 5rem 0 14rem;
	background:#FFF;
}

.feature .feature__heading {
	width: 100%;
	text-align: left;
}

.feature .feature__heading img {
	width:429px;
}

.feature .feature-content {
	padding: 40px 0 79px;
	position:relative;
	display: flex;
}

.feature-content:nth-of-type(2) {
	    flex-direction: row-reverse;

}

.feature .feature-content .text {
	width: 77%;
	padding-left: 240px;
	z-index:1;
}

.feature .feature-content .text p {
	font-size:2rem;
	padding-top: 2rem;
	padding-bottom:2rem;
}

.feature .feature-content  .vis {
		position:absolute;
		right:0;
		top: 7%;
		width: 38%;
		z-index:-1;
		max-width: 500px;
}

	.feature .feature-content .vis img {
		 mask-image: linear-gradient(to right, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%);
	}

	.feature .feature-content:nth-of-type(2) .vis img {
		mask-image: linear-gradient(to left, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%);
	}

.feature .feature-content h3 {
	font-size:66px;
	color:#00a384;
	position:relative;
	line-height:1.6;
	width: 100%;
	font-family: "Kosugi Maru", sans-serif;
	font-weight: 500;
}


.feature .feature-content h4 {
	font-size: 30px;
	position:relative;
	line-height: 1;
	width: 100%;
	font-family: "Kosugi Maru", sans-serif;
	font-weight: 500;
}

.feature .feature-content h3 span {
	color:#333;
	font-size:48px;
}

.feature .feature-content h3:before {
	position: absolute;
	left: -240px;
	top: 0;
	width: 226px;
	height: 236px;
	background-image: url(../img/SVG/promise1.svg);
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	content: "";
}

.feature .feature-content h3:after {
}



.feature-content:nth-of-type(2) .text{
	padding-left:0;
	padding-right:240px;
}

.feature-content:nth-of-type(2) h3 {
    padding-left: 0;
}

.feature-content:nth-of-type(2) h3:before {
	position: absolute;
	left: auto;
	right: -240px;
	background-image: url(../img/SVG/promise2.svg);
}

.feature-content:nth-of-type(3) h3:before {
	background-image: url(../img/SVG/promise3.svg);
}

.feature .feature-content:nth-of-type(2) .vis {
    position: absolute;
    right: auto;
	left:0;
}

.feature-content:nth-of-type(3) h3{
}

.feature-content:nth-of-type(3) p {
}


.feature-content:nth-of-type(3) h3:before {
	top:40px!important;
}

.feature-content:nth-of-type(3) h3:after {
	top:10px!important;
}

	.feature .feature-content .notion {
		font-size:0.8em;
		margin-top:0.5em;
		display:block;
    text-indent: -1em;
    padding-left: 1em;
	}

.feature .feature-content .notion a {
	text-decoration:underline;
	color:#868686;
}

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

	.feature .feature-content {
    padding: 30px 0 0;
    justify-content: center;
    flex-direction: column;
}

	.feature .feature-content h3 {
    font-size: 3.5rem;
    padding-left: 9rem;
    line-height: 1.2;
}



	
	.feature .feature-content h3 > span {
    font-size: 2rem;
    bottom: 0;
    position: relative;
    display: flex;
}

.feature .feature-content h3:before {
    width: 19vw;
    height: 19vw;
    left: 5px;
}

	.feature .feature-content h3:after {
    font-size: 4rem;
    left: 4.5rem;
    top: -2.3rem;
}


	.feature-content:nth-of-type(3) h3:before {
    top: 0px !important;
}

	.feature-content:nth-of-type(3) h3:after {
    top: -5px !important;
}
	
.feature .feature-content .text {
	width:100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

	.feature .feature-content:h3:before {
    position: absolute;
    left: 0;
    top: 0;
    width: 50px;
    height: 50px;
}


	
	.feature .feature-content .vis {
    position: relative!important;
    right: 0;
    top: 0;
    width: calc(100% - 20px);
    z-index: 0;
    max-width: 800px;
    margin:auto;
    margin-bottom: 2rem;
}

.feature .feature-content .vis img {
    mask-image:none!important;
	aspect-ratio:2 /1;
	    object-fit: cover;
}
	
.clearfix{display: inline-block;} 

/* Hides from IE Mac &yen;*/
* html .clearfix {height: 1%;}
.clearfix {display:block;}
/* End Hack */


	.feature .feature__heading {
    font-size: 2rem;
	line-height:1.2;
		font-weight:700;
}



	.feature__heading:before {
    bottom: -40px !important;
	
}

	.feature .feature__heading span {
    font-size: 6rem;
        padding-right: 0.2em;
        position: relative;
        left: 0;
        top: 0.5rem;
}

	.feature .feature-content .btn {
		margin-bottom:3rem;
	}
	
	.feature .feature-content .text p {
	font-size:1.6rem;
		padding-top:0;
		padding-bottom:2.6rem;
}

	.feature-content:nth-of-type(2) .text {
    padding-left: 0;
    padding-right: 0;
}

	.feature .feature-content .vis img {
	}
}


/*******************
	.free
********************/
.free {
	padding-top: 5rem;
	background:#FFF;
}

.free .free__heading {
position:relative;
	font-family: fot-udkakugo-large-pr6n, sans-serif;
	font-size:42px;
	font-weight:600;
}




.free .free__heading span {
	font-family: "elina", sans-serif;
	color:#d81d52;
	font-size:148px;
	padding-right:0.2em;
	font-weight:100;
}

/* 
.free .free__heading:before {
	content:"";
	position:absolute;
		border-top: 40px solid #e5cf76;
  border-right: 30px solid transparent;
  border-bottom: 40px solid #e5cf76;
  border-left: 30px solid transparent;
	left:50%;
	top:30px;
	transform: translateX(-50%);
	width:70%;
	z-index:-1;
}
*/

.free_list {
	display: grid;
	grid-template-columns: repeat( 3 , 1fr );
	column-gap: 40px;
	row-gap: 2.1rem;
}

.free_list__item {
	padding: 3rem;
    border-radius: 0;
    background: #fff;
    border: 5px solid #EEE;
}

.free_list__tit {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin: 0 auto 2.9rem;
	font-size: 3.8rem;
	font-weight: 700;
	line-height: 1.25;
	position: relative;
}

.free_list__tit .note {
	font-size: 1rem;
	display: block;
	position: absolute;
	bottom:0.5em;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	font-weight: 100;
}
.free_list__lead {
	margin-bottom: 2.1rem;
	font-size: 2.1rem;
	font-weight: 700;
	text-align: center;
}


@media screen and (min-width:769.02px) {
	.free_list__tit {
		width: 21rem;
		height: auto;
		aspect-ratio: 1/1;
	}
}

@media screen and (max-width:769px) {
	.free {
		padding-top: 1rem;
	}
	.free_list {
		grid-template-columns: 1fr;
	}

	.free_list__tit {
		width: 20rem;
		height: 7rem;
		margin-bottom: 1.55rem;
		font-size: 2rem;
	}

	.free_list__lead {
		margin-bottom: 0.96rem;
		font-size: 1.6rem;
		line-height: 1.56;
	}
}



/*******************
	.service_contents
********************/
.service_contents {
	padding: 80px 0;
	background: var(--color-green);
	position:relative;
}


.service_contents:before, .voices:before {
	    position: absolute;
	    left: 0;
	    top: -3.4vw;
	    width: 100%;
	    height: 3.4vw;
	    background-image: url(../img/SVG/bg-green-top.svg);
	    content: "";
	    background-size: cover;
	    background-repeat: no-repeat;
}

.service_contents:after, .voices:after {
	    position: absolute;
	    left: 0;
	    bottom: -3.6vw;
	    width: 100%;
	    height: 3.6vw;
	    background-image: url(../img/SVG/bg-green-bottom.svg);
	    content: "";
	    background-size: cover;
	    background-repeat: no-repeat;
}


.service_contents_list {
	display: grid;
	grid-template-columns: repeat(6 , 1fr);
	column-gap: 1.6rem;
	row-gap: 1.6rem;
	padding: 20px 0;
}

.service_contents_list__img_box img {
	width: 100%;
}

.service_contents h2 {
	color:#FFF;
}

.service_contents .notion{
	color:#FFF;
}

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

@media screen and (max-width:769px) {
	.service_contents {
		padding-bottom: 5.6rem;
	}
	.service_contents_list {
		grid-template-columns: repeat(3 , 1fr);
		column-gap: 1rem;
		row-gap: 1rem;
	}

	.service_contents .notion{
	font-size:1rem;
}
}

/*******************
	.bottom_button_set
********************/

.bottom_button_set {
	background:#FFF;
	padding: 50px 0 0;
}

.bottom_button_set .contents_wrapper {
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
}

.bottom_button_set .btn {
	background: #ffd56e;
	min-width:300px;
	max-width: 364px;
	padding: 40px 20px;
	width:40%;
	border-radius: 50px;
	color: #000;
	font-size: 2.4rem;
	margin: 0 16px;
	font-weight: 400;
	position:relative;
	margin-bottom:2.5rem;
	border: 0;
	font-family: "Kosugi Maru", sans-serif;
	line-height: 1;
	height: 100px;
}

.bottom_button_set .btn.require_btn {
	background: #00a384;
	color:#FFF;
}

.bottom_button_set .btn:before {
		content: "";
	position: absolute;
	bottom: 10px;
	left: 33px;
	display: block;
	width: 50px;
	height: auto;
	aspect-ratio: 30/40;
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
}

.bottom_button_set .btn:before,
.bottom_button_set .btn.require_btn:before {
	content:none;
}

/* 

.bottom_button_set .btn.more_btn:before {
	bottom: 0;
	width: 60px;
	height: auto;
	aspect-ratio: 30/40;
	left: 26px;
	background-image: url(../img2024/icon-img/SVG/icon-info.svg);
}


.bottom_button_set .btn.require_btn:before {
	background-image: url(../img2024/icon-img/SVG/icon-file.svg);
}
*/

 @media only screen and (max-width: 769px) {
	 .bottom_button_set .btn {
    padding: 1.6rem;
    width: 100%;
    font-size: 1.9rem;
    margin: 0 16px;
    margin-bottom: 2.5rem;
}

	 .bottom_button_set .btn.more_btn:before {
    bottom: -0.2rem;
    width: 4rem;
    height: auto;
    aspect-ratio: 30 / 40;
    left: 1.2rem;
}

.bottom_button_set .btn.require_btn:before {
	bottom: 0.3rem;
    width: 3.4rem;
    left: 1.3rem;
}
 }


/*******************
	secondary
********************/


.secondary .main_contents {
	margin-top: 11vw;
}

.secondary .wrap_head {
	display:flex;
	flex-wrap:wrap;
	margin-bottom:5rem;
	width:100%;
}

.secondary .wrap_head .text {
	width: 60%;
}

.secondary .wrap_head .pic {
	width: 40%;
	text-align: center;
}

.secondary .wrap_head .pic img {
	width:80%
}

.secondary .wrap_head .heading {
	text-align:left;
}

.secondary .wrap_head .lead {
	font-size:2rem;
	color:#4d4d4d;
}

/*******************
	.works
********************/
.works {
	padding: 100px 0 120px;
	background: var(--color-white);
	overflow: hidden;
}

.works__heading {
	color: #333;
}


.works_list__box {
	position: relative;
	padding: 1.6rem 1.6rem 1.8rem;
	border-radius: 1.17rem;
	background: var(--color-whitesmoke);
}
.works_list__img_box--inner {
	position: relative;
	display: block;
	margin-bottom: 2.1rem;
}
.works_list__img_box .pc_img {
	width: 100%;
	height: auto;
	object-fit: cover;
	object-position: top;
}
.works_list__img_box .mobile_img {
	position: absolute;
	bottom: -1.1rem;
	left: auto;
	right: 0.96rem;
}
.works_list__img_box--text {
	margin-bottom: 1.8rem;
}
.works_list__img_box--text p {
	color: #000;
	font-size: 1.4rem;
	line-height: 1.4;
	text-align: center;
}

.works_list__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 4.4rem;
	padding-bottom: 0.14em;
	border-radius: 100rem;
	border: 2px solid #00a384;
	background: #00a384;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 500;
}
.works_list__btn:hover {
	opacity: 1;
	background: #fff;
	color: var(--color-green);
}


@media screen and (min-width:769.02px) {
	.works_list {
		display: grid;
		grid-template-columns: repeat( 4 , 1fr );
		gap: 1.6rem;
	}

	.works_list__box .pc_img {
		aspect-ratio: 259/247;
	}
}

@media screen and (max-width:769px) {
	.works {
		padding: 6rem 0 3.1rem;
	}
	
	.works_list__box {
		padding: 1.25rem 1.25rem 1.3rem;
	}

	.works_list__img_box--inner {
		margin-bottom: 1.87rem;
	}

	.works_list__img_box .mobile_img {
		width: 4.7rem;
	}

	.works .works_list.works_slider_sp {
		margin-top: 2rem;
		margin-bottom: 3.4rem;
	}

	.works_list__img_box--text {
		margin-bottom: 1.5rem;
		font-size: 1.19rem;
		line-height: 1.4;
		min-height: 4.5em;
	}
	.works_list__img_box--text p {
		display: inline-block;
		text-align: left;
		font-size: 1em;
		line-height: 1.4;
	}

	.works_list__btn {
		height: 3.4rem;
		font-size: 1.25rem;
	}
}



/*******************
	.flow
********************/

/* 
.flow_step {
	display: grid;
	grid-template-columns: repeat( 4 , 1fr );
	column-gap: 1.8rem;
	row-gap: 2.2rem;
}

.flow_step__box {
	position: relative;
	background: #fff;
}
.flow_step__box:nth-of-type(n+2)::before {
	content: "";
	position: absolute;
	top: 52%;
	left: -0.5rem;
	transform: translateX(-50%) translateY(-50%);
	display: block;
	width: 5rem;
	height: 1.5rem;
	background: var(--color-green);
	clip-path: polygon( 0% 40% , 73.7% 40% , 73.7% 0% , 100% 50% , 73.7% 100% , 73.7% 60% , 0% 60% );
}

.flow_step__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 3.7rem;
	background: var(--color-whitesmoke);
	color: var(--color-black01);
	font-size: 1.8rem;
	font-weight: 700;
}
.flow_step__inner {
	display: block;
	padding: 2rem 2.2rem 2.5rem;
}

.flow_step__text {
	
}
.flow_step__text a {
	color: var(--color-blue);
	text-decoration: underline;
}
.flow_step__text a:hover {
	text-decoration: none;
}

.flow_step__text span.indent{
	display: block;
	text-indent: -1em;
	padding-left: 1em;
	margin-top: 1rem;
}


.flow_step__detail_box {
	position: relative;
}

.flow_step__detail_box li::before {
	content: "●";
}

*/



.flow {
	background-color: var(--color-white);
	overflow-x: hidden;
}
.flow .contents_wrapper {
	max-width:900px;
}

.flow_step {	
}

.flow_step .flow_step__box {
	position: relative;
}

.flow_step .flow_step__box:after {
	width:100%;
	height: 1px;
	background:#dddddd;
	bottom:20px;
	left:0;
	content:"";
	position:absolute;
}

.flow_step .flow_step__box:last-child:after {
	content:none;
}

.flow_step .flow_step__box  .flow_step__inner {
	padding-left:100px;
	padding-right: 220px;
	position:relative;
	height:180px;
}

.flow_step .flow_step__box .flow_step__inner:before {
	    position: absolute;
	    left: 0;
	    top: 0;
	    width: 86px;
	height:138px;
	    background-size: contain;
	    background-repeat: no-repeat;
	    pointer-events: none;
	    content: "";
}

.flow_step .flow_step__box.step1 .flow_step__inner:before {
	background-image: url(../img/SVG/step1.svg);
}
.flow_step .flow_step__box.step2 .flow_step__inner:before {
	background-image: url(../img/SVG/step2.svg);
}
.flow_step .flow_step__box.step3 .flow_step__inner:before {
	background-image: url(../img/SVG/step3.svg);
}
.flow_step .flow_step__box.step4 .flow_step__inner:before {
	background-image: url(../img/SVG/step4.svg);
}
.flow_step .flow_step__box.step5 .flow_step__inner:before {
	background-image: url(../img/SVG/step5.svg);
}

.flow_step .flow_step__box .flow_step__inner .flow_step__text {
	
}

.flow_step__inner .flow_step__text h3 {
	margin-bottom:0.6rem;
}


.flow_step .flow_step__box .flow_step__inner .flow_step__img_box {
	position:absolute;
	right:0;
	top:0;
	max-width: 185px;
}


.flow__heading {
		color: #333;
		position:relative;
		margin-bottom:10rem;
	}

.flow__heading:before {
	position:absolute;
    left: 50%;
    bottom: -30px;
    width: 100%;
	height:8px;
    background-image: url(../img/SVG/flow-heading.svg);
    background-size: contain;
    background-repeat: no-repeat;
    content: ""; 
	z-index:0;
}

.flow .ex-donate {
	padding:30px;
	border: 1px solid #dddddd;
	border-radius: 5px;
	display: flex;
}

.flow .ex-donate img {
	width:400px;
}

.flow .ex-donate p {
	padding-left:30px;
}

.flow_step__img_box {

}

.flow_step__img_box img {
	aspect-ratio:4 /3;
	object-fit: cover;
}

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

	.flow_step__img_box {
		margin-bottom: 1.55rem;
	}

	.flow_step__detail_box {
		position: absolute;
		top: calc(100% + 2.8rem);
		left: 50%;
		transform: translateX(-50%);
		width: 58.2rem;
		padding: 2.1rem 2.5rem 2.2rem;
		background: var(--color-green);
		color: #fff;
		font-size: 1.4rem;
	}
	.flow_step__detail_box::before {
		content: "";
		position: absolute;
		top: 0;
		left: 50%;
		transform: translateX(-50%) translateY(-100%);
		width: auto;
		height: 3.2rem;
		aspect-ratio: 30/27;
		background: #fff;
		clip-path: polygon( 0 0 , 100% 0 , 50% 100%);
	}

	.flow_step__tit {
		display: flex;
		align-items: center;
		justify-content: center;
		margin-bottom: 1.4rem;
		font-size: 1.96rem;
		font-weight: 700;
		line-height: 1.4;
		min-height: 2.8em;
		text-align: center;
	}
}

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

	.flow__heading {
    margin-bottom: 4rem;
    font-size: 2rem;
}


	.flow_step .flow_step__box .flow_step__inner .flow_step__img_box {
		position: absolute;
		width: 120px;
		top: 19vw;
	}
	.flow_step {
		grid-template-columns: 1fr;
		row-gap: 2.9rem;
	}

	.flow_step__box:nth-of-type(n+2)::before {
		top: -0.69rem;
		left: 50%;
		transform: translateX(-50%) translateY(-100%);
		width: 1.55rem;
		height: 1.37rem;
		clip-path: polygon( 0 0 , 100% 0 , 50% 100%);
	}

	.flow_step__num {
		height: 3.4rem;
	}

	.flow_step__inner {
		display: flex;
		grid-template-columns: 11.9rem 1fr;
		column-gap: 1.8rem;
		padding: 1.5rem 1.1rem 1.82rem 1.6rem;
		flex-direction: column;
		flex-wrap: wrap;
	}

	.flow_step .flow_step__box .flow_step__inner:before {
		background-image: none!important;
	}

	.flow_step .flow_step__box.step1 .flow_step__inner:before {
		
	}

	.flow_step__img_box {
		grid-row: 1 / 3;
	}
	.flow_step__img_box img {
		width: 100%;
		height: 13.8rem;
		object-fit: cover;
	}

	.flow_step__tit {
		margin-top: -0.18em;
		margin-bottom: 0.34em;
		text-align: left;
		font-size: 1.6rem;
		line-height: 1.44;
	}
	.flow_step__text {
		width: calc(100% - 135px);
		min-height: 40vw;
	}

	.flow_step__detail_box {
		margin-top: 1rem;
		grid-column: 1 / 3;
		color: var(--color-green);
	}

	.flow_step .flow_step__box .flow_step__inner {
    padding-left: 0;
    padding-right: 0;
    position: relative;
    height: auto;
    margin-bottom: 1rem;
    border-bottom: 5px solid #EEE;
    padding-bottom: 1rem;
}

	.flow_step .flow_step__box:last-child .flow_step__inner {
		border-bottom:none; 
	}

	.flow .ex-donate img {
    width: 81%;
}

	.flow_step .flow_step__box:after {
	/* width:100%; */
	/* height: 6px; */
	/* bottom:0px; */
	/* left:0; */
	/* content:""; */
	/* position:absolute; */
	width: 37px;
	height: 10px;
	bottom: -9px;
	left:50%;
	/* content:""; */
	position:absolute;
	background:none;
	background-image: url(../img/SVG/bg-arrow-under.svg);
	content:"";
	transform: translateX(-50%);
}

	.flow_step .flow_step__box .flow_step__inner .step {
		width:100%;
		margin-bottom:2rem;
		padding:5px 8px;
		color:#FFF;
		font-weight:500;
		font-size:1.5rem
	}

	.flow .ex-donate {
    padding: 20px;
    border-radius: 5px;
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
}

	.flow .ex-donate p {
    padding-left: 0px;
		margin-bottom:2rem;
}

	.flow_step .flow_step__box .flow_step__inner .step span {
		font-size:2rem
	}

	.flow_step .flow_step__box .flow_step__inner .step.step1 {
		background:#fccb5b;
	}
	.flow_step .flow_step__box .flow_step__inner .step.step2 {
		background:#bdc165;
	}
	.flow_step .flow_step__box .flow_step__inner .step.step3 {
		background:#7eb770;
	}
	.flow_step .flow_step__box .flow_step__inner .step.step4 {
		background:#3fad7a;
	}
	.flow_step .flow_step__box .flow_step__inner .step.step5 {
		background:#00a384;
	}
}

/*******************
	.sustainable
********************/

.sustainable {
	background-color: #ebf2f2;
	position:relative;
	padding: 80px 0;
	width:100%;
}

.sustainable .only-pc {
	
}

.sustainable .only-sp {
	display:none;
}

.sustainable:before {position: absolute;left: 0;top: -3.4vw;width: 100%;height: 3.4vw;background-size: cover;background-image: url(../img/SVG/bg-gray-top.svg);content: "";}


.sustainable:after {
    position: absolute;
    left: 0;
    bottom: -3.4vw;
    width: 100vw;
    height: 3.4vw;
    background-size: cover;
    background-image: url(../img/SVG/bg-gray-bottom.svg);
    content: "";
}

.sustainable .bg-earth {
	position:relative;
}

.sustainable .thinking p {
	text-align: left;
}

.sustainable .bg-earth:before {
		    position: absolute;
		    right: 2%;
		    top: 0;
		    width: 58%;
		    height: 60vw;
		    background-image: url(../img/SVG/bg-earth.svg);
		    content: "";
		    background-size: cover;
		    background-repeat: no-repeat;
		    /* max-width: 669px; */
		    max-height: 805px;
		    max-width: 788px;
}

.sustainable .heading {
	position:relative;
	margin-top: 20px;
	font-size: 3.6rem;
	text-align: left;
	left: 111px;
}

.sustainable .heading:before {
		position:absolute;
		left: -62px;
		transform: translateX(-50%);
		top: -10px;
		width: 107px;
		height: 111px;
		background-image: url(../img/SVG/icon-sustinable.svg);
		background-size: contain;
		background-repeat: no-repeat;
		content: "";
}

.sustainable p {
	margin-bottom:1em;
	font-size: 1.8rem;
	line-height: 2.4;
}

.sustainable .link {margin: 2rem 0;}

.sustainable .link .btn {
	position:relative;
	border:0;
	margin-bottom: 2rem;
}

.sustainable .link.link1 .btn,  .feature .feature-content .btn {
	background:#a0c638;
	color:#FFF;
}

.sustainable .link.link2 .btn {
	background:#0d9b80;
	color:#FFF;
}

.sustainable .link.link3 .btn {
	background:#f0dc68;
	color:#2c2c2c;
	margin-right: 1rem;
}

.sustainable .link .btn:before, .feature .feature-content .btn:before {
	position: absolute;
    left: 12px;
    top: 12px;
    width: 20px;
    height: 20px;
    background-image: url(../img/SVG/arrow-btn2.svg);
    content: "";
    background-size: cover;
    background-repeat: no-repeat;
}
.sustainable h4 {
	margin-bottom:2rem;
	font-size: 1.8rem;
	position:relative;
	margin-bottom: 30px;
	padding-left:10px;
	background: #FFF;
	display: inline-block;
	padding: 8px 30px;
	border-radius: 3px;
}

.sustainable p.indent {
    text-indent: -1em;
    padding-left: 1em;
}

/* 

.sustainable h4:before {
	position:absolute;
	width:70px;
	height:3px;
	background:#c0c0c0;
	content:"";
	bottom:-1rem;
}

*/

.sustainable .site_link_wrap {
    display: grid; /* グリッドレイアウト */
    column-gap: 30px;
    row-gap: 30px;
    grid-template-columns: 1fr 1fr 1fr;
    }

.sustainable .site_link_wrap .site {
position:relative;
}

.sustainable .site_link_wrap .site:before {
	width:1px;
	height:100%;
	background:#262626;
	position:absolute;
	content:"";
	right:-20px;
	top:0;
}

.sustainable .site_link_wrap .site:last-child:before {
	content:none;
}

.sustainable .site_link_wrap .site .logo {
	width:auto;
	min-width:130px;
	text-align:center;
}

.sustainable .site_link_wrap .site .logo img {
	width:96px;
}

.sustainable .site_link_wrap .site.bengoshi .logo img {
	width:120px;
}

.sustainable .site_link_wrap .site .text {
	padding-left:20px;
}


.sustainable .site_link_wrap .site .text p {
	font-size:1.5rem;
	line-height:1.8;
	font-weight:100;
}

.sustainable .site_link_wrap .site .text .site_name {
	font-weight:500;
	font-size:1.65rem;
	margin-bottom:1.5rem;
	display:block;
	text-decoration:underline;
}

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

.sustainable {
    padding: 40px 0;
}

	.sustainable .only-pc {
	display:none;
	
}

	.sustainable .only-sp {
		display:block;
	}
	.sustainable .heading {
    margin-top: 0;
    font-size: 2rem;
    text-align: center;
    left: 0;
    padding-top: 77px;
}
.sustainable .heading:before {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    width: 77px;
    height: 60px;
    background-image: url(../img/SVG/icon-sustinable.svg);
    background-size: contain;
    background-repeat: no-repeat;
    content: "";
}

	.sustainable .site_link_wrap .site:before {
	width:100%;
	height:1px;
	background:#262626;
	position:absolute;
	content:"";
	right:auto;
	top:auto;
	bottom:0;
}

	.sustainable .bg-earth:before {
		content:none;
	}

	.sustainable p {
    margin-bottom: 1em;
    font-size: 1.5rem;
    line-height: 2;
}

	.sustainable .link .btn {
		width: 320px;
		margin: auto;
		display: block;
	}

	.feature .feature-content .btn {
		width: 317px;
	}

	.bottom_button_set .btn {
    background: #ffd56e;
    padding: 30px 20px;
    width: 40%;
    border-radius: 50px;
    font-size: 1.8rem;
    margin: 0 16px;
    position: relative;
    margin-bottom:2rem;
    border: 0;
    height: 80px;
}

	.footer_logo {
    padding: 0 24px
}

	.footer_logo_margin {
		margin-bottom:5rem;
		padding-top: 50px!important;
	}

	.sustainable h4 {
	text-align: center;
	width: 100%;
}


	/* 
.sustainable h4:before {
	position:absolute;
	width:70px;
	height:3px;
	background:#c0c0c0;
	content:"";
	bottom:-1rem;
	left: 50%;
	transform: translateX(-50%);
}
	*/

	.sustainable .site_link_wrap .site .logo img {
    width: 130px;
}

	.sustainable .site_link_wrap .site.bengoshi .logo img {
		width:150px;
	}

	.sustainable .site_link_wrap .site .text p {
    font-size: 1.25rem;
}

	.sustainable .site_link_wrap .site .text .site_name {
    font-weight: 500;
    font-size: 1.5rem;
    margin-bottom: 1.2rem;
		text-align:center;
		margin-top:1rem;
}

	.sustainable .link.link3 .btn {
	margin: auto;
	margin-bottom: 1rem;
	}

	.feature .feature-content .btn:before, .sustainable .link .btn:before {
	left: 12px;
	top: 20px;
	}

	.sustainable .site_link_wrap {grid-template-columns: 1fr;}

	.sustainable .site_link_wrap .site {
    flex-direction: column;
}

	.sustainable .site_link_wrap .site .logo {
		width:100%;
	}
	.sustainable .site_link_wrap .site .text {
    padding-left: 0;
}

	.sustainable .link.link3 {
		padding-top:2rem;
	}
}

@media screen and (max-width:575px) {
	.sustainable .link .btn {
		width: 280px;
		margin: auto;
		display: block;
	}
	.feature .feature-content .btn {
		width: 280px;
	}
}

/*******************
	footer_logo
********************/


.footer_logo {
	background:#FFF;
	text-align:center;
	padding-top: 100px;
}

/*******************
	.voices
********************/
.voices {
	background: var(--color-green);
	position: relative;
}

.voices.main_section {
    padding: 9rem 0 7.3rem;
}

.voices h2.heading {
	    color: var(--color-white);
}

.voices_list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3.2rem;
}

.voices_list__box {
	padding: 0 3.4rem 3.7rem;
	border-radius: 2rem;
	background: #fff;
}

.voices_list__tit_block {
	width: 100%;
	max-width: 39rem;
	padding: 1.9rem 3.1rem 2.2rem;
	margin-bottom: 1rem;
	background: #ffd56e;
	color: #000;
}
.voices_list__tit {
	font-size: 2.1rem;
	line-height: 1.5;
	min-height: 3em;
	margin-bottom: 1.1rem;
}

.voices_list__profile {
	font-size: 1.4rem;
}


@media screen and (min-width:769.02px) {
	.voices .js-acc_switch {
		cursor: none;
		pointer-events: none;
	}
	.voices .js-acc_switch::after {
		display: none;
	}
	.voices .acc_block {
		display: block!important;
	}
}

@media screen and (max-width:769px) {
	.voices_list {
		grid-template-columns: 1fr;
		column-gap: 0;
		row-gap: 1.62rem;
	}
	
	.voices_list__box {
		width: 100%;
		padding: 0;
		border-radius: 0;
	}

	.voices_list__tit_block {
		padding: 1.3rem 4rem 1.7rem 2rem;
		margin-bottom: 0;
	}
	.voices_list__tit {
		margin-bottom: 0.62rem;
		font-size: 1.6rem;
	}
	.voices_list__profile {
		font-size: 1.37rem;
	}

	.voices_list__text {
		padding: 1.5rem 2.2rem 1.8rem;
	}

	.voices .js-acc_switch::after {
		--size: 1.1rem;
		--border: 0.25rem solid #fff;
		content: "";
		position: absolute;
		top: auto;
		bottom: 1.76rem;
		right: 1.9rem;
	}

}




/*******************
	.qanda
********************/
.qanda {
	background: var(--color-white);
}
.qanda__heading {
	color: #fff;
}

.qanda_wrapper {
	display: grid;
	grid-template-columns: auto 78.7rem;
	column-gap: 4rem;
	row-gap: 3.8rem;
}

.qanda__tit {
	color: var(--color-black02);
}

	

.color-green {
	color: var(--color-green);
}

.qanda_block {
	width: 100%;
}

.qanda_block dl {
	width: 100%;
}

.qanda_block .acc_wrapper:nth-of-type(n+2) {
	margin-top: 1rem;
}

.qanda-here {
	text-decoration:underline;
	color:#ff6500;
}


.qanda_contents {
	border: 0.15rem solid var(--color-whitesmoke);
	border-radius: 1rem;
}

.qanda__question {
	position: relative;
	cursor: pointer;
	color: #fff;
	margin-bottom:5px;
	background: var(--color-green);
}
.qanda__question:hover {
	background: #23bc7b;
}

.qanda__answer {
	border-radius: 0;
	border: 0;
	margin-bottom: 2.2rem;
}

.qanda_contents__inner {
	display: flex;
	align-items: center;
	column-gap: 0.89rem;
	padding: 1.3rem 5rem 1.5rem 1.19rem;
}
.qanda__answer .qanda_contents__inner {
	align-items: flex-start;
	padding-top: 2rem;
	padding-bottom: 2.5rem;
	border-radius: 1rem;
	background: var(--color-white);
	border: 1px solid #d3d3d3;
}

.qanda_contents__icon {
	text-align: center;
	min-width: 4.7rem;
	margin-top: -0.19em;
	color: var(--color-gold01);
	font-size: 3.5rem;
	font-weight: 700;
}
.qanda__answer .qanda_contents__icon {
	margin-top: -0.25em;
	color: #e0b64c;
}

.qanda_contents__text {
	flex: 1;
	font-weight: 500;
	font-family: var(--font-Noto_Serif);
	line-height: 1.7;
}

.qanda_contents__text .underline {
	text-decoration: underline;
}


@media screen and (max-width:769px) {
	.qanda_wrapper {
		grid-template-columns: 1fr;
		row-gap: 0;
	}
	.qanda__heading {
		margin-bottom: 2.2rem;
	}
	.qanda__tit {
		margin-top: 2.5rem;
		margin-bottom: 1.3rem;
		font-size: 1.7rem;
		text-align: center;
	}

	.qanda_contents {
		border-radius: 0.77rem;
	}
	.qanda_block .acc_wrapper:nth-of-type(n+2) {
		margin-top: 0.82rem;
	}

	.qanda__question::after {
		right: 2rem;
	}

	.qanda__answer {
		margin-bottom: 1rem;
	}

	.qanda_contents__icon {
		min-width: 2.5rem;
		font-size: 2rem;
	}

	.qanda_contents__inner {
		padding: 1rem 4.7rem 1.1rem 1rem;
	}
	.qanda__answer .qanda_contents__inner {
		padding-top: 1.56rem;
		padding-bottom: 1.8rem;
		padding-right: 1.7rem;
	}

	.qanda_contents__text {
		font-size: 1.4rem;
	}
}



/*******************
	.lead_section
********************/
.lead_section {
	padding: 2.2rem 0 6.2rem;
}

.lead_section__text {
	margin: 0 auto;
	text-align: center;
	margin-top: 5.1rem;
	margin-bottom: 2.5rem;
}

.lead_section__heading {
	margin: 0 auto;
	text-align: center;
}

.lead {
	display:flex;
	justify-content: center;
	margin-bottom:5rem;
}

.lead p {
		width:62%;
	font-size:2rem;
}


@media screen and (max-width:769px) {
	
	.lead_section {
		padding: 0.4rem 0 3.4rem;
	}
	
	.lead_section__text {
		width: 76%;
		margin-top: 2.5rem;
		margin-bottom: 1.4rem;
	}
	
	.lead_section__heading {
		width: 77%;
		text-align: center;
	}

	.lead p {
		width:100%;
	font-size:1.4rem;
}
}





/*******************
	.bnr_tel_block
********************/
.bnr_tel_block {
	background: #fff;
	padding: 0 0 2rem;
}

.bnr_tel_box {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: 1.5rem 0;
	overflow: hidden;
	flex-direction: column;
}

.bnr_tel_box__img_block {
	width: 39rem;
	height: 21rem;
}
.bnr_tel_box__img_block img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
}


.bnr_tel_box__text_block {
	margin-top: 1.4rem;
	flex: 1;
}
.bnr_tel_box__text {
	margin: 0 0 1.4rem;
	text-align: center;
	font-size: 1.9rem;
	font-weight: 500;
	font-family: "Kosugi Maru", sans-serif;
}
.bnr_tel_box .tel_block {
	display: block;
	margin: 0;
}
.bnr_tel_box .tel_block__tel img {
	width: 100%;
}

.bnr_tel_box .tel_block__reception_time {
	text-align:center;
	margin-top: 1.7rem;
	font-size: 1.75rem;
}

@media screen and (max-width:769px) {
	.bnr_tel_block {
		padding-bottom: 5rem;
	}
	.bnr_tel_box {
		padding: 0 1.8rem 2rem;
		border-radius: 0.77rem;
		flex-direction: column;
		overflow: inherit;
	}

	.bnr_tel_box__img_block  {
		width: 28rem;
		margin-top: -4rem;
		margin-left: auto;
		margin-right: auto;
		height: 12.5rem;
	}
	

	.bnr_tel_box__text_block {
		margin-top: 0.87rem;
		width: 100%;
	}
	.bnr_tel_box__text {
		margin-bottom: 0.7rem;
		font-size: 1.37rem;
		text-align: center;
	}
	.bnr_tel_box .tel_block__reception_time img {
		display: block;
		width: 20rem;
		margin: 1.17rem auto 0;
	}
}




/*******************
	.contact
********************/
.contact {
	position: relative;
	padding: 100px 0 120px;
	background: #fff;
}

.contact .contents_wrapper {
	position: relative;
}
.contact__heading {
	text-align: center;
	/* padding-top: 3.4rem; */
	/* margin: 3.4rem auto 3.7rem; */
}


@media screen and (max-width:769px) {
	.contact {
		padding: 6rem 0 3.1rem;
	}


	.contact__heading {
		margin-top: 0.1rem;
		margin-bottom: 1.7rem;
	}
}

/**********
   contactForm
***********/


#contactForm {
--border: 0.11rem solid #cecece;
	width: 100%;
	max-width: 104.8rem;
	margin-left: auto;
	margin-right: auto;
	font-size: 1.4rem;
	overflow: hidden;
}

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

#contactForm input[type="text"],
#contactForm input[type="time"],
#contactForm select,
#contactForm textarea {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 100%;
	max-width: 100%;
	padding: 1rem;
	padding-left: 1.77rem;
	outline: none;
	border-radius: 1rem;
	border: var(--border);
	background: var(--color-whitesmoke);
	font-feature-settings: "salt";
	color: var(--color-black01);
}

#contactForm input,
#contactForm select,
#contactForm textarea {
	font-size: 1.6rem;
	font-weight: 500;
	font-family: var(--font-base);
}
input[type="time"]::-webkit-date-and-time-value {
	text-align: left;
}
input[type="time"] {
	position: relative;
}
input[type="time"]::-webkit-calendar-picker-indicator {
	position: absolute;
    width: 100%;
    height: 100%;
	opacity: 0;
}
#contactForm select {
	appearance: none;
	cursor: pointer;
}
#contactForm .form-select_wrapper {
	position: relative;
}
#contactForm .form-select_wrapper::after {
	--size: 1.5rem;
	content: "";
	bottom: 1.3rem;
	right: 1.5rem;
	transform: translateY(-50%);
    position: absolute;
    width: var(--size);
    height: calc(var(--size) * (13/15));
    background-color: #231815;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    pointer-events: none;
}

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


#contactForm .form-wrap {
	border: var(--border);
	border-top: 0;
}
#contactForm .form-wrap:first-child {
	border-top: var(--border);
}

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

#contactForm .form-contents_title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	border-right: var(--border);
	background: var(--color-whitesmoke);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.44;
}
#contactForm .form-contents_title::after {
	content: "任意";
	position: relative;
	display: inline-block;
	padding: 0.2em 0.56em 0.25em;
	background: #b8b8b7;
	white-space: nowrap;
	color: #fff;
	font-size: 1.39rem;
	margin-left: 0.05em;
}
#contactForm .required .form-contents_title::after {
	content: "必須";
	background: var(--color-green);
}
#contactForm .form-contents_title .attention_text {
	display: inline-block;
	font-size: 0.87em;
	margin: 0.2em 0 -0.2em;
}
#contactForm .form-contents_title .attention_text:first-of-type {
	margin-top: 0.5em;
}

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


#contactForm .formErrorContent .only_single {
	display: none!important;
}
#contactForm .formErrorContent .only_single ~ br {
	display: none;
}
#contactForm .formErrorContent .only_single:first-of-type:last-of-type {
	display: inherit!important;
}


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




/* contact btn */
.form_btn_block {
	display: flex;
	align-items: center;
	justify-content: center;
	column-gap: 5rem;
	margin: 3.9rem auto 0;
}
.form_btn_block .contact_btn {
	position: relative;
	width: 100%;
	height: 12.5rem;
	margin: 0 auto;
	border: none!important;
	border-radius: 0!important;
}
.form_btn_block .contact_btn::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #fff;
}
.form_btn_block.flex_base .contact_btn {
	margin: 0;
}
#contactForm .form_btn_block .contact_btn input,
.form_btn_block .contact_btn a {
	--color: #6fba2d;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding-bottom: 0.18em;
	margin: 0 auto;
	background: var(--color);
	border: 2px solid var(--color-green);
	border-radius: 1rem!important;
	-webkit-appearance: none;
	font-weight: 500;
	font-size: 2.62rem;
	font-family: var(--font-base);
	color: #fff;
	cursor: pointer;
}


.form_btn_block .contact_btn:hover {
	opacity: 0.87;
}
#contactForm .form_btn_block .contact_btn:hover input,
.form_btn_block .contact_btn:hover a {
	background: transparent;
	color: var(--color-green);
}

.form_btn_block .submit_btn {
	width: 37rem;
}
.form_btn_block .return_btn {
	width: 29rem;
}

#contactForm .form_btn_block .submit_btn input {
	--color: var(--color-green);
}
#contactForm .form_btn_block .return_btn input,
.form_btn_block .return_btn a {
	--color: #787878;
	transition: 0s;
}

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


#contactForm .formError {
	position: static!important;
	margin: 0!important;
	pointer-events: none;
}
#contactForm .formErrorContent {
	font-size: 1.8rem;
	font-weight: 700;
	margin: 0rem auto 0.62rem;
	color: #fff;
	background: var(--color-green);
	border-radius: 0.55rem;
}
#contactForm .formError .formErrorContent:after {
	transform: translate(0);
	top: calc(100% - 0.1rem);
	left:3.6rem;
	transform: translateX(50%);
	border-top-color: var(--color-green);
}

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



@media screen and (min-width:769.02px) {
	#contactForm .form-wrap {
		display: flex;
		align-items: stretch;
		justify-content: flex-start;
	}
	#contactForm .form-contents_title,
	#contactForm .form-inner {
		padding: 2.28rem 2.38rem 2.5rem;
	}
	#contactForm .form-contents_title {
		width: 24.4rem;
		height: 100%;
	}
	#contactForm .form-wrap dd{
		max-width: calc(100% - 24.4rem);

	}

	#contactForm input[type="text"],
	#contactForm input[type="time"],
	#contactForm select {
		width: 100%;
		height: 5.45rem;
	}

	/* width調整 */
	#contactForm .form-wrap[data-name="zip"] .form-inner,
	#contactForm .form-wrap[data-name="city"] .form-inner,
	#contactForm .form-wrap[data-name="pref"] .form-inner {
		width: 32rem;
	}

	#contactForm .form-wrap[data-name="pic"] .form-inner,
	#contactForm .form-wrap[data-name="mail"] .form-inner,
	#contactForm .form-wrap[data-name="tel"] .form-inner,
	#contactForm .form-wrap[data-name="how"] .form-inner{
		width: 48.2rem;
	}

	#contactForm .radio_list label  {
		padding-right: 4rem;
	}
}


@media screen and (max-width:769px) {
	#contactForm input, #contactForm select, #contactForm textarea {
		font-size: 1.4rem;
	}
	#contactForm input[type="text"],
	#contactForm input[type="time"],
	#contactForm select,
	#contactForm textarea {
		padding: 0.5rem;
		padding-left: 1.5rem;
		border-radius: 0.62rem;
	}
	#contactForm input[type="text"],
	#contactForm input[type="time"],
	#contactForm select {
		height: 4.1rem;
	}

	#contactForm .form-select_wrapper::after {
		--size: 1.4rem;
		bottom: 0.77rem;
	}

	#contactForm textarea {
		height: 15rem;
	}
	#contactForm .form-wrap {
		display: block;
		padding: 0.51rem 0 2rem;
	}
	#contactForm .form-wrap {
		border: 0!important;
	}

	#contactForm .form-contents_title {
		align-items: flex-start;
		justify-content: flex-start;
		column-gap: 1rem;
		width: 100%;
		line-height: 1;
		margin-bottom: 1rem;
		padding: 0;
		padding-left: 0.02em;
		background: transparent;
		border: 0;
		font-size: 1.4rem;
	}
	#contactForm .form-contents_title .attention_text {
		font-size: 0.87em;
	}
	
	.form-contents_title, .form-inner {
		padding: 0;
	}

	#contactForm .form-contents_title::after {
		font-size: 1.1rem;
		margin-top: 0.05em;
	}

	/* contact btn */
	.form_btn_block {
		margin-top: 1.1rem;
	}
	.form_btn_block .contact_btn {
		width: 22rem;
		height: 7.3rem;
	}
	#contactForm .form_btn_block .contact_btn input,
	.form_btn_block .contact_btn a {
		font-size: 1.4rem;
	}

	.form_btn_block.flex_base {
		flex-direction: column-reverse;
		row-gap: 1.9rem;
		margin-top: 4.4rem;
	}
	.form_btn_block.flex_base .contact_btn {
		margin-right: auto;
		margin-left: auto;
		max-width: 60%;
	}


	#contactForm .formErrorContent {
		font-size: 1.5rem;
	}
}

#contactForm .form-preferred_date_block {
	display: flex;
	align-items: center;
	column-gap: 1.5rem;
}
#contactForm .form-preferred_date_block:nth-of-type(n+2) {
	margin-top: 1.4rem;
}

#contactForm .form-preferred_date_block__tit {
	white-space: nowrap;
	font-size: 1.62rem;
	font-weight: 500;
	margin-right: 1rem;
}
#contactForm .form-preferred_date_block > :not(.form-preferred_date_block__tit) {
	flex: 1;
}

#contactForm .form-preferred_date_block__date_wrapper {
	position: relative;
}
#contactForm .form-preferred_date_block__date_wrapper::after {
	content: "";
	position: absolute;
	bottom: 1.4rem;
	right: 1.5rem;
	display: block;
	width: 3rem;
	height: auto;
	aspect-ratio: 30/29;
	background-image: url(../img/icon-calendar.svg);
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
}
#contactForm .form-preferred_date_block__time_wrapper {
	position: relative;
}
#contactForm .form-preferred_date_block__time_wrapper input {
	cursor: pointer;
}
#contactForm .form-preferred_date_block__time_wrapper::after {
	content: "";
	position: absolute;
	bottom: 1.3rem;
	right: 1.5rem;
	display: block;
	width: 3rem;
	height: auto;
	aspect-ratio: 30/30;
	background-image: url(../img/icon-clock.svg);
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
}
#contactForm .form-preferred_date_block .formErrorContent span:nth-of-type(n+2) {
	display: none;
}
#contactForm input.form-datepicker {
	padding-right: 6.2rem;
	cursor: pointer;
}

@media screen and (max-width:769px) {
	#contactForm .form-preferred_date_block {
		flex-wrap: wrap;
	}
	#contactForm .form-wrap.date_wrap .form-contents_title::after {
		display: none;
	}
	#contactForm .form-preferred_date_block:first-of-type {
		margin-top: 1.3rem;
	}
	#contactForm .form-preferred_date_block__tit {
		width: 100%;
		margin-bottom: 0.77rem;
		font-size: 1.4rem;
		line-height: 1.1;
	}
	#contactForm .form-preferred_date_block__tit::after {
		content: "任意";
		position: relative;
		display: inline-block;
		padding: 0.2em 0.56em 0.25em;
		background: #b8b8b7;
		white-space: nowrap;
		color: #fff;
		font-size: 1.39rem;
		margin-left: 0.8em;
		font-size: 1.1rem;
	}
	#contactForm .form-preferred_date_block:first-of-type .form-preferred_date_block__tit::after {
		content: "必須";
		background: var(--color-greem);
	}

	#contactForm .form-preferred_date_block__date_wrapper::after {
		width: 2.1rem;
		bottom: 1.04rem;
		right: 1rem;
	}
	#contactForm .form-preferred_date_block__time_wrapper::after {
		width: 2.1rem;
		bottom: 0.96rem;
		right: 1.04rem;
	}

	#contactForm input.form-datepicker {
		padding-right: 4.4rem;
	}
}


/***   footer   ***/
.footer {
	position: relative;
	width: 100%;
	padding: 3.7rem 0 11rem;
	text-align: center;
	background: var(--color-green);
	color: #fff;
}

.footer:before {
	position: absolute;
	left: 0;
	top: -4.4vw;
	width: 100%;
	height: 4.4vw;
	background-image: url(../img/SVG/bg-footer-top.svg);
	content: "";
	background-size: cover;
	background-repeat: no-repeat;
}




.footer__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
}

.footer__inner p,
.footer_link_list__item {
	font-size: 1em;
}

.footer_link_list {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin-left: 4rem;
}
.footer_link_list__item {
	text-align: left;
	padding-bottom: 0.28em;
}
.footer_link_list__item a {
	padding: 0 2.5rem .1em;
	color: inherit;
	text-decoration: underline;
}
.footer_link_list__item a:hover {
	text-decoration: none;
}

.footer .copyright {
	font-size: 1.2rem;
	text-align: center;
	white-space: nowrap;
}

@media screen and (min-width:769.02px) {
	.footer__inner {
		font-size: 1.6rem;
	}
	.footer__inner p,
	.footer_link_list__item {
		line-height: 1.1;
	}
	.footer_link_list__item {
		border-left: 1px solid;
	}
}
@media screen and (max-width:769px) {
	.footer {
		padding: 2.2rem 0 7rem;
	}
	.home .footer {
		padding: 2.2rem 0 calc(1rem + var(--fixed_bottom-height));
	}
	.footer__inner {
		grid-template-columns: auto 1fr;
		font-size: 1.15rem;
	}

	.footer__address {
		grid-column: 1/3;
		text-align: left;
		margin-bottom: 1.1rem;
	}

	.footer_link_list {
		margin: 0;
	}
	.footer_link_list__item a {
		padding: 0;
		padding-right: 1em;
	}

	.footer__copyright {
		margin-left: 1rem;
		text-align: right;
	}
}





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

   cotntact page

*********************/
.contact_group {
	background: #fff;
}
.contact_group .main_contents {
	padding-top: 8.9rem;
	padding-bottom: 11.9rem;
	min-height: calc(100vh - 15rem);
}



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

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

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


@media screen and (max-width:769px) {
	.contact_group #body_inner {
		margin-bottom: 0;
	}
	.contact_group .main_contents {
		padding-top: 5.6rem;
		padding-bottom: 8.7rem;
	}

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

	.contact_group .page_lead {
		font-size: 1.55rem;
		margin-bottom: 3.8rem;
	}
}
#contactForm .form_btn_block .contact_btn {
	margin: 0;
}



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

   confirm page

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

.p-confirm .main_contents {
	padding-top: 300px;
}

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

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

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

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

.p-confirm .form_loading__bars span,
.p-confirm .form_loading__bars::before,
.p-confirm .form_loading__bars::after {
	content: "";
	display: block;
	background: #0097cd;
	width: 15rem;
	height: 0.62rem;
	margin-top: 1.18rem;
	animation: form_load 1.8s ease infinite;
	border-radius: 1rem;
}

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

@keyframes form_load {
	50%{
		width: 0.7rem;
		margin-right: 14.3rem;
		opacity: 0.5;
	}
}

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


.p-confirm #contactForm input:not([type="submit"]),
.p-confirm #contactForm .form-select_wrapper,
.p-confirm #contactForm textarea,
.p-confirm #contactForm select,
.p-confirm #contactForm .form-preferred_date_block__date_wrapper::after,
.p-confirm #contactForm .form-preferred_date_block__time_wrapper::after {
	background: transparent;
	color: #fff;
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
}

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

.p-confirm #contactForm .form-contents_title {
	width: 20rem;
}
.p-confirm #contactForm .form-wrap dd {
	max-width: 100%;
}
.p-confirm #contactForm .form-contents_title::after {
	display: none;
}



#contactForm .confirm_input_content {
	display: block;
	min-height: 1em;
	font-size: 1.8rem;
	font-feature-settings: "salt";
}
#contactForm textarea ~ .confirm_input_content {
	word-break: break-all;
}


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

	.p-confirm .message_wrap .form-inner {
		min-height: 3.2rem;
	}
	
	.p-confirm .main_contents {
		padding-top: 150px;
	}
	
}



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

   thanks page

***************/
.p-thanks .main_contents {
	margin-top: 200px;
}

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

.p-thanks .form_btn_block .return_btn a {
	--color: var(--color-green);
}





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

	.consult_contact page

********************/
.p-consult_contact {
	padding: 8.2rem 0 0;
	background: #fff;
}

.p-consult_contact #header .header__inner {
	justify-content: flex-start;
}
.p-consult_contact .header__text {
	margin-left: 1.4rem;
	font-size: 1.1rem;
	font-weight: 700;
	white-space: nowrap;
	transform: translateY(-5%);
}

.p-consult_contact main .contents_wrapper {
	max-width: 104rem;
}

@media screen and (max-width:769px) {
	.p-consult_contact {
		padding-top: 3.77rem;
	}
}

/*******************
	.consult_contact_lead
********************/
.consult_contact_lead {
	max-width: 69rem;
	margin: 0 auto 3.2rem;
}

.consult_contact_lead__heading {
	width: 100%;
	margin: 0 auto 3.1rem;
	text-align: center;
}
.consult_contact_lead__tit {
	width: 100%;
	margin: 0 auto 2.8rem;
	text-align: center;
}
.consult_contact_lead__text {
	text-align: center;
	margin: 0 auto 3.7rem;
	font-weight: 500;
}
.consult_contact_lead_list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 2.9rem;
	row-gap: 1.9rem;
	width: 100%;
	height: auto;
	padding: 3.4rem;
	padding-left: 5.4rem;
	border: 1.4px solid #231815;
	border-radius: 1.8rem;
}

.consult_contact_lead_list__item img {
	width: auto;
	height: 2.5rem;
}

@media screen and (min-width:769.02px) {
	.consult_contact_lead_list__item:nth-of-type(3) img,
	.consult_contact_lead_list__item:nth-of-type(4) img {
		height: 2.6rem;
	}
}
@media screen and (max-width:769px) {
	.consult_contact_lead {
		margin-bottom: 2rem;
	}
	.consult_contact_lead__heading {
		width: 86%;
		margin-bottom: 0.5rem;
	}
	.consult_contact_lead__tit {
		width: 86%;
	}
	.consult_contact_lead__text {
		margin-bottom: 2.28rem;
		font-size: 1.34rem;
		text-align: left;
		line-height: 1.7;
	}

	.consult_contact_lead_list {
		row-gap: 0.2rem;
		column-gap: 0;
		padding: 1.31rem 0.55rem 1.66rem;
		border-radius: 1rem;
	}

	.consult_contact_lead_list__item {
		margin-left: 1.3rem;
		text-align: left;
	}

	.consult_contact_lead_list__item img {
		height: 1.32rem;
	}
}

/*******************
	.consult_contact_lead
********************/
.online_consult_detail {
	position: relative;
}
.online_consult_detail__heading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.25em 0.1em 0.28em;
	margin: 0 auto 2rem;
	text-align: center;
	background: var(--color-green);
	color: #fff;
}

.online_consult_detail {
	max-width: 86rem;
	margin: 0 auto 2.5rem;
}

.online_consult_detail_block__inner {
	--border: 0.11rem solid #999;
	display: flex;
	align-items: stretch;
	border: var(--border);
	border-top: 0;
}
.online_consult_detail_block__inner:first-of-type {
	border-top: var(--border);
}
.online_consult_detail_block__inner > * {
	padding: 2.28rem 2.5rem 2.37rem;
}

.online_consult_detail_block__inner--heading {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24.4rem;
	height: auto;
	border-right: var(--border);
	background: var(--color-whitesmoke);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.44;
}
.online_consult_detail_block__inner--contents {
	flex: 1;
	font-weight: 500;
	line-height: 1.7;
}
.online_consult_detail_block__inner--contents_inner li {
	text-indent: -1em;
	padding-left: 0.81em;
}
.online_consult_detail_block .logo--google_meets {
	position: relative;
	transform: translateY(-8.2%);
	width: 16rem;
	margin-left: 2rem;
}

@media screen and (max-width:769px) {
	.online_consult_detail_block__inner--heading {
		width: 11.6rem;
		font-size: 1.4rem;
		text-align: center;
	}

	.online_consult_detail_block .logo--google_meets {
		width: 11rem;
		margin-left: 1rem;
	}

	.online_consult_detail_block__inner > * {
		padding: 1.3rem 1.5rem 1.5rem;
	}
	.online_consult_detail_block__inner--contents {
		padding: 1.3rem 0.5rem 1.5rem 1.55rem;
		font-size: 1.37rem;
		line-height: 1.6;
	}
	.online_consult_detail_block__inner--contents_inner li:nth-of-type(n+2) {
		margin-top: 0.28em;
	}
}

/*******************
	.form
********************/
.p-consult_contact #contactForm {
	max-width: 86rem;
}

.p-consult_contact .contact .attention_text {
	margin: 4.4rem 0;
	line-height: 1.9;
	font-weight: 500;
}
.p-consult_contact .contact .attention_text > span {
	display: inline-block;
	margin: 0.25em 0 0;
	text-indent: 1.15em;
}

.p-consult_contact .contact .attention_text a {
	color: var(--color-green);
	text-decoration: underline;
}
.p-consult_contact .contact .attention_text a:hover {
	text-decoration: none;
}

@media screen and (min-width:769.02px) {
	.p-consult_contact #contactForm .form-inner {
		width: 100%!important;
	}
}

@media screen and (max-width:769px) {
	.p-consult_contact .contact .attention_text {
		margin-top: 3.8rem;
		margin-bottom: 2.5rem;
		font-size: 1.18rem;
	}
	.p-consult_contact .contact .attention_text > span {
		text-indent: 0;
	}
}


/***********************************
	Additonal CSS for new services
************************************/

/* :: Import Fonts */
@import url("https://fonts.googleapis.com/css?family=Open+Sans:300,400,600,700");
@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&family=Oswald:wght@200..700&display=swap');
@import url(css/bootstrap.min.css);
@import url(css/classy-nav.css);
@import url(css/animate.css);
@import url(css/owl.carousel.css);
@import url(css/font-awesome.min.css);
@font-face {
  font-family: 'corp-bold';
  src: url("../fonts/Corporate-Logo-Bold-ver3.woff") format("woff");
}
@font-face {
  font-family: 'corp-medium';
  src: url("../fonts/Corporate-Logo-Medium-ver3.woff") format("woff");
}
@font-face {
  font-family: 'helveticaneuebold';
  src: url("../fonts/helvetica_neu_bold-webfont.woff2") format("woff2"), url("../fonts/helvetica_neu_bold-webfont.woff") format("woff");
  v
}
@font-face {
  font-family: 'helveticaneuemedium';
  src: url("../fonts/helveticaneue_medium-webfont.woff2") format("woff2"), url("../fonts/helveticaneue_medium-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}

.btn {
    display: inline-block;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    padding: 13px;
    font-size: 1.6rem;
    line-height: 1;
    border-radius: 23px;
    background:#FFF;
    height: 46px;
    width:266px;
    border: 1px solid #dedede;
    position: relative;
}

.btn:before {
	position: absolute;
	left: 16px;
	top: 16px;
	width: 12px;
	height: 12px;
	background-image: url(../img/SVG/arrow-btn3.svg);
	content: "";
	background-size: cover;
	background-repeat: no-repeat;
}

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

		.btn {
    font-size: 1.5rem;
    line-height: 60px;
    border-radius: 30px;
    background:#FFF;
    height: 60px;
    width: 218px;
    padding: 0px 30px;
}
	}

.btn:before {
    left: 14px;
    top: 14px;
}


.plan-list {
	padding-top:5rem;
	background:#FFF;
}

.plan-list p {
	margin-bottom:1.5rem;
}

.list-page .service-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.list-page .service-list .single-service {
  width: 45.5%;
  margin-bottom: 7em;
  position: relative;
}
.list-page .service-list .single-service:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 118px;
  height: 118px;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../img/bg-img/bg-pattern1.svg);
  z-index: -1;
}
.list-page .service-list .single-service .catch {
  font-family: corp-medium, sans-serif;
  margin-bottom: 0.2em;
  font-size: clamp(1em, 1.4vw, 1.125em);
/* font-size: 1.125em;*/
	line-height: 1.2;
}
.list-page .service-list .single-service .name {
  display: flex;
  /* flex-wrap:wrap; */
  justify-content: space-between;
  min-height: 122px;
  padding-bottom: 3em;
  position: relative;
  align-items: flex-end;
}
.list-page .service-list .single-service .name .piece {
  width: 35%;
  max-width: 170px;
  min-width: 100px;
}
.list-page .service-list .single-service .name .type {
  font-family: corp-bold, sans-serif;
  font-weight: 700;
	font-size: clamp(2em, 4vw, 3.4375em);
  line-height: 1.1;
  padding-left: 1.13em;
  position: relative;
  white-space: nowrap;
}
.list-page .service-list .single-service.service_plus .name .type {
  padding-left: 1.8em;
}
.list-page .service-list .single-service.service_nextstage .name .type {
  transform: scale(0.9, 1);
  transform-origin: top left;
  width: 80%;
}
.list-page .service-list .single-service .name .type:before {
  content: "";
  width: 1em;
  height: 2em;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 1;
}
.list-page .service-list .single-service.service_plus .name .type:before {
  width: 1.5em;
}
.list-page .service-list .single-service.service_plus .name .type span {
  font-size: clamp(0.8em, 1.2vw, 1em);
}
.list-page .service-list .single-service.service_simple .name .type:before {
  background-image: url(../img/service-img/mark_simple.png);
}
.list-page .service-list .single-service.service_startup .name .type:before {
  background-image: url(../img/service-img/mark_startup.png);
  height: 1.9em;
}
.list-page .service-list .single-service.service_standard .name .type:before {
  background-image: url(../img/service-img/mark_standard.png);
}
.list-page .service-list .single-service.service_factory .name .type:before {
  background-image: url(../img/service-img/mark_factory.png);
  width: 1.15em;
  top: 55%;
}
.list-page .service-list .single-service.service_nextstage .name .type:before {
  background-image: url(../img/service-img/mark_next.png);
  width: 1.14em;
  left: -5px;
}
.list-page .service-list .single-service.service_plus .name .type:before {
  background-image: url(../img/service-img/mark_plus.png);
}
.list-page .service-list .single-service.service_extra .name .type:before {
  background-image: url(../img/service-img/mark_extra.png);
  width: 1.12em;
}
.list-page .service-list .single-service.service_alpha .name .type:before {
  background-image: url(../img/service-img/mark_alpha.png);
  width: 1.13em;
  top: 53%;
}
.list-page .service-list .single-service .summary {
  font-size: clamp(1em, 1.4vw, 1em);
  letter-spacing: 0.05em;
	min-height: 5.5em;
}
.list-page .service-list .single-service .name:after {
  content: "";
  width: 100%;
  height: 1px;
  background: #c9caca;
  bottom: 2em;
  left: 0;
  position: absolute;
}
.list-page .service-list .single-service .performance {
  margin-bottom: 1em;
  min-height: 62px;
}
.list-page .service-list .single-service .performance span {
  display: inline-block;
  border: 2px solid #d8d8d8;
  padding: 0.3em 0.5em;
  margin: 0 3px 3px 0;
  border-radius: 5px;
  line-height: 1;
  font-size: clamp(0.75em, 1vw, 0.875em);
}
.list-page .service-list .single-service .fee {
  font-family: kinto-sans, sans-serif;
  font-weight: 600;
  font-size: clamp(1.25em, 1.75vw, 1.375em);
  line-height: 1.125;
  margin-bottom: 1em;
}
.list-page .service-list .single-service .fee .cost {
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: clamp(1.5em, 3vw, 2.2em);
}
.btn.more-btn {
  background: #EEE;
  padding: 1em 5em;
  line-height: 1;
	font-size: 1em;
  /* font-size: clamp(0.875em, 1.4vw, 1em);*/
  margin: auto;
  display: inline-block;
}
.service_simple .btn.more-btn {
  background: #9cdbd3;
}
.service_startup .btn.more-btn {
  background: #c2e5a0;
}
.service_standard .btn.more-btn {
  background: #a7daf9;
}
.service_factory .btn.more-btn {
  background: #90cddd;
}
.service_nextstage .btn.more-btn {
  background: #bac9e5;
}
.service_nextstage .btn.more-btn {
  background: #bac9e5;
}
.service_plus .btn.more-btn {
  background: #a4cdea;
}
.service_extra .btn.more-btn {
  background: #eadebb;
}
.service_alpha .btn.more-btn {
  background: #efc5cf;
}



.connect-area {
  padding: 2em 0;
  border-top: 1px solid #dbdbdb;
  background: #FFF;
}
.connect-area .connect {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
.connect-area .connect .freedial {
  width: 55%;
}
.connect-area .connect .freedial img {
  width: 100%;
}
.connect-area .connect .contact-btn { /* display: flex; */
}
.connect-area .connect .contact-btn .btn-mail {
  background: #29abe2;
  width: 227px;
  height: 70px;
  padding: 0 30px;
  position: relative;
  border-radius: 15px;
  box-shadow: 0 0 0 .2rem rgba(0, 123, 255, .25);
}
.connect-area .connect .contact-btn .btn-mail:before {
  content: "";
  width: 44px;
  height: 28px;
  position: absolute;
  top: calc(50% - 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 1;
  background-image: url(../img/bg-img/icon-mail.svg);
}
.connect-area .connect .contact-btn .btn-mail:after {
  content: "お問い合わせ";
  color: #ffffff;
  bottom: 3px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.875rem;
  font-family: a-otf-ud-shin-go-pr6n, sans-serif;
}
.connect-area .connect .contact-btn a {
  margin: 0 0.5em;
}
.connect-area .connect .contact-btn a span {
  text-align: center;
  display: block;
}
.connect-area .connect .contact-btn img {
  width: 100px;
}
.footer-area {
  background: rgb(255 255 255);
  padding: 4rem 0;
}
.list-page .footer-area {
  background: linear-gradient(0deg, rgba(221, 232, 240, 1) 0%, rgba(235, 239, 242, 1) 100%);
}
.factory .footer-area {
  background: linear-gradient(0deg, rgba(221, 232, 240, 1) 0%, rgba(235, 239, 242, 1) 100%);
}
.startup .footer-area {
  background: linear-gradient(0deg, rgba(227, 232, 214, 1) 0%, rgb(244 245 235) 100%);
}
.simple .footer-area {
  background: linear-gradient(0deg, rgb(214 229 227) 0%, rgb(234 244 242) 100%);
}
.standard .footer-area {
  background: linear-gradient(0deg, rgb(191 215 245) 0%, rgb(225 237 245) 100%);
}
.extra .footer-area {
  background: linear-gradient(0deg, rgb(227 223 219) 0%, rgb(242 240 237) 100%);
}
.alpha .footer-area {
  background: linear-gradient(0deg, rgb(234 224 223) 0%, #f5efee 100%);
}
.confirm .footer-area {
  background: linear-gradient(0deg, rgb(236 236 236) 0%, rgb(245 245 245) 100%);
}
.footer-area .address {
  padding: 1rem 0;
}
.footer-area .f-nav a {
  margin-right: 1rem;
  color: #6d6d6d;
  font-size: 0.875rem;
  font-family: a-otf-ud-shin-go-pr6n, sans-serif;
}
.footer-area .f-logo {
  max-width: 265px;
  width: 50%;
  display: block;
}
.footer-area .bottom-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.footer-area .copyright {
  font-size: 0.875rem;
}
@media only screen and (max-width: 991px) {
  .list-page .service-list .single-service:before {
    width: 8vw;
    height: 8vw;
    min-width: 50px;
    min-height: 50px;
  }
  .connect-area .connect .contact-btn img {
    width: 70px;
  }
}
@media only screen and (max-width: 767px) {

	.footer-area {
  padding: 2rem 0;
}
  .list-page .service-list {
    justify-content: space-between;
  }
  .list-page .service-list .single-service {
    width: 100%;
    margin-bottom: 0;
    padding: 1em 0 3em;
  }
  .list-page .service-list .single-service .name .type {
    /* font-size: 2rem;*/
  }
  .list-page .service-list .single-service .name .piece {
    width: 35%;
    max-width: 120px;
    min-width: 100px;
  }
  .list-page .service-list .single-service:before {
    right: 15px;
    bottom: 0;
  }
  .connect-area .connect {
    display: flex;
    width: 100%;
    justify-content: center;
  }
  .connect-area .connect .freedial {
    margin-bottom: 1.5rem;
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .connect-area .connect .contact-btn {
    text-align: center;
  }
  .connect-area .connect .contact-btn img {
    width: 80px;
  }
  .connect-area .connect .contact-btn .btn-mail {
    min-width: 260px;
    height: 58px;
    width: 100%;
  }
  .connect-area .connect .contact-btn .btn-mail:before {
    content: "";
    width: 38px;
    height: 24px;
  }
  .connect-area .connect .contact-btn .btn-mail:after {
    font-size: 0.75rem;
  }
}
.service-page .header-area .logo-area .container {
  max-height: 180px;
  height: 20vw;
  min-height: 110px;
}
.service-page .header-area .logo-area .container .row {
  max-height: 180px;
  height: 12vw;
  min-height: 90px;
}
body.service-page {
  position: relative;
}
body.service-page:before {
  height: 100%;
  width: 27vw;
  right: 0;
  top: 0;
  content: "";
  position: absolute;
  z-index: -1;
}
body.service-page.factory:before {
  background: #91bbc9;
}
body.service-page.startup:before {
  background: #d6e9a8;
}
body.service-page.simple:before {
  background: #c0d8d5;
}
body.service-page.standard:before {
  background: #cee5f8;
}
body.service-page.nextstage:before {
  background: #c5cddd;
}
body.service-page.extra:before {
  background: #eadebb;
}

body.service-page.alpha:before {
  background: #f0c8cb;
}

body.service-page .service-head .container .head-container {
  width: calc(100% - 100px / 2);
  max-width: none;
  display: flex;
  justify-content: space-between;
}
body.service-page .service-head .container .name-area {
  width: 40%;
}
body.service-page .service-head .container .pic-area {
  width: 57%;
}
body.service-page .service-head .container .pic-area img {
  text-align: right;
}
.head-container .name-area .catch {
  font-size: clamp(1rem, 2vw, 1.4375rem);
  font-family: corp-medium, sans-serif;
  line-height: 1;
  margin-bottom: 0.5em;
}
.head-container .name-area .type {
  font-family: corp-bold, sans-serif;
  font-weight: 700;
  font-size: clamp(1.5rem, 4.5vw, 4.375rem);
  line-height: 1.1;
  padding-left: 1.13em;
  position: relative;
  white-space: nowrap;
}

.factory .head-container .name-area .type {
  padding-left: 1.17em;
}

.nextstage .head-container .name-area .type {
  padding-left: 1.2em;
}
.alpha .head-container .name-area .type {
  padding-left: 1.25em;
}

.head-container .name-area .fee {
  padding: 0.8em 0;
  font-size: clamp(1.125rem, 2vw, 1.625rem);
  font-family: corp-medium, sans-serif;
  color: #999;
  line-height: 2;
  width: 100%;
  max-width: 390px;
  padding-right: 1rem;
}
.head-container .name-area .fee .fee-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.head-container .name-area .fee .value {
  font-family: "Jost", sans-serif;
  color: #000;
  font-size: clamp(1.5rem, 3.4vw, 3.125rem);
  font-weight: 700;
  line-height: 1;
}
.head-container .name-area .fee .value .unit {
  font-size: clamp(0.875rem, 2.5vw, 2rem);
  padding-left: 0.3em;
}

.head-container .name-area .type:before {
  content: "";
  width: 1em;
  height: 2em;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 1;
}
.factory .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_factory.png);
  width: 1.15em;
  top: 55%;
}
.startup .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_startup.png);
}
.simple .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_simple.png);
}
.standard .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_standard.png);
}
.nextstage .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_next.png);
  width: 1.15em;
  top: 55%;
}

.extra .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_extra.png);
  width: 1.08em;
  top: 55%;
}

.alpha .head-container .name-area .type:before {
  background-image: url(img/service-img/mark_alpha.png);
  width: 1.18em;
  top: 55%;
}
body.service-page .service-head .container {
  display: flex;
  justify-content: space-between;
}
.service-page .single-blog-wrapper {
  background-color: #f2f2f2;
  padding: 0;
}
.service-page .single-blog-wrapper .lead-area {
  padding: 4rem;
  position: relative;
}
.service-page .single-blog-wrapper .lead-area:before, .service-page .single-blog-wrapper .lead-area:after {
  content: "";
  position: absolute;
  left: 0;
  top: 30px;
  width: 63px;
  height: 63px;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(img/bg-img/bg-pattern-wh.svg);
}
.service-page .single-blog-wrapper .lead-area:after {
  left: auto;
  right: 0;
}
.service-page .single-blog-wrapper .archive-area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.service-page .single-blog-wrapper .archive-area .capture {
  width: calc(90% / 3);
  padding-bottom: 4vw;
  font-family: a-otf-ud-shin-go-pr6n, sans-serif;
  font-size: clamp(0.75rem, 1.5vw, 1.125rem);
}
.service-page .single-blog-wrapper .archive-area .capture span {
  text-align: center;
  display: block;
  padding: 0.5rem
}
.service-page .single-blog-wrapper .features, .service-page .single-blog-wrapper .recommend, .service-page .single-blog-wrapper .characteristic {
  padding: 4rem 0 0;
  overflow-x: hidden;
}
.service-page .single-blog-wrapper .characteristic ul {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% + 30px);
}
.service-page .single-blog-wrapper .characteristic ul li {
  font-family: a-otf-ud-shin-go-pr6n, sans-serif;
  width: calc(100% / 4);
  position: relative;
  margin-bottom: 1.5em;
  padding-right: 30px;
  .service-page .single-blog-wrapper .characteristic ul li {
    font-family: a-otf-ud-shin-go-pr6n, sans-serif;
    width: calc(100% / 4);
    position: relative;
    margin-bottom: 1.5em;
    padding-right: 30px;
    font-size: clamp(0.875rem, 1.5vw, 1rem);
  }
  ;
  font-size: clamp(0.875rem, 1.5vw, 1rem);
}
.service-page .single-blog-wrapper .characteristic ul li:after {
  position: relative;
  width: 100%;
  height: 1px;
  background: #CCC;
  content: "";
  left: 0;
  bottom: -0.5em;
  display: block;
}
.service-page .single-blog-wrapper .recommend ul {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 4em;
}
.service-page .single-blog-wrapper .recommend ul li {
  font-family: a-otf-ud-shin-go-pr6n, sans-serif;
  position: relative;
  line-height: 2;
  padding-right: 1.5em;
  .service-page .single-blog-wrapper .characteristic ul li {
    width: calc(100% / 3);
  }
  ;
  font-size: clamp(0.875rem, 1.5vw, 1rem);
}
.service-page .single-blog-wrapper .recommend ul li:after {
  content: "/";
  width: 1.5em;
  right: -0.5em;
  position: absolute;
  color: #bfbfbf;
}
.service-page .single-blog-wrapper:nth-child(even) {
  background-color: #FFF;
}
.service-page h2 {
  font-family: corp-medium, sans-serif;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  padding-left: 3.3rem;
  position: relative;
  margin-bottom: 1.3rem;
}
.service-page h2:before {
  width: 42px;
  height: 42px;
  content: "";
  position: absolute;
  left: 0;
  top: -7px;
  background-size: contain;
  background-repeat: no-repeat;
}
.service-page h3 {
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  margin-bottom: 2em;
  position: relative;
}
.service-page h3:after {
  position: relative;
  width: 100%;
  height: 4px;
  background: #CCC;
  content: "";
  left: 0;
  bottom: -0.5em;
  display: block;
}
.factory.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-factory.svg);
}
.startup.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-startup.svg);
}
.simple.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-simple.svg);
}
.standard.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-standard.svg);
}
.nextstage.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-next.svg);
}
.extra.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-extra.svg);
}
.alpha.service-page h2:before {
  background-image: url(img/bg-img/bg-h2-alpha.svg);
}
.service-page p {
  line-height: 1.9;
  font-size: clamp(0.875rem, 1.5vw, 1rem);
}
.service-page .lead {
  font-size: clamp(0.875rem, 1.5vw, 1.125rem);
  line-height: 2;
}
.service-page #chatplusview #outline #chatpluscontent #chatplusheader {
  background-color: #277fba !important;
}
#chatplusview .btn {
  color: #ffffff;
  background-color: #37a9d9 !important;
}
.service-page #chatplusview #outline #chatpluscontent #chatplusheader {
    background-color: #18bcdf !important;
}
#chatplusview.chatplusview-modern #outline #chatpluscontent #textarea #operate button, #chatplusview.chatplusview-modern .btn {
  border-radius: 4px !important;
}



.mail-form {
  padding: 50px 20px 0;
}
.thanks .mail-form {
  padding: 50px 20px 50px;
}
.mail-form h2 {
  text-align: center;
  font-size: clamp(1.125rem, 2vw, 1.75rem);
  font-family: corp-bold, sans-serif;
  padding-left: 0 !important;
}
.mail-form h2:before {
  content: none;
}
.modal-dialog {
  max-width: 1100px;
  width: 90%;
  margin: 1.75rem auto;
}
.modal-header {
  padding: 1rem;
  border: none;
  width: 100%;
}
#scrollUp {
  z-index: 9999 !important;
}
@media only screen and (max-width: 993px) {
  .service-page h2:before {
    width: 30px;
    height: 30px;
    top: -4px;
  }
  .service-page h2 {
    padding-left: 2.5rem;
  }
  .service-page .single-blog-wrapper .characteristic ul li {
    width: calc(100% / 3);
  }
}
@media only screen and (max-width: 769px) {
  a, p, .service-page .single-blog-wrapper .archive-area .capture, .service-page .single-blog-wrapper .characteristic ul li, .service-page .single-blog-wrapper .recommend ul li, .footer-area .f-nav a {
    font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  }
  .service-page .lead {
    line-height: 1.8
  }
  body.service-page:before {
    width: 16%;
  }
  .head-container .name-area .catch {
    font-size: clamp(0.875rem, 4vw, 4vw);
    font-family: corp-medium, sans-serif;
  }
  .head-container .name-area .type {
    font-size: clamp(2.2rem, 10vw, 10vw);
  }

  body.service-page .service-head .container .head-container {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
  body.service-page .service-head .container .name-area {
    width: 100%;
    padding-left: 5px;
  }
  body.service-page .service-head .container .pic-area {
    width: 100%;
    padding: 0 5px;
  }
  .service-page .single-blog-wrapper .lead-area {
    padding: 2.6rem 0;
  }
  .service-page .single-blog-wrapper .lead-area:before, .service-page .single-blog-wrapper .lead-area:after {
    left: 0;
    top: -15px;
    width: 40px;
    height: 40px
  }
  .service-page .single-blog-wrapper .lead-area:after {
    right: 0;
    left: auto;
    top: auto;
    bottom: 22px;
  }
  .service-page .single-blog-wrapper .archive-area .capture {
    width: calc(90% / 2);
  }
}
@media only screen and (max-width: 577px) {
  .head-container .name-area .fee {
    padding: 0.8em 0;
    font-size: clamp(1rem, 2vw, 1.625rem);
    font-family: corp-medium, sans-serif;
    color: #999;
    line-height: 1.6;
    width: 100%;
    max-width: calc(84% - 15px);
    padding-right: 0;
  }
  .service-page h2:before {
    width: 20px;
    height: 20px;
    top: 2px;
  }
  .service-page h2 {
    padding-left: 1.5rem;
  }
  .service-page .single-blog-wrapper .characteristic ul li {
    width: calc(100% / 2);
  }
}

#chatplusview #outline #chatpluscontent #chatplusheader {
    background-color: #18bcdf !important;
}





h2.lineup {
	padding: 1.5em 0;
	position:relative;
	width:100%;
	margin-bottom: 1.5em;
}

h2.lineup:after {
	  content: "";
  width: 100%;
  height: 2px;
  position: absolute;
   bottom: 5px;
  left: 0;
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 1;
	background-image: url(../img/text/bg-lineup.png);
	
}

h2.lineup img {
	max-width: 550px;
}

@media screen and (max-width: 769px) {
	.plan-list {
		/* font-size:1rem;*/
		padding-top:1.5rem;
	}

h2.lineup {
	width:100%;
}
	
	h2.lineup img {
		width:80%;
	}
}



.footer_nav {
	background-color:#FFF;
}


.footer_nav ul {
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
}

/* 
.footer_nav ul li {
	padding:2rem 0;
	background:#c9e3ec;
	margin-right:1px;
	text-align:center;
	width:calc(100% / 5 - 1px);
	border-top-left-radius:5px;
	border-top-right-radius:5px;
}


*/

.footer_nav ul {
	padding-bottom: 8rem;
}


.footer_nav ul li {
	margin: 0 24px;
	text-align:center;
	font-family: "Kosugi Maru", sans-serif;
	font-weight: 500;
	position:relative;
}

.footer_nav ul li:before {
	width:8px;
	height:8px;
	border-radius:4px;
	background: var(--color-green);
	content:"";
	right: -30px;
	top: 14px;
	position:absolute;
}

.footer_nav ul li:last-child:before {
	content:none;
}

.footer_nav ul li a {
	display:block;
	width:100%;
	height:100%;
	font-size: 1.9rem;
}


.footer_nav ul li.on,
.footer_nav ul li:hover{
}

.footer_nav ul li.on a,
.footer_nav ul li a:hover{
	color:#f69d0e;
	opacity:1;
}



/* Extra
-----------------------------------------------------------------*/


.imago {
  -webkit-clip-path: polygon(0 0, 0% 0, 0% 100%, 0 100%);
  clip-path: polygon(0 0, 0% 0, 0% 100%, 0 100%);
  -webkit-transform: scale(1.2);
  -ms-transform: scale(1.2);
  transform: scale(1.2);
  -webkit-filter: blur(5px);
  filter: blur(5px);
  -webkit-transition: -webkit-clip-path .8s ease-in-out .3s, -webkit-transform .8s ease-in-out 1.1s, -webkit-filter .8s ease-in-out 1.1s;
  transition: -webkit-clip-path .8s ease-in-out .3s, -webkit-transform .8s ease-in-out 1.1s, -webkit-filter .8s ease-in-out 1.1s;
  -o-transition: clip-path .8s ease-in-out .3s, transform .8s ease-in-out 1.1s, filter .8s ease-in-out 1.1s;
  transition: clip-path .8s ease-in-out .3s, transform .8s ease-in-out 1.1s, filter .8s ease-in-out 1.1s;
  transition: clip-path .8s ease-in-out .3s, transform .8s ease-in-out 1.1s, filter .8s ease-in-out 1.1s, -webkit-clip-path .8s ease-in-out .3s, -webkit-transform .8s ease-in-out 1.1s, -webkit-filter .8s ease-in-out 1.1s;
  position: relative;
}

.imago.animated {
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
  -webkit-filter: blur(0px);
  filter: blur(0px);
}

.imago.simpl {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
  -webkit-filter: blur(0px);
  filter: blur(0px);
}

.d-rotate {
  -webkit-perspective: 1000px;
  perspective: 1000px;
}

.d-rotate .rotate-text {
  display: block;
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
  -webkit-transition: all .8s;
  -o-transition: all .8s;
  transition: all .8s;
  -webkit-transform-origin: 50% 0%;
  -ms-transform-origin: 50% 0%;
  transform-origin: 50% 0%;
  -webkit-transform: translate3d(0px, 50px, -50px) rotateX(-45deg) scale(0.95);
  transform: translate3d(0px, 50px, -50px) rotateX(-45deg) scale(0.95);
  opacity: 0;
  -webkit-transition-delay: .3s;
  -o-transition-delay: .3s;
  transition-delay: .3s;
}

.d-rotate.animated .rotate-text {
  -webkit-transform: translate3d(0px, 0px, 0px) rotateX(0deg) scale(1);
  transform: translate3d(0px, 0px, 0px) rotateX(0deg) scale(1);
  opacity: 1;
}

.d-slideup .sideup-text {
  overflow: hidden;
  display: block;
}

.d-slideup .sideup-text:first-of-type .up-text {
  -webkit-transition-delay: .1s;
  -o-transition-delay: .1s;
  transition-delay: .1s;
}

.d-slideup .sideup-text:nth-of-type(2) .up-text {
  -webkit-transition-delay: .4s;
  -o-transition-delay: .4s;
  transition-delay: .4s;
}

.d-slideup .sideup-text:nth-of-type(3) .up-text {
  -webkit-transition-delay: .8s;
  -o-transition-delay: .8s;
  transition-delay: .8s;
}

.d-slideup .sideup-text:nth-of-type(4) .up-text {
  -webkit-transition-delay: 1.2s;
  -o-transition-delay: 1.2s;
  transition-delay: 1.2s;
}

.d-slideup .sideup-text:nth-of-type(5) .up-text {
  -webkit-transition-delay: 1.6s;
  -o-transition-delay: 1.6s;
  transition-delay: 1.6s;
}

.d-slideup .sideup-text .up-text {
  -webkit-transform: translateY(100%);
  -ms-transform: translateY(100%);
  transform: translateY(100%);
  -webkit-transition: all .8s;
  -o-transition: all .8s;
  transition: all .8s;
}

.d-slideup.animated .up-text {
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}