#lp_reform {
}
@media only screen and (max-width: 767px) {
	#lp_reform {
	}
}

/* ===== ファーストビュー ===== */
#fv {
	background: url(../img/reform/bg.jpg) repeat-y center top / 100%;
	background-color: #f8f8f8;
	padding: 40px 0 200px;
}
#fv .inner {
	position: relative;
}
.fv_flex {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8%;
}
.fv_text {
	width: 42%;
}
.fv_img {
	width: 50%;
}
.fv_img .img_wrap {
	width: 50vw;
	height: 580px;
	border-radius: 16px 0 0 16px;
	overflow: hidden;
}
.fv_img .img_wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.fv_subtitle {
	margin-bottom: 12px;
}
.fv_title_wrap {
	position: relative;
	margin-bottom: 46px;
}
.fv_title_wrap .icon_01 {
	position: absolute;
	top: 20px;
	left: -82px;
	width: 80px;
}
.fv_title_wrap .icon_02 {
	position: absolute;
	bottom: 10px;
	right: -32px;
	width: 42px;
}
.fv_title {
	position: relative;
	z-index: 2;
}
.fv_feature {
	margin-bottom: 40px;
}
.fv_area {
	width: 100%;
	max-width: 380px;
	margin: 0 auto;
}
.fv_cta {
	position: absolute;
	top: calc(100% + 200px);
	left: 40px;
	width: calc(100% - 80px);
	transform: translateY(-50%);
	z-index: 3;
}
.fv_cta .icon {
	position: absolute;
	bottom: 0;
	left: -90px;
	width: 147px;
}
@media only screen and (max-width: 767px) {
	#fv {
		background: url(../img/reform/bg.jpg) no-repeat center top / cover;
		background-color: #f8f8f8;
		padding: 150px 0 120px;
	}
	.fv_flex {
		display: block;
	}
	.fv_text {
		width: 100%;
	}
	.fv_img {
		width: 100%;
	}
	.fv_img .img_wrap {
		width: calc(50vw + 180px);
		height: 300px;
		border-radius: 8px 0 0 8px;
	}
	.fv_subtitle {
		width: 100%;
		max-width: 300px;
		margin: 0 auto 16px;
	}
	.fv_title_wrap {
		width: 100%;
		max-width: 330px;
		margin: 0 auto 32px;
	}
	.fv_title_wrap .icon {
		position: absolute;
		bottom: -26px;
		right: 14px;
		width: 74px;
	}
	.fv_title {
	}
	.fv_feature {
		width: 100%;
		max-width: 330px;
		margin: 0 auto 20px;
	}
	.fv_area {
		max-width: 330px;
		margin: 0 auto 25px;
	}
	.fv_cta {
		top: calc(100% + 120px);
		left: 15px;
		width: calc(100% - 30px);
		transform: translateY(calc(-50% + 30px));
	}
}

