@charset "utf-8";
/* CSS Document */

#gHeader {
}

.mainVisual.subs {
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
	width: 100%;
	height: 420px;
	/*height:1000px;*/
	min-height: 420px;
    }
.mainVisual.subs .imgs {
	position: absolute;
	right: 0;
	top: 90px;
	width: 100%;
	height: calc(100% - 90px);
}
.mainVisual.subs img {
	width: 100%;
	height: 500px;
	object-fit: cover;
	object-position: 0px 170px 0 0;
}
.mainVisual.subs .mv_txt .txt {
	position: absolute;
	text-align: center;
	left: 0;
	right: 0;
	margin: auto;
	top: 50%;
}

@media all and (max-width: 768px) {
	.mainVisual.subs {
		box-sizing: border-box;
		position: relative;
		overflow: hidden;
		width: 100%;
		height: 230px;
		/*height:1000px;*/
		min-height: 230px;
		}
	.mainVisual.subs .imgs {
		position: absolute;
		right: 0;
		top: 55px;
		width: 100%;
		height: calc(100% - 55px);
	}
	.mainVisual.subs .imgs::after {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		width: 100%;
		height: 100%;
		background: rgba(255,255,255,0.4);
	}
	.mainVisual.subs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.mainVisual.subs .mv_txt .txt {
		position: absolute;
		text-align: center;
		left: 0;
		right: 0;
		margin: auto;
		top: 50%;
	}
	.mainVisual.subs .mv_txt .txt h1 {
		font-size: 25px;
		letter-spacing: 1px;
	}
}




.branch {
	display: block;
	background: #EFEFEF;
	padding: 18px 0;
}
@media all and (max-width: 1300px) {
	.branch {
		margin-left: 4%;
		margin-right: 4%;
	}
}
.branch ul {
	display: flex;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}
.branch ul li {
	display: block;
	position: relative;
	margin-left: 27px;
	font: normal normal bold 15px/16px Noto Sans JP;
	letter-spacing: 0.75px;
	color: #231815;
}
.branch ul li a {
	color: #BFBFBF;
}
.branch ul li::before {
	position: absolute;
	left: -15px;
	top: 0;
	content: "";
	width: 1px;
	height: 100%;
	background: #BFBFBF;
}
.branch ul li:nth-child(1) {
	margin-left: 0px;
}
.branch ul li:nth-child(1)::before {
	display: none;
}
@media all and (min-width: 769px) {
	.branch ul li a:hover {
		color:#c82b16;
	}
}
@media all and (max-width: 768px) {
	.branch {
		display: none;
	}
}



/* news----------------------------------------------- */
.subpage-contents {
	color: #5C4228;
}
.subpage-contents p {
	color: #5C4228;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%; /* 24px */
	letter-spacing: 0.8px;
}
.subinfolist {
	display: block;
	padding: 100px 0;
}
.title1 {
	display: block;
	text-align: center;
	position: relative;
	color: #5C4228;
	font-size: 36px;
	font-style: normal;
	font-weight: 700;
	line-height: 180%; /* 64.8px */
	letter-spacing: 5.4px;
	padding-bottom: 25px;
	margin-bottom: 45px;
}
.title1::after {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	content: "";
	margin: auto;
	width: 100px;
	height: 5px;
	border-radius: 3px;
	background: #419F34;
}
.subinfolist .lists {
	display: flex;
	flex-wrap: wrap;
}
.subinfolist .lists a {
	display:block;
	margin-left: 45px;
	flex-basis: calc((100% - (45px * 2)) / 3 - .01px);
	margin-bottom: 60px;
}
.subinfolist .lists a:nth-of-type(3n+1) {
	margin-left: 0px;
}
.subinfolist .lists a .imgs {
	display: block;
	overflow: hidden;
	border-radius: 10px;
	margin-bottom:15px;
}
.subinfolist .lists a .imgs img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 5 / 3;
	transition:1s all;
}
.subinfolist .lists a dl {
	display: flex;
}
.subinfolist .lists a dl dt {
	display: block;
	min-width: 100px;
	width: 100px;
	font-size: 15px;
	line-height: 1.5;
	padding-top: 3px;
}
.subinfolist .lists a dl dd {
	display: block;
}
.subinfolist .lists a dl span {
	display: inline-block;
	font-size: 14px;
	line-height: 1.4;
	padding: 3px 9px;
	border-radius: 3px;
	margin-right: 4px;
	margin-bottom: 4px;
	background: #B27F4E;
	color: #FFF;
}
.subinfolist .lists a h3 {
	display: block;
	padding: 15px 0;
	font-size: 17px;
	letter-spacing: 1px;
}
.subinfolist .lists a .txt_01 {
	display: block;
	overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* 行数を指定 */
}
@media all and (min-width: 769px) {
	.subinfolist .lists a:hover .imgs img {
		transform:scale(1.2,1.2);
  		transition:1s all;
	}
}



@media all and (max-width: 768px) {
	.subpage-contents p {
		color: #5C4228;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 24px */
		letter-spacing: 0.8px;
	}
	.subinfolist {
		display: block;
		padding: 50px 0;
	}
	.title1 {
		display: block;
		text-align: center;
		position: relative;
		color: #5C4228;
		font-size: 22px;
		font-style: normal;
		font-weight: 700;
		line-height: 180%; /* 64.8px */
		letter-spacing: 1.4px;
		padding-bottom: 20px;
		margin-bottom: 25px;
	}
	.title1::after {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		content: "";
		margin: auto;
		width: 100px;
		height: 5px;
		border-radius: 3px;
		background: #419F34;
	}
	.subinfolist .lists {
		display: block;
	}
	.subinfolist .lists a {
		display:block;
		margin-left: 0px;
		flex-basis: calc((100% - (45px * 2)) / 3 - .01px);
		margin-bottom: 40px;
	}
	.subinfolist .lists a .imgs {
		display: block;
		overflow: hidden;
		border-radius: 10px;
		margin-bottom:15px;
	}
	.subinfolist .lists a .imgs img {
		width: 100%;
		object-fit: cover;
		aspect-ratio: 5 / 3;
		transition:1s all;
	}
	.subinfolist .lists a dl {
		display: flex;
	}
	.subinfolist .lists a dl dt {
		display: block;
		min-width: 100px;
		width: 100px;
		font-size: 15px;
		line-height: 1.5;
		padding-top: 3px;
		color: #B27F4E;
	}
	.subinfolist .lists a dl dd {
		display: block;
	}
	.subinfolist .lists a dl span {
		display: inline-block;
		font-size: 14px;
		line-height: 1.4;
		padding: 3px 9px;
		border-radius: 3px;
		margin-right: 4px;
		margin-bottom: 4px;
		background: #B27F4E;
		color: #FFF;
	}
	.subinfolist .lists a h3 {
		display: block;
		padding: 12px 0;
		font-size: 16px;
		letter-spacing: 1px;
		color: #222;
	}
	.subinfolist .lists a .txt_01 {
		display: block;
		overflow: hidden;
	  display: -webkit-box;
	  -webkit-box-orient: vertical;
	  -webkit-line-clamp: 3; /* 行数を指定 */
	}
}



/* news detail----------------------------------------------- */

.info-detail {
	display: block;
	padding: 100px 0;
}
.info-detail .flx {
	display: flex;
	justify-content: space-between;
}
.infomain {
	display: block;
	flex-basis: 72%;
	padding-top: 20px;
	padding-bottom: 90px;
}
.infomain img {
	max-width: 100%;
	border-radius: 10px;
	width: 100%;
}
.infomain .imgs {
	display: block;
	overflow: hidden;
	border-radius: 10px;
	margin-bottom:15px;
}
.infomain .imgs img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 5 / 3;
	transition:1s all;
}
.infomain dl {
	display: flex;
}
.infomain dl dt {
	display: block;
	min-width: 100px;
	width: 100px;
	font-size: 15px;
	line-height: 1.5;
	padding-top: 3px;
}
.infomain dl dd {
	display: block;
}
.infomain dl span {
	display: inline-block;
	font-size: 14px;
	line-height: 1.4;
	padding: 3px 9px;
	border-radius: 3px;
	margin-right: 4px;
	margin-bottom: 4px;
	background: #B27F4E;
	color: #FFF;
}
.infomain h2 {
	display: block;
	padding: 15px 0;
	font-size: 24px;
	letter-spacing: 1px;
}
.infomain .txt_01 {
	display: block;
	font-size: 16px;
	line-height: 2.2;
}
.infomain .boxs {
	margin-top: 60px;
}
.infomain .boxs img {
	width: 100%;
}
.info-detail .ref {
	flex-basis: 23%;
	max-width: 23%;
}

@media all and (max-width: 768px) {
	.info-detail {
		display: block;
		padding: 50px 0;
	}
	.info-detail .flx {
		display: block;
	}
	.infomain {
		display: block;
		flex-basis: 72%;
		padding-top: 0px;
		padding-bottom: 40px;
	}
	.infomain img {
		max-width: 100%;
	}
	.infomain .imgs {
		display: block;
		overflow: hidden;
		border-radius: 10px;
		margin-bottom:15px;
	}
	.infomain .imgs img {
		width: 100%;
		object-fit: cover;
		aspect-ratio: 5 / 3;
		transition:1s all;
	}
	.infomain dl {
		display: flex;
	}
	.infomain dl dt {
		display: block;
		min-width: 100px;
		width: 100px;
		font-size: 15px;
		line-height: 1.5;
		padding-top: 3px;
	}
	.infomain dl dd {
		display: block;
	}
	.infomain dl span {
		display: inline-block;
		font-size: 14px;
		line-height: 1.4;
		padding: 3px 9px;
		border-radius: 3px;
		margin-right: 4px;
		margin-bottom: 4px;
		background: #B27F4E;
		color: #FFF;
	}
	.infomain h2 {
		display: block;
		padding: 12px 0;
		font-size: 17px;
		letter-spacing: 1px;
	}
	.infomain .txt_01 {
		display: block;
		font-size: 15px;
		line-height: 2;
	}
	.infomain .boxs {
		margin-top: 45px;
	}
	.infomain .boxs img {
		max-width: 100%;
		width: auto;
	}
	.info-detail .ref {
		flex-basis: 20%;
	}
}


/* faq----------------------------------------------- */

.faqlist {
	display: block;
	padding: 100px 0;
}
.acMenu {
	margin-top: 40px;
}
.acMenu dt{
	display:block;
	position: relative;
	margin-top: 20px;
	padding: 20px 50px 20px 25px;
	font-size: 20px;
	font-weight: 600;
	background: #fae4ce;
	border-radius: 10px;
	color: #b27f4e;
	cursor:pointer;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.acMenu dt span {
	display: block;
	position: relative;
	padding-left: 50px;
}
.acMenu dt span::before {
	position: absolute;
	left: 0;
	top: -10px;
	content: "Q.";
	font-size: 29px;
	font-weight: 600;
}
.acMenu dt::before {
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 17px;
	height: 2px;
	background: #fff;
}
.acMenu dt::after {
	position: absolute;
	right: 27px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 2px;
	height: 17px;
	background: #fff;
}
.acMenu dt.active {
	background: #B27F4E;
	color: #FFF;
}
.acMenu dt.active::after {
	display: none;
}
.acMenu dd{
	display:none;
	background: #f9f9f9;
	padding: 35px 35px 35px 65px;
	font-size: 16px;
	line-height: 2;
	letter-spacing: 1px;
	font-weight: 500;
	position: relative;
}
.acMenu dd::before {
	position: absolute;
	left: 25px;
	top: 15px;
	content: "A.";
	font-size: 29px;
	font-weight: 600;
}
.acMenu dd .rbox {
	display: block;
	margin-bottom: 45px;
}
.acMenu dd .rbox h3 {
	display: block;
	font-size: 17px;
	padding-bottom: 15px;
	margin-bottom: 15px;
	border-bottom: #555 dotted 1px;
}
.acMenu dd .rbox ul {
	display: block;
}
.acMenu dd .rbox li {
	display: inline-block;
	margin-right: 6px;
	margin-bottom: 6px;
	min-width: 160px;
	
}
.acMenu dd .rbox li a {
	display: block;
	text-align: center;
	padding: 6px 15px;
	background: #FFF;
	font-size: 15px;
}




@media all and (max-width: 768px) {
	.faqlist {
		display: block;
		padding: 50px 0;
	}
	.acMenu {
		margin-top: 40px;
	}
	.acMenu dt{
		display:block;
		position: relative;
		margin-top: 20px;
		padding: 20px 50px 20px 15px;
		font-size: 17px;
		font-weight: 600;
		background: #fae4ce;
		border-radius: 10px;
		color: #b27f4e;
		cursor:pointer;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.acMenu dt span {
		display: block;
		position: relative;
		padding-left: 40px;
	}
	.acMenu dt span::before {
		position: absolute;
		left: 0;
		top: -10px;
		content: "Q.";
		font-size: 29px;
		font-weight: 600;
	}
	.acMenu dt::before {
		position: absolute;
		right: 20px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 17px;
		height: 2px;
		background: #fff;
	}
	.acMenu dt::after {
		position: absolute;
		right: 27px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 2px;
		height: 17px;
		background: #fff;
	}
	.acMenu dt.active {
		background: #B27F4E;
		color: #FFF;
	}
	.acMenu dt.active::after {
		display: none;
	}
	.acMenu dd{
		display:none;
		background: #f9f9f9;
		padding: 35px 35px 35px 65px;
		font-size: 15px;
		line-height: 2;
		letter-spacing: 1px;
		font-weight: 500;
		position: relative;
	}
	.acMenu dd::before {
		position: absolute;
		left: 25px;
		top: 15px;
		content: "A.";
		font-size: 29px;
		font-weight: 600;
	}
	.acMenu dd .rbox {
		display: block;
		margin-bottom: 45px;
	}
	.acMenu dd .rbox h3 {
		display: block;
		font-size: 17px;
		padding-bottom: 15px;
		margin-bottom: 15px;
		border-bottom: #555 dotted 1px;
	}
	.acMenu dd .rbox ul {
		display: block;
	}
	.acMenu dd .rbox li {
		display: inline-block;
		margin-right: 6px;
		margin-bottom: 6px;
		min-width: 160px;

	}
	.acMenu dd .rbox li a {
		display: block;
		text-align: center;
		padding: 6px 15px;
		background: #FFF;
		font-size: 15px;
	}

}

/* contact-top----------------------------------------------- */

.c-tops {
	display: block;
	padding: 100px 0 ;
	background: #f0f8ff;
}
.c-tops h2 {
	display: block;
	text-align: center;
}
.c-tops .mt {
	text-align: center;
	margin-bottom: 45px;
	font-size: 17px;
	line-height: 2;
}
.cont-faq {
	display: block;
	margin-bottom: 40px;
}
.cont-faq .mt {
	font-size: 21px !important;
	margin-bottom: 20px !important;
	font-weight: bold !important;
}
.c-tops .boxs2 {
	display: block;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	background: #FFF;
	box-sizing: border-box;
	padding: 60px;
	text-align: center;
	border-radius: 30px;
}

.c-tops .boxs2 b,
.c-tops .boxs2 a {
	display:flex;
	justify-content: center;
	position: relative;
	font-size: 45px;
	font-weight: 600;
	color: #B27F4E;
	line-height: 1;
	letter-spacing: 6px;
	margin-bottom: 10px;
}
.sml-tel {
	margin-right: 15px;
	font-size: 22px !important;
}
.c-tops .boxs2 small {
	display: block;
	padding-top: 14px;
	font-size:16px;
	font-weight: 600;
}
.c-cont {
	padding: 100px 0;
	background: #FFF;
}

@media screen and (max-width:768px) {
	.c-tops {
		display: block;
		padding: 50px 0 ;
		background: #f0f8ff;
	}
	.c-tops h2 {
		display: block;
		text-align: center;
		position: relative;
		margin-top: 0px;
		margin-bottom: 20px;
	}
	.c-tops .mt {
		text-align: left;
		margin-bottom: 25px;
		font-size: 15px;
		line-height: 2;
	}
	.cont-faq {
		display: block;
		margin-bottom: 25px;
	}
	.cont-faq .mt {
		font-size: 16px !important;
		margin-bottom: 15px !important;
		font-weight: bold !important;
	}
	.c-tops .boxs2 {
		display: block;
		max-width: 700px;
		margin-left: auto;
		margin-right: auto;
		background: #FFF;
		box-sizing: border-box;
		padding: 20px;
		text-align: center;
		border-radius: 15px;
	}

	.c-tops .boxs2 b,
	.c-tops .boxs2 a {
		display:flex;
		justify-content: center;
		position: relative;
		font-size: 22px;
		font-weight: 600;
		line-height: 1;
		letter-spacing: 3px;
		margin-bottom: 10px;
	}
	.sml-tel {
		margin-right: 5px;
		font-size: 14px !important;
	}
	.c-tops .boxs2 small {
		display: block;
		padding-top: 5px;
		font-size:13px;
		font-weight: 600;
	}
	.c-cont {
		padding: 50px 0;
	}
}






/* event----------------------------------------------- */

.check-base {
	background: #FFF;
	position: relative;
	padding: 80px 0;
}
.check-base .lef {
	display: block;
	width: 65%;
	background: #FFF;
	padding: 45px;
	position: relative;
	z-index: 5;
	border-left: #c82b16 solid 4px;
	box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
}
.check-base ul {
	display: block;
}
.check-base li {
	display: block;
	position: relative;
	font-size: 21px;
	font-weight: bold;
	line-height: 1.1;
	letter-spacing: 1px;
	margin: 19px 0;
	padding-left: 32px;
	padding-bottom: 24px;
	border-bottom: #ccc dotted 1px;
}
.check-base li::after {
	content: '';
	display: block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 14px;
	height: 7px;
	border-left: 3px solid #c82b16;
	border-bottom: 3px solid #c82b16;
	transform: rotate(-45deg);
}
.check-base .imgs {
	display: block;
	position: absolute;
	right: 0;
	top: 0;
	width: 55%;
	height: 100%;
}
.check-base .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.bt1.v2 {
	display: block;
	width: 380px;
	margin-left: auto;
	margin-right: auto;
}
.mt55 {
	margin-top: 55px;
}
.recruit2 {
	display: block;
	padding: 100px 0;
	background: #EFEFEF;
}
.flow-base {
	display:block;
}
.flow-base li {
	display: flex;
	justify-content: space-between;
	background: #FFF;
	position: relative;
	box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
	margin-top: 95px;
}
.flow-base li::before {
	position: absolute;
	left: 0;
	right: 0;
	top: -55px;
	margin: auto;
	content: "";
	box-sizing: border-box;
	width: 24px;
	height: 24px;
	border: 24px solid transparent;
	border-top: 24px solid #555;
}
.flow-base li:nth-of-type(1) {
	margin-top: 0px;
}
.flow-base li:nth-of-type(1)::before {
	display: none;
}
.flow-base li .lef {
	display: block;
	flex-basis: 20%;
	padding: 35px 0;
	text-align: center;
	background: #c82b16;
}
.flow-base li .lef .nums {
	display: block;
}
.flow-base li .lef .nums small {
	display: block;
	color: #FFF;
	font-size:22px;
	font-weight: bold;
	line-height: 1;
}
.flow-base li .lef .nums b {
	display: block;
	color: #FFF;
	font-size: 36px;
	line-height: 1;
	margin-top: 6px;
}
.flow-base li .ref {
	display: block;
	flex-basis: 80%;
	box-sizing: border-box;
	padding: 35px;
}
.flow-base li .ref h3 {
	display: block;
	font-size: 24px;
	letter-spacing: 2px;
	line-height: 1.4;
	font-weight: bold;
	color: #c82b16;
	border-bottom: #ccc dotted 1px;
	padding-bottom: 24px;
	margin-bottom: 24px;
}
.flow-base li .ref .bt1 {
	width: 300px;
	margin-top: 30px;
}

@media all and (max-width: 768px) {
	.check-base {
		background: #FFF;
		position: relative;
		padding: 170px 0 40px 0;
	}
	.check-base .lef {
		display: block;
		width: 92%;
		box-sizing: border-box;
		margin-left: 4%;
		margin-right: 4%;
		background: #FFF;
		padding: 20px;
		position: relative;
		z-index: 5;
		border-left: #c82b16 solid 0px;
		border-top: #c82b16 solid 4px;
		box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
	}
	.check-base ul {
		display: block;
	}
	.check-base li {
		display: block;
		position: relative;
		font-size: 15px;
		font-weight: bold;
		line-height: 1.5;
		letter-spacing: 1px;
		margin: 12px 0;
		padding-left: 32px;
		padding-bottom: 14px;
		border-bottom: #ccc dotted 1px;
	}
	.check-base li::after {
		content: '';
		display: block;
		position: absolute;
		top: 5px;
		left: 0;
		width: 14px;
		height: 7px;
		border-left: 3px solid #c82b16;
		border-bottom: 3px solid #c82b16;
		transform: rotate(-45deg);
	}
	.check-base .imgs {
		display: block;
		position: absolute;
		right: 0;
		top: 0;
		width: 100%;
		height: 200px;
	}
	.check-base .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.bt1.v2 {
		display: block;
		width: 260px;
		margin-left: auto;
		margin-right: auto;
	}
	.mt55 {
		margin-top: 25px;
	}
	.recruit2 {
		display: block;
		padding: 40px 0;
		background: #EFEFEF;
	}
	.flow-base {
		display:block;
	}
	.flow-base li {
		display: flex;
		justify-content: space-between;
		background: #FFF;
		position: relative;
		box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
		margin-top: 95px;
	}
	.flow-base li::before {
		position: absolute;
		left: 0;
		right: 0;
		top: -55px;
		margin: auto;
		content: "";
		box-sizing: border-box;
		width: 24px;
		height: 24px;
		border: 24px solid transparent;
		border-top: 24px solid #555;
	}
	.flow-base li:nth-of-type(1) {
		margin-top: 0px;
	}
	.flow-base li:nth-of-type(1)::before {
		display: none;
	}
	.flow-base li .lef {
		display: block;
		flex-basis: 20%;
		padding: 20px 0;
		text-align: center;
		background: #c82b16;
	}
	.flow-base li .lef .nums {
		display: block;
	}
	.flow-base li .lef .nums small {
		display: block;
		color: #FFF;
		font-size:14px;
		font-weight: bold;
		line-height: 1;
	}
	.flow-base li .lef .nums b {
		display: block;
		color: #FFF;
		font-size: 26px;
		line-height: 1;
		margin-top: 6px;
	}
	.flow-base li .ref {
		display: block;
		flex-basis: 80%;
		box-sizing: border-box;
		padding: 20px 3%;
	}
	.flow-base li .ref h3 {
		display: block;
		font-size: 17px;
		letter-spacing: 2px;
		line-height: 1.4;
		font-weight: bold;
		color: #c82b16;
		border-bottom: #ccc dotted 1px;
		padding-bottom: 14px;
		margin-bottom: 14px;
	}
	.flow-base li .ref .bt1 {
		width: 200px;
		margin-top: 20px;
	}
}



/* workflow----------------------------------------------- */

.wflow1 {
	display: block;
	padding: 100px 0;
}
.wflow1 .flx {
	display: flex;
	justify-content: space-between;
	position: relative;
	margin-top: 30px;
	margin-bottom: 90px;
}
.wflow1 .flx.ri {
	flex-direction: row-reverse;
}
.wflow1 .flx .txt {
	display: block;
	position: relative;
	z-index: 5;
	background: #FFF;
	flex-basis: 55%;
	box-sizing: border-box;
	padding: 45px;
	margin-top: 90px;
	min-height: 370px;
	box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
}
.wflow1 .flx .txt h2 {
	display: block;
	font-size: 24px;
	letter-spacing: 2px;
	line-height: 1.4;
	font-weight: bold;
	color: #c82b16;
	border-bottom: #ccc dotted 1px;
	padding-bottom: 24px;
	margin-bottom: 24px;
}
.wflow1 .flx .txt .bt1 {
	margin-top: 35px;
}
.wflow1 .imgs {
	position: absolute;
	right: 0;
	top: 0px;
	width: 60%;
	height: 90%;
}
.wflow1 .ri .imgs {
	right: auto;
	left: 0;
}
.wflow1 .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.bt1.v3 {
	width: 290px;
}


@media all and (max-width: 768px) {
	.wflow1 {
		display: block;
		padding: 40px 0;
	}
	.wflow1 .flx {
		display: flex;
		justify-content: space-between;
		position: relative;
		padding-top: 160px;
		margin-top: 20px;
		margin-bottom: 50px;
	}
	.wflow1 .flx.ri {
		flex-direction: row-reverse;
	}
	.wflow1 .flx .txt {
		display: block;
		position: relative;
		z-index: 5;
		background: #FFF;
		flex-basis: 94%;
		box-sizing: border-box;
		padding: 20px;
		margin-top: 50px;
		min-height: auto;
		box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
	}
	.wflow1 .flx .txt h2 {
		display: block;
		font-size: 17px;
		letter-spacing: 2px;
		line-height: 1.4;
		font-weight: bold;
		color: #c82b16;
		border-bottom: #ccc dotted 1px;
		padding-bottom: 14px;
		margin-bottom: 14px;
	}
	.wflow1 .flx .txt .bt1 {
		margin-top: 20px;
	}
	.wflow1 .imgs {
		position: absolute;
		right: 0;
		top: 0px;
		width: 100%;
		height: 50%;
	}
	.wflow1 .ri .imgs {
		right: auto;
		left: 0;
	}
	.wflow1 .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.bt1.v3 {
		width: 240px;
	}
}


/* strength----------------------------------------------- */
.str1 {
	display: block;
	padding: 100px 0 40px 0;
}
.str1 .boxs {
	position: relative;
	padding-top: 400px;
	margin-bottom: 100px;
}
.str1 .boxs .imgs {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 440px;
}
.str1 .boxs .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.str1 .boxs .txt {
	position: relative;
	z-index: 5;
	background: #FFF;
	box-sizing: border-box;
	margin-left: 10%;
	margin-right: 10%;
	padding: 80px 50px;
	text-align: center;
	box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
}
.str1 .boxs .txt::before {
	position: absolute;
	left: 0;
	top: -60px;
	right: 0;
	margin: auto;
	content: "";
	width: 1px;
	height: 120px;
	background: #c82b16;
}
.str1 .boxs h2 {
	display:block;
	position: relative;
	font-size: 26px;
	letter-spacing: 3px;
	line-height: 1.6;
	font-weight: bold;
	color: #c82b16;
	padding-bottom: 35px;
	margin-bottom: 35px;
}
.str1 .boxs h2::after {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 50px;
	height: 3px;
	background: #666;
}

@media all and (max-width: 768px) {
	.str1 {
		display: block;
		padding: 40px 0 10px 0;
	}
	.str1 .boxs {
		position: relative;
		padding-top: 270px;
		margin-bottom: 40px;
	}
	.str1 .boxs .imgs {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 270px;
	}
	.str1 .boxs .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.str1 .boxs .txt {
		position: relative;
		z-index: 5;
		background: #FFF;
		box-sizing: border-box;
		margin-left: 4%;
		margin-right: 4%;
		padding: 50px 20px;
		text-align: center;
		box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
	}
	.str1 .boxs .txt::before {
		position: absolute;
		left: 0;
		top: -30px;
		right: 0;
		margin: auto;
		content: "";
		width: 1px;
		height: 60px;
		background: #c82b16;
	}
	.str1 .boxs h2 {
		display:block;
		text-align: left;
		position: relative;
		font-size: 20px;
		letter-spacing: 3px;
		line-height: 1.6;
		font-weight: bold;
		color: #c82b16;
		padding-bottom: 20px;
		margin-bottom: 20px;
	}
	.str1 .boxs h2::after {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 50px;
		height: 3px;
		background: #666;
	}
	.str1 .boxs p {
		text-align: left;
	}

}



/* works----------------------------------------------- */
.workslist {
	display: block;
	margin-bottom: 130px;
}
.workslist .cats {
	display: block;
	margin-bottom: 60px;
	padding-top: 80px;
}
.workslist .cats li {
	display: inline-block;
	margin-right: 10px;
	margin-bottom: 18px;
}
.workslist .cats li a {
	display: inline-block;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 22px;
	font-style: normal;
	font-weight: 700;
	line-height: 22px; /* 100% */
	letter-spacing: 2.2px;
	position: relative;
	padding: 15px 25px 18px 40px;
	
}
.workslist .cats li a::before {
	position: absolute;
	left: 15px;
	bottom: 0;
	top: 0;
	z-index: 5;
	margin: auto;
	content: "";
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: #E26D00;
	-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
}
.workslist .cats li a::after {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 50px;
	background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
	-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
	opacity: 0;
}
.workslist .cats li.current a {
	color: #FFF;
	opacity: 1;
	-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
}
.workslist .cats li.current a::before{
	background: #FFD86F;
}
.workslist .cats li.current a::after {
    opacity: 1;
    background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
    -webkit-transition: all 0.2s ease-in-out 0s;
    transition: all 0.2s ease-in-out 0s;
}
.workslist .cats li a span {
	position: relative;
	z-index: 5;
}
@media all and (min-width: 769px) {
	.workslist .cats li a:hover {
		color: #FFF;
		opacity: 1;
	}
	.workslist .cats li a:hover::after {
		opacity: 1;
		background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
		-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
	}
	.workslist .cats li a:hover::before{
		background: #FFD86F;
	}
}
.workslist .lists {
	display: flex;
	flex-wrap: wrap;
}
.workslist .lists li {
	display: block;
	margin-bottom: 80px;
	margin-left: 80px;
	flex-basis: calc((100% - (80px * 3)) / 4 - .01px);
	max-width: calc((100% - (80px * 3)) / 4 - .01px);
	position: relative;
}
.workslist .lists li:nth-child(4n+1) {
	margin-left: 0px;
}
.workslist .lists li a {
	display: block;
}
@media all and (min-width: 769px) {
	.workslist .lists li a:hover {
		opacity: 0.7;
	}
}
.workslist .lists li .imgs {
	display: block;
	position: relative;
}
.workslist .lists li .imgs img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 9 / 10.8;
	border-radius: 30px 0;
}
.workslist .lists li .imgs span {
	position: absolute;
	display: inline-block;
	left: 5px;
	bottom: 5px;
	z-index: 5;
	color: #FFF;
	text-align: center;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 18px; /* 100% */
	letter-spacing: 1.8px;
	padding: 14px 25px;
	border-radius: 10px 0px;
	background: #E26D00;
}
.workslist .lists li .days {
	display: block;
	padding: 10px 0 5px 0;
	color: #464646;
	font-size: 16px;
	font-style: normal;
	font-weight: 700 !important;
	line-height: 18px; /* 112.5% */
	letter-spacing: 1.28px;
}
.workslist .lists li p {
	width: 100%;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 18px; /* 100% */
	letter-spacing: 1.44px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
@media all and (min-width: 769px) and (max-width: 1100px) {
	.workslist .lists li {
		display: block;
		margin-bottom: 40px;
		margin-left: 40px;
		flex-basis: calc((100% - (40px * 3)) / 4 - .01px);
		max-width: calc((100% - (40px * 3)) / 4 - .01px);
		position: relative;
	}
	.workslist .lists li .imgs span {
		font-size: 14px;
		line-height: 18px; /* 100% */
		padding: 10px 15px
	}
	.workslist .lists li .days {
		font-size: 14px;
	}
	.workslist .lists li p {
		font-size: 15px;
	}
}
@media screen and (max-width:768px) {
	.workslist {
		display: block;
		margin-bottom: 50px;
	}
	.workslist .cats {
		display: block;
		margin-bottom: 30px;
		padding-top: 0px;
	}
	.workslist .cats li {
		display: inline-block;
		margin-right: 5px;
		margin-bottom: 10px;
	}
	.workslist .cats li a {
		display: inline-block;
		color: #464646;
		font-family: "Zen Kaku Gothic New";
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 100% */
		letter-spacing: 2.2px;
		position: relative;
		padding: 8px 10px 8px 10px;
		border-radius: 50px;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	
	.workslist .cats li a::before {
		display: none;
	}
	.workslist .cats li.current a {
		color: #FFF;
		background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
	}
	.workslist .cats li.current a::before{
		background: #FFD86F;
	}
	.workslist .lists {
		display: block;
	}
	.workslist .lists li {
		display: block;
		margin-bottom: 30px;
		margin-left: 0px;
		flex-basis:100%;
		max-width: 100%;
		position: relative;
	}
	.workslist .lists li:nth-child(4n+1) {
		margin-left: 0px;
	}
	.workslist .lists li a {
		display: block;
	}
	.workslist .lists li .imgs {
		display: block;
		position: relative;
	}
	.workslist .lists li .imgs img {
		width: 100%;
		object-fit: cover;
		aspect-ratio: 9 / 6;
		border-radius: 30px 0;
	}
	.workslist .lists li .imgs span {
		position: absolute;
		display: inline-block;
		left: 5px;
		bottom: 5px;
		z-index: 5;
		color: #FFF;
		text-align: center;
		font-family: "Zen Kaku Gothic New";
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 100% */
		letter-spacing: 1.8px;
		padding: 10px 15px;
		border-radius: 10px 0px;
		background: #E26D00;
	}
	.workslist .lists li .days {
		display: block;
		padding: 10px 0 5px 0;
		color: #464646;
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 112.5% */
		letter-spacing: 1.28px;
	}
	.workslist .lists li p {
		width: 100%;
		color: #464646;
		font-family: "Zen Kaku Gothic New";
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 100% */
		letter-spacing: 1.44px;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
}





/*pagenav*/
@media screen and (max-width:768px) {
	.wp-pagenavi {
		display:flex;
		justify-content: center;
		text-align: center;
		margin: 0px 0;
		padding-bottom: 0px;
		padding-top: 30px;
	}
	.wp-pagenavi li {
		display: inline-block;
		margin: 8px;
	}
	.wp-pagenavi a,
	.wp-pagenavi span {
		margin: 4px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items:center;
		width: 35px;
		height: 35px;
		border-radius: 50%;
		background: #b27f4e;
		border:#b27f4e solid 2px;
		color: #FFF;
		font-size: 12px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi a.page {
		color: #b27f4e;
		text-align: center;
		border:#fff solid 2px;
		background: #FFF;
		font-size: 12px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 5px;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 5px;
	}
	.wp-pagenavi a:hover {
		background: #FFF;
		color: #b27f4e;
		border:#b27f4e solid 2px;
	}
	.wp-pagenavi span {
		background: #FFF;
		color: #b27f4e;
	}
}
@media screen and (min-width:769px) {
	.wp-pagenavi {
		display:flex;
		justify-content: center;
		text-align: center;
		margin: 0px 0;
		padding-bottom: 0px;
		padding-top: 50px;
	}
	.wp-pagenavi li {
		display: inline-block;
		margin: 8px;
	}
	.wp-pagenavi a,
	.wp-pagenavi span {
		margin: 6px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items:center;
		width: 45px;
		height: 45px;
		border-radius: 50%;
		background: #b27f4e;
		border:#b27f4e solid 2px;
		color: #FFF;
		font-size: 22px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi a.page {
		color: #b27f4e;
		text-align: center;
		border:#fff solid 2px;
		background: #FFF;
		font-size: 22px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		font-size: 16px;
		color: #b27f4e;
		background: #FFF;
		border: #FFF solid 2px;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 10px;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 10px;
	}
	.wp-pagenavi a:hover {
		background: #FFF;
		color: #b27f4e;
		border:#b27f4e solid 2px;
	}
	.wp-pagenavi span {
		background: #FFF;
		color: #b27f4e;
	}
	
	
}





/* works-detail----------------------------------------------- */
.worksdetail {
	display: block;
	padding-top: 30px;
	margin-bottom: 130px;
}
.worksdetail .ti {
	display: block;
	margin-bottom: 80px;
}
.worksdetail .ti dl {
	display: flex;
	margin-bottom: 24px;
}
.worksdetail .ti dt {
	display: block;
	color: #FFF;
	text-align: center;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 18px; /* 100% */
	letter-spacing: 1.8px;
	border-radius: 10px 0px;
	background: #E26D00;
	padding: 13px 25px;
	margin-right: 25px;
}
.worksdetail .ti dd {
	display: block;
	color: #464646;
	font-size: 21px;
	font-style: normal;
	font-weight: 700;
	line-height: 18px; /* 85.714% */
	letter-spacing: 1.68px;
	padding-top: 13px;
}
.worksdetail .ti h2 {
	display: block;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 30px;
	font-style: normal;
	font-weight: 700;
	line-height: 22px; /* 73.333% */
	letter-spacing: 3px;
	padding-bottom: 30px;
	border-bottom: #E26D00 solid 2px;
}
.worksdetail .flx {
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
}
.worksdetail .flx .imgs {
	display: block;
	flex-basis: 55%;
}
.worksdetail .flx .imgs img {
	width: 100%;
	border-radius: 30px 0;
}
.worksdetail .flx .txt {
	display: block;
	flex-basis: 40%;
}
.table02 {
	width: 100%;
	border-collapse: collapse;
}
.table02 tr:nth-of-type(odd) {
	background: #FFF6DD;
}
.table02 th {
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 26px; /* 144.444% */
	letter-spacing: 1.44px;
	padding: 20px 30px;
	width: 32%;
	text-align: left;
	vertical-align: top;
}
.table02 td {
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	padding: 20px 30px;
	text-align: left;
	vertical-align: top;
}
.worksdetail .sub-imgs {
	display: flex;
	flex-wrap: wrap;
}
.worksdetail .sub-imgs li {
	display: block;
	margin-bottom: 54px;
	margin-left: 54px;
	flex-basis: calc((100% - (54px * 3)) / 4 - .01px);
	max-width: calc((100% - (54px * 3)) / 4 - .01px);
}
.worksdetail .sub-imgs li:nth-child(4n+1) {
	margin-left: 0px;
}
.worksdetail .sub-imgs li img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: 30px 0;
}
@media screen and (min-width:769px) {
	a:hover {
		opacity: 0.7;
	}
}
.listback {
	display: block;
	text-align: center;
	position: relative;
	margin-top: 50px;
}
.listback .ons {
	display: inline-block;
}
.listback .ons a {
	display: block;
	text-align: center;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 22px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: 2.2px;
	padding: 8px 50px;
	border-radius: 50px;
	background: #FFF;
	border: 3px solid #FFC939;
}
.listback .prevs,
.listback .nexts {
	width: 220px;
}
.listback .prevs {
	position:absolute;
	top: 7px;
	right: 0;
	left: -580px;
	margin: auto;
}
.listback .nexts {
	position:absolute;
	top: 7px;
	right: -580px;
	left: 0;
	margin: auto;
}
.listback .prevs a {
	display: block;
	position: relative;
	padding-left: 50px;
}
.listback .nexts a {
	display: block;
	position: relative;
	padding-right: 50px;
}
.listback .prevs a::before {
	position: absolute;
	left: 0;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	border-radius: 50%;
	background: #FFC939;
	width: 50px;
	height: 50px;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .nexts a::before {
	position: absolute;
	right: 0;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	border-radius: 50%;
	background: #FFC939;
	width: 50px;
	height: 50px;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .prevs a::after {
	position: absolute;
	left: 21px;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 7px;
	height: 7px;
	border-bottom: 2px solid #fff;
	border-left: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .nexts a::after {
	position: absolute;
	right: 21px;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 7px;
	height: 7px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .prevs a span,
.listback .nexts a span{
	display: inline-block;
	position: relative;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 22px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: 2.2px;
	border-bottom: #FFC939 solid 1px;
	padding-bottom: 5px;
	padding-left: 10px;
	padding-right: 10px;
}

@media screen and (min-width:769px) {
	.listback .prevs a:hover::before,
	.listback .nexts a:hover::before{
		background: #E26D00;
	}
}

@media screen and (min-width:769px) and (max-width:1000px) {
	.worksdetail .flx .imgs {
		display: block;
		flex-basis: 48%;
	}
	.worksdetail .flx .txt {
		display: block;
		flex-basis: 49%;
	}
	.table02 tr:nth-of-type(odd) {
		background: #FFF6DD;
	}
	.table02 th {
		font-size: 16px;
		line-height: 26px; /* 144.444% */
		padding: 13px 20px;
		width: 32%;
	}
	.table02 td {
		font-size: 16px;
		line-height: 32px; /* 177.778% */
		padding: 13px 20px;
	}
	.listback .ons a {
		font-size: 17px;
		padding: 8px 30px;
	}
	.listback .prevs,
	.listback .nexts {
		width: 220px;
	}
	.listback .prevs {
		position:absolute;
		top: 7px;
		right: 0;
		left: -400px;
		margin: auto;
	}
	.listback .nexts {
		position:absolute;
		top: 7px;
		right: -400px;
		left: 0;
		margin: auto;
	}
}
@media screen and (max-width:768px) {
	.worksdetail {
		padding-top: 20px;
		margin-bottom: 50px;
	}
	.worksdetail .ti {
		margin-bottom: 30px;
	}
	.worksdetail .ti dl {
		display: flex;
		flex-wrap: wrap;
		margin-bottom: 15px;
	}
	.worksdetail .ti dt {
		font-size: 14px;
		line-height: 16px; /* 100% */
		padding: 7px 14px;
		margin-right: 5px;
	}
	.worksdetail .ti dd {
		display: block;
		font-size: 14px;
		line-height: 15px; /* 85.714% */
		letter-spacing: 1.68px;
		padding-top: 5px;
	}
	.worksdetail .ti h2 {
		font-size: 21px;
		line-height: 22px; /* 73.333% */
		letter-spacing: 3px;
		padding-bottom: 14px;
		border-bottom: #E26D00 solid 2px;
	}
	.worksdetail .flx {
		display: block;
		margin-bottom: 40px;
	}
	.worksdetail .flx .imgs {
		display: block;
		flex-basis: 55%;
		margin-bottom: 20px;
	}
	.worksdetail .flx .imgs img {
		width: 100%;
		border-radius: 30px 0;
	}
	.worksdetail .flx .txt {
		display: block;
		flex-basis: 40%;
	}
	.table02 {
		width: 100%;
		border-collapse: collapse !important;
	}
	.table02 tr {
		background: #FFF !important
	}
	.table02 th {
		display: block;
		box-sizing: border-box;
		color: #464646;
		font-family: "Zen Kaku Gothic New";
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 26px; /* 144.444% */
		letter-spacing: 1.44px;
		padding: 10px 15px;
		width: auto;
		text-align: left;
		vertical-align: top;
		background: #FFF6DD;
	}
	.table02 td {
		display: block;
		font-size: 15px;
		line-height: 24px; /* 177.778% */
		padding: 10px 15px;
	}
	.worksdetail .sub-imgs {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.worksdetail .sub-imgs li {
		display: block;
		margin-bottom: 15px;
		margin-left: 0px;
		flex-basis: 49%;
		max-width: 49%;
	}
	.worksdetail .sub-imgs li img {
		width: 100%;
		aspect-ratio: 4 / 3;
		object-fit: cover;
		border-radius: 15px 0;
	}
	.listback {
		display: block;
		text-align: center;
		position: relative;
		margin-top: 30px;
	}
	.listback .ons {
		display: inline-block;
	}
	.listback .ons a {
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: 2.2px;
		padding: 8px 16px;
		border-radius: 50px;
		background: #FFF;
		border: 2px solid #FFC939;
	}
	.listback .prevs,
	.listback .nexts {
		width: 90px;
	}
	.listback .prevs {
		position:absolute;
		top: 18px;
		right: 0;
		left: -190px;
		margin: auto;
	}
	.listback .nexts {
		position:absolute;
		top: 18px;
		right: -190px;
		left: 0;
		margin: auto;
	}
	.listback .prevs a {
		display: block;
		position: relative;
		padding-left: 0px;
	}
	.listback .nexts a {
		display: block;
		position: relative;
		padding-right: 0px;
	}
	.listback .prevs a::before {
		position: absolute;
		left: 0;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		border-radius: 50%;
		background: #FFC939;
		width: 50px;
		height: 50px;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .nexts a::before {
		position: absolute;
		right: 0;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		border-radius: 50%;
		background: #FFC939;
		width: 50px;
		height: 50px;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .prevs a::after {
		position: absolute;
		left: 21px;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 10px;
		height: 10px;
		border-bottom: 2px solid #fff;
		border-left: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .nexts a::after {
		position: absolute;
		right: 21px;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 10px;
		height: 10px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .prevs a span,
	.listback .nexts a span{
		display: none;
	}
}






/* privacy----------------------------------------------- */
.privacy1 {
	display: block;
	padding-top: 140px;
}
.privacy1 dl {
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width: 1020px;
	padding-top: 45px;
	counter-reset: number 0; 
}
.privacy1 dl dd {
	display: block;
	position: relative;
	font: normal normal bold 16px/32px Yu Gothic;
	letter-spacing: 0.8px;
	color: #757067;
	margin-bottom: 45px;
	padding-left: 30px;
}
.privacy1 dl dd::before {
	position:absolute;
	left: 0;
	top: 0;
	font: normal normal bold 23px/28px Montserrat;
	letter-spacing: 0px;
	color: #7890A0;
	counter-increment: number 1;      /* number カウンタを増加 */
  	content: "" counter(number) ".";
}
.privacy2 {
	display: block;
	background: url("../images/survey/gradient_bg.png") center center no-repeat;
	background-size: 100% 100%;
	padding: 110px 0;
	margin-top: 70px;
	margin-bottom: 140px;
}
.privacy2 small {
	display: block;
	font: normal normal bold 16px/32px Yu Gothic;
	letter-spacing: 0.8px;
	color: #757067;
	margin-bottom: 50px;
}
.privacy2 h3 {
	display: block;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	font: normal normal bold 40px/32px Yu Gothic;
	letter-spacing: 2px;
	color: #1C72D4;
	margin-bottom: 30px;
}
.privacy2 .fix {
	margin-left: auto;
	margin-right: auto;
	max-width: 700px;
	font: normal normal bold 23px/50px Yu Gothic;
	letter-spacing: 1.15px;
	color: #757067;
	margin-bottom: 25px;
}
.privacy2 .btn {
	width: 320px !important;
	margin-left: auto;
	margin-right: auto;
}
.privacy2 .btn a span {
	position: relative;
	padding-right: 30px;
}
.privacy2 .btn a span::after {
	background:url("../images/send1.png") center center no-repeat;
	background-size: 100% auto;
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 24px;
	height: 21px;
	right: -6px;
}
@media all and (max-width: 768px) {
	.privacy1 {
		display: block;
		padding-top: 40px;
	}
	.privacy1 dl {
		display: block;
		margin-left: auto;
		margin-right: auto;
		max-width: 1020px;
		padding-top: 0px;
		counter-reset: number 0; 
	}
	.privacy1 dl dd {
		display: block;
		position: relative;
		font: normal normal bold 14px/22px Yu Gothic;
		letter-spacing: 0.8px;
		color: #757067;
		margin-bottom: 20px;
		padding-left: 30px;
	}
	.privacy2 {
		display: block;
		background: url("../images/survey/gradient_bg.png") center center no-repeat;
		background-size: 100% 100%;
		padding: 40px 0;
		margin-top: 20px;
		margin-bottom: 40px;
	}
	.privacy2 small {
		display: block;
		font: normal normal bold 13px/18px Yu Gothic;
		letter-spacing: 0.8px;
		color: #757067;
		margin-bottom: 20px;
	}
	.privacy2 h3 {
		display: block;
		text-align: center;
		max-width: 1000px;
		margin-left: auto;
		margin-right: auto;
		font: normal normal bold 24px/30px Yu Gothic;
		letter-spacing: 2px;
		color: #1C72D4;
		margin-bottom: 15px;
	}
	.privacy2 .fix {
		margin-left: auto;
		margin-right: auto;
		max-width: 700px;
		font: normal normal bold 17px/32px Yu Gothic;
		letter-spacing: 1.15px;
		color: #757067;
		margin-bottom: 25px;
	}
	.privacy2 .btn {
		width: 270px !important;
		margin-left: auto;
		margin-right: auto;
	}
	.privacy2 .btn a span {
		position: relative;
		padding-right: 30px;
	}
}


/* contact-top----------------------------------------------- */

.c-tops {
	display: block;
	padding: 100px 0 ;
	background: #EFEFEF;
}
.c-tops .boxs {
	display: block;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	background: #FFF;
	box-sizing: border-box;
	padding: 60px;
	text-align: center;
}
.c-tops .boxs h2 {
	display: block;
	text-align: center;
	font-size: 33px;
	letter-spacing: 2px;
	line-height: 1.4;
	font-weight: bold;
	color: #c82b16;
	margin-bottom: 40px;
}
.c-tops .boxs b,
.c-tops .boxs a {
	display: block;
	position: relative;
	font-size: 35px;
	font-weight: 600;
	font-family: "Lexend", serif;
	color: #000;
	line-height: 1;
	letter-spacing: 3px;
}
.c-tops .boxs small {
	display: block;
	padding-top: 10px;
	font-size: 17px;
	font-weight: 600;
}
.c-cont {
	padding: 100px 0;
}
.title03 {
	display: block;
	font-size: 24px;
	letter-spacing: 2px;
	line-height: 1.5;
	background:#EFEFEF;
	padding: 16px 25px;
	margin-bottom: 35px;
	border-radius: 10px;
}
.title03.v2 {
	display: block;
	text-align: center;
	font-size: 28px;
	letter-spacing: 2px;
	line-height: 1.5;
	background:none;
	padding: 0;
	margin-bottom: 35px;
	border-radius: 10px;
}
.mcont {
	text-align: center;
	line-height: 2;
}
.fix-1100 {
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}
@media all and (max-width: 1100px) {
	.fix-1100 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 768px) {
	.c-tops {
		display: block;
		padding: 40px 0 ;
		background: #EFEFEF;
	}
	.c-tops .boxs {
		display: block;
		max-width: 700px;
		margin-left: auto;
		margin-right: auto;
		background: #FFF;
		box-sizing: border-box;
		padding: 20px;
		text-align: center;
	}
	.c-tops .boxs h2 {
		display: block;
		text-align: center;
		font-size: 20px;
		letter-spacing: 2px;
		line-height: 1.4;
		font-weight: bold;
		color: #c82b16;
		margin-bottom: 20px;
	}
	.c-tops .boxs b,
	.c-tops .boxs a {
		display: block;
		position: relative;
		font-size: 23px;
		font-weight: 600;
		font-family: "Lexend", serif;
		color: #000;
		line-height: 1;
		letter-spacing: 3px;
	}
	.c-tops .boxs small {
		display: block;
		padding-top: 10px;
		font-size: 14px;
		font-weight: 600;
	}
	.c-cont {
		padding: 100px 0;
	}
	.title03 {
		display: block;
		font-size: 20px;
		letter-spacing: 2px;
		line-height: 1.5;
		background:#EFEFEF;
		padding: 12px 15px;
		margin-bottom: 24px;
	}
	.title03.v2 {
		display: block;
		text-align: center;
		font-size: 23px;
		letter-spacing: 2px;
		line-height: 1.5;
		background:none;
		padding: 0;
		margin-bottom: 25px;
		border-radius: 10px;
	}
	.mcont {
		text-align:left;
		line-height: 2;
	}
}


/* estimate----------------------------------------------- */
.forms-base {
	display: block;
	padding-top: 90px;
	margin-left: 4%;
	margin-right: 4%;
	padding-bottom: 90px;
}
.forms-base .title01 {
	margin-bottom: 40px;
}
.form-wraps {
	margin-top: 65px;
	border-radius: 10px;
}
.form-wraps .txt_01 {
	padding-top: 45px;
	text-align: center;
	margin-bottom: 50px;
}
.forms-table {
	width: 100%;
	border-collapse: collapse;
}
.forms-table th {
	display: block;
	text-align: left;
	vertical-align: top;
	position: relative;
	color: #3F3B3A;
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 26px; /* 130% */
	letter-spacing: 1.6px;
	padding: 20px;
	background: #EFEFEF;
	border-radius: 10px;
}
.forms-table th.requier::after {
	margin-left: 25px;
	content: "必須";
	background: #c82b16;
	color: #FFF;
	font-size: 15px;
	font-style: normal;
	font-weight: 500;
	line-height: 27px; /* 150% */
	letter-spacing: 1.8px;
	padding: 1px 11px 3px 11px;
	border-radius: 0px;
}
.forms-table td {
	display: block;
	text-align: left;
	vertical-align: top;
	padding-top: 15px;
	padding-bottom: 25px;
	
}
.bl-labs {
	background: none;
	padding-left: 0px;
	padding-right: 0px;
}
.n001 {
	width: 100%;
	box-sizing: border-box;
	padding: 20px;
	border: 0px;
	font-size: 16px;
	font-style: normal;
	font-weight: 700 !important;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	background: #fff;
	border: #EFEFEF solid 1px;
	border-radius: 10px;
}
.n002 {
	width: 60%;
	box-sizing: border-box;
	padding: 20px;
	border: 0px;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
	background: #fff;
	border: #EFEFEF solid 1px;
	border-radius: 10px;
}
.txer {
	width: 100%;
	height: 240px;
	box-sizing: border-box;
	padding: 20px;
	border: 0px;
	font-size: 16px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
	background: #fff;
	border: #EFEFEF solid 1px;
	border-radius: 10px;
}
::placeholder {
	font-size: 18px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	color: #888;
}
.form-in {
	margin-bottom: 10px;
}
.select-over {
	display: block;
	width: 60%;
}
.select-over select {
	width: 100%;
	height: 60px;
	background: #fff;
	font-size: 17px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
	padding-left: 20px;
	padding-right: 20px;
	border: none;
	color: #3F3B3A !important;
	border: #EFEFEF solid 1px;
}
.select-over select option:nth-child(1) {
	
}
select:invalid {
    color: #888 !important;
}
select option:first-child {
    color: #888 !important;
}

select:invalid {
    color: #888;
}

select option {
    color: #333;
}
/* radioBtn */
.blocks-label {
	margin-top: 17px;
}
.radio__list {
	border: 0px !important;
}
label {
	color: #333;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
}
input.radioBtn {
	top: 3px;
	block-size: 2rem;
	inline-size: 2rem;
	position: relative;
	z-index: 1;
	margin-left: 5px;
	margin-right: 8px;
	border: 0px !important;
}
input.radioBtn::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 17px;
  height: 17px;
  border-radius: 50%;
	background: #DBDBDB;
	border: 5px solid #FFF;
}

input.radioBtn::after {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  background: #43b23a;
  border-radius: 50%;
  opacity: 0;
}
input.radioBtn[type="radio"]:checked::after {
  opacity: 1;
}
label {
  cursor: pointer;
}
.blocks-label label {
	display: inline-block;
	margin-bottom: 10px;
	width: auto !important;
	font-weight: 600;
}
label.radio__list {
	margin-right: 30px;
}
.cbtn {
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
	text-align: center;
	padding: 30px 0 40px 0;
}
.sbt {
	width: 400px;
	height: 65px;
	border: #B27F4E solid 1px;
	color: #FFF;
	border-radius: 50px;
	cursor: pointer;
	font-size: 17px;
	background: #B27F4E;
	margin-left: 10px;
	margin-right: 10px;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.sbt.v2 {
	background: #333;
}
input[type="submit"] {
  -webkit-appearance: none;
}
.addf {
	margin-top: 14px;
}
@media all and (min-width: 769px) {
	.sbt:hover {
		background: #333;
		color: #fff;
	}
	.sbt.v2:hover {
		opacity: 0.7;
	}
}
select {
	border-radius: 10px;
}


/* privacy__policy */
.privacy__policy--area {
	margin-top: 50px;
  padding: 0px 0;
	
  
}
.privacy__policy {
  padding: 20px 0px 40px 0px;
}
.privacy__policy .scr {
	height: 325px;
	padding-right: 50px;
	padding: 50px;
	margin-right: 26px;
	background: #EFEFEF;
  overflow-y: scroll;
	border-radius: 10px;
}


.privacy__policy .scr::-webkit-scrollbar {
  width: 8px;  
  margin-top: 41px;
}
.privacy__policy .scr::-webkit-scrollbar-track {
	background-size: auto 5px;
}
.privacy__policy .scr::-webkit-scrollbar-thumb {
  background: #B27F4E;
  height: 100px;
}

.privacy__policy p:first-of-type {
  font-size: 24px;
	font-weight: 700;
	margin-bottom: 24px;
}
.privacy__policy p.s-mt {
  color: #3F3B3A;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 29px; /* 108.333% */
	letter-spacing: 1.92px;
  margin-bottom: 16px;
}
.privacy__policy p.p-tt {
	font-size: 18px !important;
}
.privacy__policy p.mp-ti {
	font-size: 17px !important;
}
.privacy__policy p span {
  font-size: 17px;
  margin-bottom: 5px;
  display: block;
}
.privacy__policy ul {
  margin-bottom: 16px;
}
.privacy__policy ul li {
  list-style: disc;
  margin-left: 20px;
}
.form_consent_txt {
  text-align: center;
  color: #3F3B3A;
	font-size: 20px;
	font-style: normal;
	font-weight: 700 !important;
	line-height: normal;
	letter-spacing: 2.2px;
  padding: 50px 5px 0;
}
.form_consent_txt label {
	position: relative;
	font-weight: 700 !important;
}
input[type="checkbox"] {
  position: relative;
	top: 3px;
  width: 23px;
  height: 22px;
  border: 1px solid #000;
  vertical-align: -5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

input[type="checkbox"]:checked:before {
  position: absolute;
  top: -5px;
  left: 7px;
  transform: rotate(50deg);
  width: 11px;
  height: 20px;
  border-right: 3px solid #B27F4E;
  border-bottom: 3px solid #B27F4E;
  content: '';
}
select {
	cursor: pointer;
}

.center-txt1 {
	color: #464646;
	text-align: center;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
}

@media all and (max-width: 768px) {
	.forms-base {
		display: block;
		padding-top: 40px;
		padding-bottom: 50px;
	}
	.form-wraps {
		margin-left: auto;
		margin-right: auto;
		max-width: 1000px;
		padding: 15px 0;
	}
	.form-wraps .txt_01 {
		text-align: left;
		padding-top: 20px;
		margin-bottom: 20px;
	}
	.forms-base .center-txt1 {
		text-align: left;
		font-size: 16px;
		line-height: 1.9;
		margin-left: 4%;
		margin-right: 4%;
	}
	.forms-table {
		width: 100%;
		border-collapse: collapse;
	}
	.forms-table th {
		display: block;
		text-align: left;
		vertical-align: top;
		position: relative;
		width: 100%;
		box-sizing: border-box;
		font-size: 15px;
		letter-spacing: 0px;
		padding: 20px 15px;
		margin-bottom: 10px;
	}
	.forms-table th.requier::after {
		position:relative;
		right: 15px;
		top: 0px;
		content: "必須";
		font-size: 14px;
		letter-spacing: 0px;
		padding: 3px 10px;
	}
	.forms-table td {
		display: block;
		text-align: left;
		vertical-align: top;
		padding-bottom: 0px;
		padding-top: 0px;
		margin-bottom: 22px;
	}
	.bl-labs {
		padding-left: 15px;
		padding-right: 15px;
		padding-top: 1px !important;
		padding-bottom: 15px !important;
	}
	.bl-labs label {
		padding-bottom: 10px;
		margin-bottom: 0px;
	}
	.n001 {
		width: 100%;
		box-sizing: border-box;
		padding: 15px;
		font-size: 15px;
		border: 0px;
		border: #EFEFEF solid 1px;
	}
	.n002 {
		width: 100%;
		box-sizing: border-box;
		padding: 15px;
		font-size: 15px;
		border: 0px;
		border: #EFEFEF solid 1px;
	}
	.txer {
		width: 100%;
		height: 180px;
		box-sizing: border-box;
		padding: 15px;
		font-size: 15px;
		border: 0px;
		border: #EFEFEF solid 1px;
	}
	.blocks-label span {
		height: auto !important;
		margin-left: 0 !important;
	}
	.blocks-label span label {
		margin-bottom: 0 !important;
		padding-bottom: 0px !important;
	}
	::placeholder {
		font-size: 15px;
	}
	.form-in {
		margin-bottom: 10px;
	}
	.select-over {
		display: block;
		width: 100%;
	}
	.select-over select {
		width: 100%;
		height: 55px;
		background: #fff;
		font-size: 15px;
		letter-spacing: 0px;
		color: #3F3B3A !important;
		padding-left: 20px;
		padding-right: 20px;
		border: #EFEFEF solid 1px;
	}
	.select-over select option:nth-child(1) {

	}

	select option {
		color: #333;
	}
	/* radioBtn */
	.radio__list {
		border: 0px !important;
		padding-top: 9px;
	}
	label {
		font-size: 15px;
		letter-spacing: 0px;
	}
	input.radioBtn[type="radio"]:checked::after {
	  opacity: 1;
	}
	label {
	  cursor: pointer;
	}
	.blocks-label label {
		display: block;
		width: auto !important;
	}
	label.radio__list {
		margin-right: 30px;
	}
	.cbtn {
		display: block;
		text-align: center;
		padding: 30px 0 40px 0;
	}
	.privacy__policy--area {
	  padding-top: 25px;
	  padding: 15px 0;
		margin-top: 20px;
		margin-right: 0px !important;
	}
	.privacy__policy {
	  padding: 20px 0px 20px 0px !important;
	}
	.privacy__policy .scr {
		height: 245px;
		padding-right: 20px;
		padding: 15px;
		margin-right: 0px;
	  overflow-y: scroll;
	}
	.privacy__policy .scr::-webkit-scrollbar {
	  width: 6px;
	  margin-top: 41px;
	}
	.privacy__policy .scr::-webkit-scrollbar-track {
	  background-color: #fff;
	}
	.privacy__policy .scr::-webkit-scrollbar-thumb {
	  height: 100px;
	}
	.privacy__policy p:first-of-type {
	  font-size: 17px;
		font-weight: 700;
		margin-bottom: 14px;
	}
	.privacy__policy p.s-mt {
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 21px; /* 108.333% */
		letter-spacing: 1.92px;
	  margin-bottom: 16px;
	}
	.privacy__policy p span {
	  font-size: 15px;
	  margin-bottom: 5px;
	  display: block;
	}
	.privacy__policy ul {
	  margin-bottom: 16px;
	}
	.privacy__policy ul li {
	  list-style: disc;
	  margin-left: 20px;
	}
	.sbt {
		width: 270px;
		height: 55px;
		border: none;
		color: #FFF;
		border-radius: 50px;
		cursor: pointer;
		font-size: 15px;
		margin-bottom: 15px;
	}
	.form_consent_txt {
		background: none !important;
	}
}




.fl100p {
	flex-basis: 100% !important;
}
.no-ims {
	display: block !important;
	text-align: right !important;
	padding-top: 35px;
	flex-basis: 100% !important;
}
.no-ims span {
	display: block;
	font-size: 18px;
	text-align: right !important;
}
.mw_wp_form_confirm .privacy__policy--area {
	display: none !important;
}
.mw_wp_form_confirm  .bl-labs {
	padding-left: 0 !important;
	padding-right: 0 !important;
}


.mx-1100 {
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}
.mx-1000 {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
@media all and (max-width: 999px) {
	.mx-1000 {

	}
}




.cols001 {
	text-align: center;
	font-weight: 900;
	background: #EFEFEF;
	padding: 22px 0 !important;
	font-size: 18px !important;
}
.mb35 {
	margin-bottom: 35px;
}
.bge2 {
	background: #fbeedf !important;
}
.bge2.go {
	padding-left: 2%;
	padding-right: 2%;
	font-size: 22px !important;
}
.bg-fff {
	background: #FFF;
}
.bg-fff .rectitle {
	background: #efefef;
}
.pt-01 {
	padding: 90px 0 40px 0!important;
}
.mb100 {
	margin-bottom: 100px;
}
@media all and (max-width:768px) {
	.cols001 {
		text-align: center;
		font-weight: 900;
		background: #eafce8 !important;
		padding: 14px 0 !important;
		font-size: 17px !important;
	}
	.table01.prices .bge2 {
		padding-left: 2%;
		padding-right: 2%;
		text-align: center !important;
		font-size: 20px !important;
		padding-top: 10px !important;
		padding-bottom: 10px !important;
	}
}



.flx-03 {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.flx-03 .txt {
	display: block;
	flex-basis: 55%;
}
.flx-03 .txt h3 {
	display: block;
	font-size: 22px;
	letter-spacing: 2px;
	line-height: 1.6;
	margin-bottom: 35px;
}
.flx-03 .imgs {
	display: block;
	flex-basis: 38%;
}
.flx-03 .imgs img {
	width: 100%;
}
@media all and (max-width:768px) {
	.flx-03 {
		display: block;
	}
	.flx-03 .txt {
		display: block;
		flex-basis: 55%;
		margin-bottom: 22px;
	}
	.flx-03 .txt h3 {
		display: block;
		font-size: 18px;
		letter-spacing: 2px;
		line-height: 1.6;
		margin-bottom: 20px;
	}
}



.recruit1 {
	display: block;
	padding: 100px 0;
}
.recruit1 .mt {
	display: block;
	text-align: center;
	font-size: 20px;
	letter-spacing: 3px;
	line-height: 2.2;
	margin-bottom: 50px;
}
.recruit1 ul {
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content:flex-start;
	flex-wrap: wrap;
}
.recruit1 ul li {
	display: block;
	flex-basis: 30%;
	margin-left: 1.5%;
	margin-right: 1.5%;
	margin-bottom: 24px;
}
.recruit1 ul li img {
	width: 100%;
	object-fit: cover;
	border-radius: 10px;
	aspect-ratio: 1 / 1;
}
.interview {
	display: block;
	padding: 100px 0 40px 0;
	background: #FFF;
}
.interview .flx {
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
}
.interview .flx .lef {
	display: block;
	flex-basis: 30%;
	text-align: center;
	padding-top: 40px;
}
.interview .flx .lef .imgs {
	border: #dfb790 solid 10px;
	border-radius: 20px;
	overflow: hidden;
}
.interview .flx .lef img {
	width: 100%;
}
.interview .flx .lef span {
	display: block;
	padding: 6px 0;
	text-align: center;
	font-size: 18px;
}
.interview .flx .lef h3 {
	display: block;
	text-align: center;
	font-size: 30px;
	
}
.interview .flx .ref {
	flex-basis: 66%;
}
.recruitment {
	display: block;
	padding: 100px 0;
}
.tab1 {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	text-align: center;
	margin: 0 !important;
}
.tab1__item {
	display: inline-block;
	padding: 10px;
}
.tab1__link {
	display: block;
	text-decoration: none;
	color: #B27F4E;
	background-color: #fad8b7;
	cursor: pointer;
	border-radius: 10px;
	padding: 7px 25px;
	font-size: 17px;
	letter-spacing: 3px;
	font-weight: bold;
}
.tab1__link.on {
	background-color: #B27F4E !important;color: #FFF;
}
.tab1-body__item {
	margin: 30px 15px;
	display: none;
	text-align: center;
}
.tab1-body__item.on {
	display: block;
}
.comp-tab {
	width: 100%;
}
.comp-tab table {
	width: 100%;
	border-collapse: collapse;
	border-top: #B27F4E solid 1px;
}
.comp-tab table th {
	text-align: left;
	vertical-align: top;
	padding: 20px 2%;
	background: #feecda;
	font-size: 16px;
	line-height: 2;
	color: #B27F4E;
	width: 25%;
	border-bottom: #B27F4E solid 1px;
}
.comp-tab table td {
	text-align: left;
	vertical-align: top;
	padding: 20px 2%;
	font-size: 16px;
	line-height: 2;
	border-bottom: #B27F4E solid 1px;
}
.recruitment .btl {
	padding-top: 50px;
	padding-bottom: 50px;
	max-width: 350px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}
.recruitment .btl a {
	justify-content: center;
}
@media all and (min-width:769px) {
	.tab1__link:hover {
		background-color: #B27F4E !important;color: #FFF;
	}
}

@media all and (max-width:768px) {
	.recruit1 {
		display: block;
		padding: 50px 0;
	}
	.recruit1 .mt {
		display: block;
		text-align:left;
		font-size: 16px;
		letter-spacing: 1px;
		line-height: 2;
		margin-bottom: 30px;
	}
	.recruit1 ul {
		max-width: 900px;
		margin-left: auto;
		margin-right: auto;
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
	}
	.recruit1 ul li {
		display: block;
		flex-basis: 31%;
		margin-left: 1%;
		margin-right: 1%;
		margin-bottom: 14px;
	}
	.recruit1 ul li img {
		width: 100%;
		object-fit: cover;
		border-radius: 10px;
		aspect-ratio: 1 / 1;
	}
	.interview {
		display: block;
		padding: 50px 0 40px 0;
		background: #FFF;
	}
	.interview .flx {
		display: block;
		margin-bottom: 40px;
	}
	.interview .flx .lef {
		display: block;
		flex-basis: 30%;
		text-align: center;
		padding-top: 50px;
	}
	.interview .flx .lef .imgs {
		border: #dfb790 solid 10px;
		border-radius: 20px;
		overflow: hidden;
	}
	.interview .flx .lef img {
		width: 100%;
	}
	.interview .flx .lef span {
		display: block;
		padding: 6px 0;
		text-align: center;
		font-size: 15px;
	}
	.interview .flx .lef h3 {
		display: block;
		text-align: center;
		font-size: 22px;
		padding: 0;
		margin: 0;
		line-height: 1.4;

	}
	.interview .flx .ref {
		flex-basis: 66%;
	}
	.interview .flx .ref .acMenu {
		padding-top: 0 !important;
		margin-top: 0 !important;
	}
	.recruitment {
		display: block;
		padding: 50px 0;
	}
	.tab1 {
		display: block;
		text-align: center;
		margin: 0 !important;
	}
	.tab1__item {
		display: block;
		padding: 10px;
	}
	.tab1__link {
		display: block;
		text-decoration: none;
		color: #B27F4E;
		background-color: #fad8b7;
		cursor: pointer;
		border-radius: 10px;
		padding: 7px 25px;
		font-size: 17px;
		letter-spacing: 3px;
		font-weight: bold;
	}
	.tab1__link.on {
		background-color: #B27F4E !important;color: #FFF;
	}
	.tab1-body__item {
		margin: 30px 15px;
		display: none;
		text-align: center;
	}
	.tab1-body__item.on {
		display: block;
	}
	.comp-tab {
		width: 100%;
	}
	.comp-tab table {
		width: 100%;
		border-collapse: collapse;
		border-top: #B27F4E solid 1px;
	}
	.comp-tab table th {
		display: block;
		text-align: left;
		vertical-align: top;
		padding: 14px 2%;
		background: #feecda;
		font-size: 15px;
		line-height: 2;
		color: #B27F4E;
		width: auto;
		border-bottom: #B27F4E solid 1px;
	}
	.comp-tab table td {
		display: block;
		text-align: left;
		vertical-align: top;
		padding:14px 2% 25px 2%;
		font-size: 15px;
		line-height: 2;
		border-bottom: #B27F4E solid 1px;
	}
	.recruitment .btl {
		padding-top: 30px;
		padding-bottom: 30px;
		max-width: 270px;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
	}
	.recruitment .btl a {
		justify-content: center;
	}
}



.service2 {
	display: block;
	padding: 100px 0;
	background: #FFF;
}
.servlist {
	display: block;
	position: relative;
	padding: 45px;
	border-radius: 15.5px;
	background: #F5E8DE;
	box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
	margin-top: 100px;
}
.servlist h3 {
	position: absolute;
	left: 0;
	top: -30px;
	width: 100%;
	text-align: center;
}
.servlist h3 span {
	display: inline-flex;
	padding: 17px 50px;
	border-radius: 50px;
	color: #FFF;
	font-size: 25px;
	letter-spacing: 3px;
	background: #B27F4E;
}
.servlist .mc {
	display: block;
	text-align: center;
	font-size: 17px;
	letter-spacing: 2px;
	line-height: 2.2;
	margin-bottom: 45px;
	padding-top: 30px;
}
.servlist ul {
	display:flex;
	justify-content: space-between;
	flex-wrap: wrap;
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
}
.servlist ul li {
	display: block;
	font-size: 17px;
	font-weight: bold;
	background: #FFF;
	box-sizing: border-box;
	padding: 14px 3%;
	flex-basis: 48%;
	margin-bottom: 15px;
	text-align: center;
	border-radius: 45px;
}
.service3 {
	padding: 100px 0;
}
.service3 .flx {
	padding-top: 80px;
	display: flex;
	justify-content: space-between;
}
.service3 .lef {
	display: block;
	flex-basis: 48%;
}
.service3 .ti {
	display: flex;
	margin-bottom: 22px;
}
.service3 .ti span {
	display: block;
	margin-right: 15px;
}
.service3 .ti h3 {
	display: block;
	color: #5C4228;
	font-size: 28px;
	font-style: normal;
	font-weight: 700;
	line-height: 1.7; /* 70px */
	letter-spacing: 1.4px;
}
.service3 .lef ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	background: #fff;
	padding: 20px;
	border-radius: 10px;
	box-sizing: border-box;
	width: 100%;
}
.service3 .lef ul li {
	flex-basis: 48%;
	margin-bottom: 10px;
	font-size: 17px;
	padding: 13px 0;
	border-radius: 10px;
	background: #f8e5d2;
	text-align: center;
}
.service3 .ref {
	flex-basis: 48%;
}
.service3 .ref h4 {
	display: block;
	font-size: 17px;
	padding: 13px 4%;
	border-radius: 10px;
	background: #f8e5d2;
	margin-bottom: 20px;
}
.service3 .ref .txt_01 {
	margin-bottom: 35px;
}
.title04 {
	display: block;
	text-align: center;
	font-size: 26px;
	letter-spacing: 4px;
	line-height: 1.6;
	margin-bottom: 35px;
}
.pdf-box {
	margin-bottom: 45px;
}
.pd-link {
	display: block;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 25px;
}
.pd-link a {
	display: block;
	position: relative;
	border-radius: 10px;
	color: #B27F4E;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.5;
	border: #B27F4E solid 3px;
	padding: 19px 45px 19px 24px;
}
.pd-link a::after {
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	content: "";
	margin: auto;
	background: url("../images/recruit/pdf2.png") center center no-repeat;
	background-size: 100% auto;
	width: 35px;
	height: 100%;
}
.btl.w-400 {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}
@media all and (min-width:769px) {
	.pd-link a:hover {
		background: #f7f7f7;
	}
}

@media all and (max-width:768px) {
	.service2 {
		display: block;
		padding: 50px 0;
		background: #FFF;
	}
	.servlist {
		display: block;
		position: relative;
		padding: 35px 15px 15px 15px;
		border-radius: 15.5px;
		background: #F5E8DE;
		box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
		margin-top: 60px;
	}
	.servlist h3 {
		position: absolute;
		left: 0;
		top: -25px;
		width: 100%;
		text-align: center;
	}
	.servlist h3 span {
		display: inline-flex;
		padding: 11px 15px;
		border-radius: 50px;
		color: #FFF;
		font-size: 18px;
		letter-spacing: 3px;
		background: #B27F4E;
	}
	.servlist .mc {
		display: block;
		text-align:left;
		font-size: 15px;
		letter-spacing: 2px;
		line-height: 2;
		margin-bottom: 25px;
		padding-top: 20px;
	}
	.servlist ul {
		display: block;
		max-width: 960px;
		margin-left: auto;
		margin-right: auto;
	}
	.servlist ul li {
		display: block;
		font-size: 15px;
		font-weight: bold;
		background: #FFF;
		padding: 10px 5%;
		flex-basis: 48%;
		margin-bottom: 10px;
		text-align: center;
		border-radius: 45px;
	}
	.service3 {
		padding: 50px 0 20px 0;
	}
	.service3 .flx {
		padding-top: 30px;
		display: block;
	}
	.service3 .lef {
		display: block;
		flex-basis: 48%;
		margin-bottom: 45px;
	}
	.service3 .ti {
		display: flex;
		margin-bottom: 22px;
	}
	.service3 .ti span {
		display: block;
		width: 30px;
		margin-right: 15px;
	}
	.service3 .ti h3 {
		display: block;
		color: #5C4228;
		font-size: 18px;
		font-style: normal;
		font-weight: 700;
		line-height: 1.7; /* 70px */
		letter-spacing: 1.4px;
	}
	.service3 .lef ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		background: #fff;
		padding: 20px;
		border-radius: 10px;
		box-sizing: border-box;
		width: 100%;
	}
	.service3 .lef ul li {
		flex-basis: 48%;
		margin-bottom: 10px;
		font-size: 17px;
		padding: 13px 0;
		border-radius: 10px;
		background: #f8e5d2;
		text-align: center;
	}
	.service3 .ref {
		flex-basis: 48%;
	}
	.service3 .ref h4 {
		display: block;
		font-size: 17px;
		padding: 13px 4%;
		border-radius: 10px;
		background: #f8e5d2;
		margin-bottom: 20px;
	}
	.service3 .ref .txt_01 {
		margin-bottom: 35px;
	}
	.title04 {
		display: block;
		text-align: center;
		font-size: 18px;
		letter-spacing: 4px;
		line-height: 1.6;
		margin-bottom: 20px;
	}
	.pdf-box {
		margin-bottom: 45px;
	}
	.pd-link {
		display: block;
		max-width: 700px;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 25px;
	}
	.pd-link a {
		display: block;
		position: relative;
		border-radius: 10px;
		color: #B27F4E;
		font-size: 14px;
		font-weight: 600;
		line-height: 1.5;
		border: #B27F4E solid 3px;
		padding: 15px 45px 15px 14px;
	}
	.pd-link a::after {
		position: absolute;
		right: 20px;
		top: 0;
		bottom: 0;
		content: "";
		margin: auto;
		background: url("../images/recruit/pdf2.png") center center no-repeat;
		background-size: 100% auto;
		width: 35px;
		height: 100%;
	}
	.btl.w-400 {
		max-width: 400px;
		margin-left: auto;
		margin-right: auto;
	}
}
.top-box4.sub {
	padding: 0 !important;
}
.nones {
	display: none !important;
}


.subinfocat {
	display:block;
}
.subinfocat dt {
	display: block;
	margin-right: 0px;
	width: 100px;
	font-size: 12px;
	line-height: 1.5;
	padding-bottom: 3px;
}
.subinfocat dd {
	display: block;
}
.subinfocat span {
	display: inline-block;
	font-size: 11px;
	line-height: 1.4;
	padding: 3px 9px;
	border-radius: 3px;
	margin-right: 0px;
	margin-bottom: 4px;
	background: #B27F4E;
	color: #FFF;
}
.infolist.subs a .txt p {
	font-size: 14px;
	line-height: 1.7;
	margin-right: 10px;
}
.infolist.subs a {
	padding-right: 20px ;
}
.infolist.subs a::after {
    position: absolute;
    right: 4px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    background: url(../images/arrow_forward.png) center center no-repeat;
	background-size: 100% auto;
    width: 18px;
    height: 18px;
}



.info-n-p-box {
	position: relative;
	margin-top: 45px;
}
.info-n-p-box a {
	display: inline-block;
	font-size: 15px;
	color: #FFF;
	padding: 10px 24px;
	border-radius: 4px;
	background: #B27F4E;
	border: #B27F4E solid 2px;
}
@media all and (min-width:768px) {
	.info-n-p-box a:hover {
		object-fit: 1;
		color: #B27F4E;
		background: #fff;
	}
}
.info-n-p-box .net1 {
	position: absolute;
	left: 0;
	top: 0;
}
.info-n-p-box .prv1 {
	position: absolute;
	right: 0;
	top: 0;
}
.center-btn4 {
	max-width: 200px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 10;
}
.center-btn4 a {
	display: block;
	font-size: 15px;
	text-align: center;
	color: #FFF;
	padding: 10px 24px;
	border-radius: 4px;
	background: #B27F4E;
	border: #B27F4E solid 2px;
}
@media all and (min-width:768px) {
	.center-btn4 a:hover {
		object-fit: 1;
		color: #B27F4E;
		background: #fff;
	}
}
@media all and (max-width:767px) {
	.info-n-p-box a {
		display: block;
		max-width: 100px;
		font-size: 13px;
		color: #FFF;
		padding: 2px 4px;
		border-radius: 4px;
		background: #B27F4E;
		border: #B27F4E solid 2px;
		line-height: 1.5;
	}
	.center-btn4 a {
		display: block;
		font-size: 13px;
		text-align: center;
		color: #FFF;
		padding: 2px 0px;
		border-radius: 4px;
		background: #B27F4E;
		border: #B27F4E solid 2px;
		line-height: 1.5;
	}
	
	.center-btn4 {
		max-width: 90px;
		margin-left: auto;
		margin-right: auto;
		position: relative;
		z-index: 10;
		margin-top: 38px;
	}
}