/* ===== 3つのお約束 ===== */
#merit {
	position: relative;
	background: url(../img/reform/bg.jpg) repeat-y center bottom / 100%;
	background-color: #f8f8f8;
	padding: 168px 0 80px;
}
.merit_bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(100% - 150px);
	background: #14763F;
}
.merit_bg::after {
	content: '';
	position: absolute;
	top: calc(100% - .5px);
	left: 0;
	width: 100%;
	height: 150px;
  clip-path: polygon(50% 100%,100% 0,0 0);
  background: #14763F;
}
.merit_intro {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: 100px;
	color: #fff;
}
.merit_intro .bubble {
	width: 380px;
}
.merit_intro .sec_title {
	margin-bottom: 40px;
	width: 450px;
}
.merit_intro .desc {
	font-size: 20px;
	font-weight: 700;
	line-height: 1.8;
	text-align: center;
	letter-spacing: 2px;
}
.merit_list {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin: 0;
	padding: 0;
}
.merit_item {
	position: relative;
	display: flex;
	flex-direction: column;
	padding: 50px 14px 20px;
	width: calc((100% - 40px) / 3);
	background: #fff;
	border: 3px solid #EB5437;
	border-radius: 8px;
	box-shadow: 8px 8px 0 0 #37473E33;
}
.merit_item .icon {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%,-51%);
	width: 102px;
}
.merit_item .lead {
	margin-bottom: 21px;
	font-size: 21.5px;
	font-weight: 900;
	line-height: 1.6;
}
.merit_item .lead.lead01 {
	letter-spacing: 0.5px;
}
.merit_item .lead.lead02 {
	margin-top: .8em;
	min-height: 2.4em;
	text-align: center;
}
.merit_item .lead  .line {
	display: inline-block;
	background: linear-gradient(transparent 70%, #FDFB59 70%, #FDFB59 90%, transparent 90%);
}
.merit_item .img {
	margin: 0 auto 24px;
	width: 204px;
	border-radius: 8px;
	overflow: hidden;
}
.merit_item .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
	aspect-ratio: 1 / 1;
}
.merit_item .text {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.8;
	text-align: justify;
}
@media only screen and (max-width: 767px) {
	#merit {
		background: #fff;
		padding: 200px 0 70px;
	}
	.merit_bg {
		height: calc(100% - 50px);
	}
	.merit_bg::after {
		height: 50px;
	}
	.merit_intro {
		margin-bottom: 75px;
	}
	.merit_intro .bubble {
		width: 295px;
	}
	.merit_intro .sec_title {
		width: 310px;
	}
	.merit_intro .desc {
		margin-bottom: 16px;
		font-size: 16px;
		letter-spacing: 1px;
	}
	.merit_list {
		flex-direction: column;
		align-items: center;
		gap: 70px;
		margin: 0;
		padding: 0;
	}
	.merit_item {
		flex-direction: column;
		padding: 50px 15px 20px;
		width: 100%;
	}
}

/* ===== お客様の声 ===== */
#voice {
	background: url(../img/reform/bg.jpg) repeat-y center top / 100%;
	background-color: #f8f8f8;
	padding: 80px 0;
}
#voice .inner {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.voice_intro {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-bottom: 48px;
}
.voice_intro .bubble {
	margin-bottom: 16px;
	width: 507px;
}
.voice_intro .icon_01 {
	position: absolute;
	bottom: 47px;
	left: -54px;
	width: 40px;
}
.voice_intro .icon_02 {
	position: absolute;
	bottom: 0;
	right: -200px;
	width: 184px;
}
.voice_intro .sec_title {
	position: relative;
	z-index: 2;
	width: 512px;
}
.voice_list {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
}
.voice_item {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 24px 30px;
	padding: 32px 70px;
	background: #fff;
	border: 6px solid #1D8D4F;
	border-radius: 8px;
	box-shadow: 8px 8px 0 0 #37473E33;
}
.voice_item .img {
	width: calc(42% - 15px);
}
.voice_item .lead_wrap {
	width: calc(58% - 15px);
}
.voice_item .lead {
	margin-bottom: 24px;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 2px;
	color: #14763F;
}
.voice_item .name {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
}
.voice_item .comment {
	width: 100%;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.8;
}
@media only screen and (max-width: 767px) {
	#voice {
		background: #fff;
		padding: 60px 0;
	}
	.voice_intro {
		align-items: flex-start;
		padding-bottom: 32px;
	}
	.voice_intro .bubble {
		margin-bottom: 9px;
		width: 280px;
	}
	.voice_intro .icon_01 {
		bottom: 95px;
		left: -17px;
		width: 22px;
	}
	.voice_intro .icon_02 {
		right: -37px;
		width: 152px;
	}
	.voice_intro .sec_title {
		width: 158px;
	}
	.voice_list {
		gap: 20px;
	}
	.voice_item {
		flex-direction: column;
		align-items: flex-start;
		flex-wrap: nowrap;
		gap: 0;
		padding: 27px 20px;
		border: 5px solid #1D8D4F;
		box-shadow: 7px 7px 0 0 #37473E33;
	}
	.voice_item .img {
		margin-bottom: 32px;
		width: 100%;
	}
	.voice_item .lead_wrap {
		display: contents;
	}
	.voice_item .lead {
		margin-bottom: 16px;
		font-size: 20px;
		font-weight: 900;
		line-height: 1.6;
	}
	.voice_item .name {
		order: 2;
	}
	.voice_item .comment {
		margin-bottom: 24px;
	}
}

/* ===== 対応エリア ===== */
#area {
	position: relative;
	background: #14763F;
	margin-bottom: 150px;
	padding: 80px 0;
	color: #fff;
}
#area::after {
	content: '';
	position: absolute;
	top: calc(100% - .5px);
	left: 0;
	width: 100%;
	height: 150px;
  clip-path: polygon(50% 100%,100% 0,0 0);
  background: #14763F;
}
#area .inner {
	position: relative;
}
.area_intro {
	position: relative;
	display: inline-block;
	margin-bottom: 40px;
}
.area_intro .bubble {
	margin-bottom: 24px;
	width: 404px;
}
.area_intro .icon {
	position: absolute;
	bottom: -2px;
	right: -74px;
	width: 118px;
}
.area_intro .sec_title {
	font-size: 48px;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 4px;
}
.area_text {
	margin-bottom: 70px;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.8;
	letter-spacing: 2px;
}
.area_text .line {
	display: inline-block;
	background: linear-gradient(transparent 60%, #F49D00 60%, #F49D00 90%, transparent 90%);
}
.area_img {
	position: absolute;
	top: 0;
	right: 90px;
	width: 316px;
}
@media only screen and (max-width: 767px) {
	#area {
		margin-bottom: 40px;
		padding: 60px 0 32px;
	}
	#area::after {
		height: 40px;
	}
	.area_intro {
		margin-bottom: 44px;
	}
	.area_intro .bubble {
		margin-bottom: 10px;
		width: 320px;
	}
	.area_intro .icon {
		position: absolute;
		bottom: -17px;
		right: -20px;
		width: 96px;
	}
	.area_intro .sec_title {
		margin-left: 10px;
		font-size: 30px;
		font-weight: 900;
		letter-spacing: 3px;
	}
	.area_text {
		margin-left: 10px;
		margin-bottom: 90px;
		font-size: 16px;
		letter-spacing: 1px;
		position: relative;
		z-index: 2;
	}
	.area_img {
		top: 180px;
		right: 20px;
		width: 142px;
	}
}

/* ===== お問い合わせフォーム ===== */
#form {
	background: #fff;
	padding: 80px 0;
}
.form_intro {
	position: relative;
	width: 500px;
	margin: 0 auto;
	padding-bottom: 48px;
}
.form_intro .bubble {
	margin-bottom: 16px;
}
.form_intro .icon {
	position: absolute;
	bottom: 0;
	right: 30px;
	width: 180px;
}
.form_intro .sec_title {
	font-size: 48px;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 4px;
}
.form_wrap {
	background: #DFF5E9;
	width: 100%;
	max-width: 980px;
	margin: 0 auto;
	padding: 48px 90px;
	border-radius: 8px;
}
.form_wrap .form_item {
	margin-bottom: 48px;
}
.form_wrap .form_item label {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.3;
}
.form_wrap .form_item label .small {
	font-size: 12px;
	font-weight: 400;
}
.form_wrap .form_item .req {
	display: inline-block;
	padding: 3px 8px;
	background-color: #D23A1F;
	color: #FFF;
	font-size: 10px;
	font-weight: 400;
	line-height: 1;
}
.form_wrap .form_item input,
.form_wrap .form_item textarea {
	width: 100%;
	padding: 12px 16px;
	border: 2px solid #D4E5DC;
	border-radius: 4px;;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.5;
}
.form_wrap .form_item input:focus,
.form_wrap .form_item textarea:focus {
	outline: none;
	border: 2px solid #789B88;
}
.form_wrap .form_item ::placeholder {
	color: #C5C5C5;
}
.form_wrap .form_btn {
	display: flex;
	justify-content: center;
}
.form_wrap .form_btn input {
	outline: none;
	position: relative;
	width: 100%;
	padding: 20px 33px 20px 0;
	background-color: #14763F;
	border: none;
	border-radius: 100px;
	color: #FFF;
	font-size: 14px;
	font-weight: 700;
	text-align: center;
	letter-spacing: 1px;
	cursor: pointer;
	transition: all .5s;
}
.form_wrap .form_btn .form_btn_wrap {
	position: relative;
	width: 100%;
	max-width: 400px;
}
.form_wrap .form_btn .form_btn_wrap::before {
	content: '';
	position: absolute;
	top: 50%;
	left: calc(50% + 74px);
	transform: translateY(-2px) rotate(45deg);
	display: inline-block;
	width: 8px;
	height: 2px;
	border-radius: 0 2px 2px 0;
	background-color: #FFF;
	z-index: 2;
	transition: all .5s;
}
.form_wrap .form_btn .form_btn_wrap::after {
	content: '';
	position: absolute;
	top: 50%;
	left: calc(50% + 60px);
	display: inline-block;
	width: 21px;
	height: 2px;
	border-radius: 0 2px 2px 0;
	background-color: #FFF;
	z-index: 2;
	transition: all .5s;
}
.form_wrap .form_btn input:hover {
	opacity: .7;
}
#form .wpcf7-spinner {
	display: none;
}
#form .wpcf7 form .wpcf7-response-output {
	margin: 24px 0 0;
	padding: 20px;
	font-size: 15px;
	font-weight: 400;
	text-align: center;
	border: none;
}
#form .wpcf7 form.invalid .wpcf7-response-output,
#form .wpcf7 form.unaccepted .wpcf7-response-output,
#form .wpcf7 form.payment-required .wpcf7-response-output {
	color: #FF0000;
}
#form .wpcf7 form.sent .wpcf7-response-output {
	color: #439768;
}
#form .wpcf7-not-valid-tip {
	color: #FF0000;
	font-size: 15px;
	font-weight: 400;
	display: block;
}
@media only screen and (max-width: 767px) {
	#form {
		padding: 60px 0;
	}
	.form_intro {
		width: 300px;
		margin: 0 auto;
		padding-bottom: 32px;
	}
	.form_intro .bubble {
		margin-bottom: 4px;
	}
	.form_intro .icon {
		right: 22px;
		width: 112px;
	}
	.form_intro .sec_title {
		font-size: 30px;
		font-weight: 900;
		letter-spacing: 3px;
	}
	.form_wrap {
		padding: 24px 15px;
		border-radius: 4px;
	}
	.form_wrap .form_item {
		margin-bottom: 32px;
	}
	.form_wrap .form_item label {
		align-items: flex-start;
		margin-bottom: 12px;
		padding-top: 4px;
		font-size: 15px;
	}
	.form_wrap .form_item .req {
		margin-top: -4px;
		padding: 6px 8px;
		font-size: 14px;
		border-radius: 2px;
		background: #EB5437;
	}
	.form_wrap .form_item input,
	.form_wrap .form_item textarea {
		padding: 6px 8px;
	}
	.form_wrap .form_btn input {
		padding: 19px 33px 19px 0;
	}
	.form_wrap .form_btn .form_btn_wrap {
		max-width: 300px;
	}
	
}

/* ===== 会社概要 ===== */
#info {
	background: #14763F;
	color: #fff;
	padding: 80px 0;
}
#info .sec_title {
	margin-bottom: 48px;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 2px;
}
.info_flex {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 80px;
}
.info_item {
	width: 50%;
	max-width: 480px;
}
.info_table {
	margin-top: -24px;
	width: 100%;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.8;
	text-align: left;
	border-spacing: 0;
}
.info_table th {
	width: 37.5%;
	vertical-align: top;
	padding: 24px 16px 8px 0;
	border-bottom: 2px solid #69B28A;
}
.info_table td {
	width: 62.5%;
	vertical-align: top;
	padding: 24px 16px 8px 0;
	border-bottom: 2px solid #69B28A;
}
.map_wrap {
	position: relative;
	background: #f8f8f8;
	border-radius: 12px;
	width: 100%;
	height: 550px;
	overflow: hidden;
}
.map_wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
@media only screen and (max-width: 767px) {
	#info {
		padding: 60px 0;
	}
	#info .sec_title {
		margin-bottom: 32px;
	}
	.info_flex {
		flex-direction: column;
		align-items: center;
		gap: 60px;
	}
	.info_item {
		width: 100%;
		max-width: none;
	}
	.info_table {
		margin-top: -32px;
		width: 100%;
		font-weight: 500;
	}
	.info_table th {
		width: 30%;
		padding: 32px 8px 8px 0;
	}
	.info_table td {
		width: 70%;
		padding: 32px 0 8px;
	}
	.map_wrap {
		border-radius: 8px;
		height: 250px;
	}
}



















