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

#gHeader {
}
.mainVisual.submain {
	min-height: 685px;
	height: 685px;
}
.mainVisual.submain .engs {
	text-align: right;
	display: block;
}
.mainVisual.submain h1 {
	display: flex;
	align-items: center;
}
.mainVisual.submain h1 small {
	margin-left: 25px;
	color: #000;
	font-size: 20px;
	font-style: normal;
	font-weight: 900;
	line-height: normal;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	font-family: "Lato", sans-serif !important;
}
.sub-mainVisual .imgs {
	display: block;
	position:absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.sub-mainVisual .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media all and (max-width: 768px) {
	.mainVisual.submain {
		min-height: 345px;
		height: 345px;
	}
	.mainVisual.submain .engs {
		text-align: right;
		display: block;
	}
	.mainVisual.submain h1 {
		display: flex;
		align-items: center;
	}
	.mainVisual.submain h1 small {
		margin-left: 25px;
		color: #000;
		font-size: 20px;
		font-style: normal;
		font-weight: 900;
		line-height: normal;
		letter-spacing: 0.8px;
		text-transform: uppercase;
		font-family: "Lato", sans-serif !important;
	}
	.mainVisual.submain .imgs {
		position: absolute;
		right: 0;
		top: 160px;
		width: 100%;
		height: calc(100% - 160px);
	}
}




.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;
	}
}



/* business----------------------------------------------- */
.subpage-contents {
	color: #000;
}
.subpage-contents p {
	color: #000;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 180%; /* 32.4px */
	letter-spacing: 0.9px;
}
.company1 {
	padding: 140px 0 0 0;
}
.company1 .flx {
	display:flex;
	justify-content: space-between;
	margin-top: 60px;
}
.company1 .flx .txt {
	display:block;
	flex-basis: 65%;
}
.names-right {
	display: block;
	text-align: right;
	color: #000;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 180%; /* 32.4px */
	letter-spacing: 0.9px;
	margin-top: 30px;
}
.names-right span {
	font-size: 22px;
	margin-left: 15px;
}
.company1 .flx .imgs {
	display: block;
	flex-basis: 30%;
}
.company1 .flx .imgs img {
	width: 100%;
}
.company2 {
	padding: 140px 0 0 0;
}
.comp-tab1 {
	display: block;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}
.company2 .comp-tab1 {
	margin-top: 55px;
}
.comp-tab1 table {
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #B0AB99;
}
.comp-tab1 table th {
	text-align: left;
	vertical-align: top;
	color: #000;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 24px; /* 150% */
	letter-spacing: 0.8px;
	width: 20%;
	padding: 20px 0;
	border-bottom: 1px solid #B0AB99;
}
.comp-tab1 table td {
	text-align: left;
	vertical-align: top;
	color: #000;
	font-size: 15px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%; /* 22.5px */
	letter-spacing: 0.75px;
	padding: 20px 0 20px 25px;
	border-bottom: 1px solid #B0AB99;
}
.gmaps {
	display: block;
	margin-top: 55px;
}
.gmaps iframe {
	width: 100%;
	height: 470px;
}
.flx-comp {
	display: flex;
	justify-content: space-between;
}
.flx-comp .lef {
	display: block;
	flex-basis: 23%;
}
.flx-comp .comp-tab1 {
	flex-basis:65%;
	margin-right: 10%;
	margin-top: 0;
}
.comp-tab1.v2 th {
	width: auto;
	vertical-align: middle;
}
.comp-tab1.v2 td {
	text-align: right;
	width: 170px;
	vertical-align: middle;
}
.rec-banner {
	position: relative;
	left: -38px;
	width: calc(100% + 38px)
}
.rec-banner img {
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
@media all and (min-width: 769px) {
	.rec-banner img:hover {
		opacity: 0.7;
	}
	
}

@media all and (max-width: 768px) {
	.subpage-contents p {
		color: #000;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 32.4px */
		letter-spacing: 0.9px;
	}
	.company1 {
		padding: 40px 0 0 0;
	}
	.company1 .flx {
		display: block;
		margin-top: 25px;
	}
	.company1 .flx .txt {
		display:block;
		flex-basis: 65%;
		margin-bottom: 24px;
	}
	.names-right {
		display: block;
		text-align: right;
		color: #000;
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 180%; /* 32.4px */
		letter-spacing: 0.9px;
		margin-top: 20px;
	}
	.names-right span {
		font-size: 17px;
		margin-left: 15px;
	}
	.company1 .flx .imgs {
		display: block;
		flex-basis: 30%;
	}
	.company1 .flx .imgs img {
		width: 100%;
	}
	.company2 {
		padding: 40px 0 0 0;
	}
	.comp-tab1 {
		display: block;
		max-width: 900px;
		margin-left: auto;
		margin-right: auto;
	}
	.company2 .comp-tab1 {
		margin-top: 55px;
	}
	.comp-tab1 table {
		width: 100%;
		border-collapse: collapse;
		border-top: 1px solid #B0AB99;
	}
	.comp-tab1 table th {
		display: block;
		background: #f7f7f7;
		text-align: left;
		vertical-align: top;
		color: #000;
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 2; /* 150% */
		letter-spacing: 0.8px;
		width: auto;
		padding: 14px 2%;
		border-bottom: 1px solid #B0AB99;
	}
	.comp-tab1 table td {
		display: block;
		text-align: left;
		vertical-align: top;
		color: #000;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 22.5px */
		letter-spacing: 0.75px;
		padding: 14px 2% 14px 2%;
		border-bottom: 1px solid #B0AB99;
	}
	.gmaps {
		display: block;
		margin-top: 25px;
	}
	.gmaps iframe {
		width: 100%;
		height: 330px;
	}
	.flx-comp {
		display: block;
	}
	.flx-comp .lef {
		display: block;
		flex-basis: 23%;
		margin-bottom: 24px;
	}
	.flx-comp .comp-tab1 {
		flex-basis:65%;
		margin-right: 0%;
		margin-top: 0;
	}
	.comp-tab1.v2 th {
		width: auto;
		vertical-align: middle;
	}
	.comp-tab1.v2 td {
		text-align:left;
		width: auto;
		vertical-align: middle;
	}
	.rec-banner {
		position: relative;
		left: 0px;
		width: 100%
	}
	.rec-banner img {
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
}

/* business----------------------------------------------- */

.business1 {
	display: block;
	padding: 100px 0;
}
.business1 .mt {
	display: block;
	text-align: center;
	font-size: 18px;
	letter-spacing: 3px;
	line-height: 2.1;
}
.business2 {
	display: block;
	background: #EFEFEF;
	padding: 100px 0;
}
.business2 .flx {
	display: flex;
	justify-content: space-between;
	margin-bottom: 120px;
}
.business2 .flx.ri {
	flex-direction: row-reverse;
}
.business2 .flx .txt {
	display: block;
	flex-basis: 55%;
	min-width: 55%;
	background: rgba(255,255,255,0.9);
	position: relative;
	z-index: 10;
	box-sizing: border-box;
	padding: 45px;
	top: 60px;
	border: #666 solid 1px;
}
.title02 {
	display: block;
	position: relative;
	font-size: 26px;
	letter-spacing: 3px;
	line-height: 1.5;
	border-bottom: #fff065 solid 3px;
	padding-bottom: 24px;
	margin-bottom: 30px;
}
.title02::first-letter {
	color: #f4bc0c;
	font-size: 32px;
}
.title02::after {
	position: absolute;
	left: 0;
	bottom: -3px;
	content: "";
	width: 27px;
	height: 3px;
	background: #f4bc0c;
}
.business2 .flx .imgs {
	display: block;
	flex-basis: 50%;
	min-width: 50%;
	position: relative;
	left: -5%;
}
.business2 .flx.ri .imgs {
	left: auto;
	right: -5%;
}
.business2 .flx .imgs img {
	object-fit: cover;
	width: 100%;
	aspect-ratio: 1000 / 667;
}
.business3 {
	display: block;
	padding: 100px 0;
}
.business3 .flx {
	display: flex;
	justify-content: space-between;
}
.business3 .lef {
	flex-basis: 47%;
}
.business3 .lef .txt_01 {
	padding: 35px 0;
}
.business3 .lef .imgs {
	display: block;
	text-align: center;
}
.business3 .lef .imgs img {
	display: inline-block;
	max-width: 300px;
}
.business3 .lef ul {
	display: block;
	background: #EFEFEF;
	padding: 30px 30px 15px 30px;
	counter-reset: number 0; 
}
.business3 .lef ul li {
	display: block;
	position:relative;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.6;
	padding-left: 35px;
	padding-bottom: 17px;
}
.business3 .lef ul li:before {
	position: absolute;
	left: 0;
	top: 0;
	font-size: 25px;
	line-height: 1;
	font-weight: 600;
	color: #f4bc0c;
	font-family: "Lato", sans-serif;
  counter-increment: number 1;      /* number カウンタの増加数をセット */
  content: counter(number,decimal-leading-zero) "";      /* 表示形式を指定 */
}
.top-box3.v2 {
	margin: 0;
	padding: 100px 0;
	background: #EFEFEF;
}
.business4 {
	display: block;
	padding: 100px 0 10px 0;
}
.flows {
	display: block;
	margin-top: 60px;
	counter-reset: number 0; 
}
.flows li {
	display: block;
	position: relative;
}
.flows li::before {
	position: absolute;
	left: 0;
	top: 0;
	color: #f4bc0c;
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	background: #888 ;
	width: 70px;
	height: 70px;
	font-size: 30px;
	font-weight: 600;
	font-family: "Lato", sans-serif;
  counter-increment: number 1;      /* number カウンタの増加数をセット */
  content: counter(number,decimal-leading-zero) "";
}
.flows li .txt {
	display: block;
	padding-left: 100px;
	padding-bottom: 50px;
}
.title04 {
	display: block;
	font-size: 26px;
	letter-spacing: 3px;
	line-height: 1.5;
	padding-bottom: 24px;
	margin-bottom: 24px;
	border-bottom: #333 dotted 1px;
	color: #000;
}
.title04::first-letter {
	color: #f4bc0c;
}

@media all and (max-width: 768px) {
	.business1 {
		display: block;
		padding: 50px 0;
	}
	.business1 .mt {
		display: block;
		text-align:left;
		font-size: 15px;
		letter-spacing: 2px;
		line-height: 2;
	}
	.business2 {
		display: block;
		background: #EFEFEF;
		padding: 40px 0 10px 0;
	}
	.business2 .flx {
		display: block;
		margin-bottom: 50px;
	}
	.business2 .flx .txt {
		display: block;
		flex-basis: 100%;
		min-width: 100%;
		background: rgba(255,255,255,0.9);
		position: relative;
		z-index: 10;
		box-sizing: border-box;
		padding: 20px;
		top: 0px;
		border: #666 solid 1px;
		margin-bottom: 14px;
	}
	.title02 {
		display: block;
		position: relative;
		font-size: 22px;
		letter-spacing: 3px;
		line-height: 1.5;
		border-bottom: #fff065 solid 3px;
		padding-bottom: 14px;
		margin-bottom: 20px;
	}
	.title02::first-letter {
		color: #f4bc0c;
		font-size: 27px;
	}
	.title02::after {
		position: absolute;
		left: 0;
		bottom: -3px;
		content: "";
		width: 22px;
		height: 3px;
		background: #f4bc0c;
	}
	.business2 .flx .imgs {
		display: block;
		flex-basis: 100%;
		min-width: 100%;
		position: relative;
		left: 0%;
	}
	.business2 .flx.ri .imgs {
		left: auto;
		right: 0%;
	}
	.business2 .flx .imgs img {
		object-fit: cover;
		width: 100%;
		aspect-ratio: 1000 / 667;
	}
	.business3 {
		display: block;
		padding: 50px 0 10px 0;
	}
	.business3 .flx {
		display: block;
	}
	.business3 .lef {
		flex-basis: 47%;
		margin-bottom: 40px;
	}
	.business3 .lef .txt_01 {
		padding: 15px 0;
	}
	.business3 .lef .imgs {
		display: block;
		text-align: center;
	}
	.business3 .lef .imgs img {
		display: inline-block;
		max-width: 300px;
	}
	.business3 .lef ul {
		display: block;
		background: #EFEFEF;
		padding: 25px 25px 10px 25px;
		counter-reset: number 0; 
	}
	.business3 .lef ul li {
		display: block;
		position:relative;
		font-size: 15px;
		font-weight: 600;
		line-height: 1.9;
		padding-left: 35px;
		padding-bottom: 17px;
	}
	.business3 .lef ul li:before {
		position: absolute;
		left: 0;
		top: 0;
		font-size: 25px;
		line-height: 1;
		font-weight: 600;
		color: #f4bc0c;
		font-family: "Lato", sans-serif;
	  counter-increment: number 1;      /* number カウンタの増加数をセット */
	  content: counter(number,decimal-leading-zero) "";      /* 表示形式を指定 */
	}
	.top-box3.v2 {
		margin: 0;
		padding: 50px 0;
		background: #EFEFEF;
	}
	.business4 {
		display: block;
		padding: 50px 0 10px 0;
	}
	.flows {
		display: block;
		margin-top: 24px;
		counter-reset: number 0; 
	}
	.flows li {
		display: block;
		position: relative;
	}
	.flows li::before {
		position: absolute;
		left: 0;
		top: 0;
		color: #f4bc0c;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		background: #888 ;
		width: 40px;
		height: 40px;
		font-size: 24px;
		font-weight: 600;
		font-family: "Lato", sans-serif;
	  counter-increment: number 1;      /* number カウンタの増加数をセット */
	  content: counter(number,decimal-leading-zero) "";
	}
	.flows li .txt {
		display: block;
		padding-left: 50px;
		padding-bottom: 35px;
	}
	.title04 {
		display: block;
		font-size: 18px;
		letter-spacing: 2px;
		line-height: 1.5;
		padding-bottom: 14px;
		margin-bottom: 14px;
		border-bottom: #333 dotted 1px;
		color: #000;
	}
	.title04::first-letter {
		color: #f4bc0c;
	}
}



/* works----------------------------------------------- */

.workslists {
	display: block;
	padding: 100px 0 70px 0;
}
.w-cats {
	display: flex;
	flex-wrap: wrap;
}
.w-cats li {
	display: block;
	margin-bottom: 16px;
	margin-right: 24px;
}
.w-cats li a {
	display: block;
	position: relative;
	text-align: center;
	border: #B0AB99 solid 1px;
	color: #000;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 130%; /* 26px */
	letter-spacing: 0.8px;
	padding: 14px 37px;
}
.w-cats li a::after {
	position: absolute;
	right: 10px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	box-sizing: border-box;
	width: 4px;
	height: 4px;
	border: 4px solid transparent;
	border-left: 4px solid #333;
}
.w-cats li.current a {
    border: #B0AB99 solid 1px;
    color: #fff;
    background: #B0AB99;
}
.w-cats li.current a::after {
    border: 4px solid transparent;
    border-left: 4px solid #fff;
}

.workslists2 {
	display: block;
	padding: 100px 0;
	background: #EFEFEF;
}
.workslists2 ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.workslists2 ul li {
	display: block;
	flex-basis: 48%;
	max-width: 48%;
	margin-bottom: 55px;
}
.workslists2 ul li .imgs {
	display: block;
	overflow: hidden;
}
.workslists2 ul li img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 4 / 3;
	transform:scale(1,1);
	transition:1s all;
}
.workslists2 ul li dl {
	display: flex;
	margin-top: 10px;
	position: relative;
}
.workslists2 ul li dl::after {
	position: absolute;
	right: 0px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	box-sizing: border-box;
	width: 9px;
	height: 9px;
	border: 9px solid transparent;
	border-left: 9px solid #333;
}
.workslists2 ul li dl dt {
	display: block;
	white-space: nowrap;
}
.workslists2 ul li dl dt span {
	display: inline-block;
	font-size: 15px;
	padding: 4px 14px;
	margin-right: 10px;
	background: #f4bc0c;
}
.workslists2 ul li dl dd {
	display: block;
	width: 95%;
	font-size: 16px;
	line-height: 1.8;
	margin-right: 35px;
	white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media screen and (min-width:769px) {
	.w-cats li a:hover {
		border: #B0AB99 solid 1px;
		color: #fff;
		background: #B0AB99;
	}
	.w-cats li a:hover::after {
		border: 4px solid transparent;
		border-left: 4px solid #fff;
	}
	.workslists2 ul li a:hover img {
		transform:scale(1.2,1.2);
	}
}

@media screen and (max-width:768px) {
	.workslists {
		display: block;
		padding: 50px 0 30px 0;
	}
	.w-cats {
		display: block;
	}
	.w-cats li {
		display:inline-block;
		margin-bottom: 12px;
		margin-right: 0px;
		text-align: center;
	}
	.w-cats li a {
		display: block;
		position: relative;
		text-align: center;
		border: #B0AB99 solid 1px;
		color: #000;
		font-size: 13px;
		font-style: normal;
		font-weight: 700;
		line-height: 130%; /* 26px */
		letter-spacing: 0.8px;
		padding: 13px 17px 13px 13px;
	}
	.w-cats li a::after {
		position: absolute;
		right: 6px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		box-sizing: border-box;
		width: 4px;
		height: 4px;
		border: 4px solid transparent;
		border-left: 4px solid #333;
	}
	.w-cats li.current a {
		border: #B0AB99 solid 1px;
		color: #fff;
		background: #B0AB99;
	}
	.w-cats li.current a::after {
		border: 4px solid transparent;
		border-left: 4px solid #fff;
	}

	.workslists2 {
		display: block;
		padding: 50px 0;
		background: #EFEFEF;
	}
	.workslists2 ul {
		display: block;
	}
	.workslists2 ul li {
		display: block;
		flex-basis: 48%;
		max-width: 100%;
		margin-bottom: 35px;
	}
	.workslists2 ul li a {
		color: #000;
	}
	.workslists2 ul li .imgs {
		display: block;
		overflow: hidden;
	}
	.workslists2 ul li img {
		width: 100%;
		object-fit: cover;
		aspect-ratio: 4 / 3;
		transform:scale(1,1);
		transition:1s all;
	}
	.workslists2 ul li dl {
		display: flex;
		margin-top: 10px;
		position: relative;
	}
	.workslists2 ul li dl::after {
		position: absolute;
		right: 0px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		box-sizing: border-box;
		width: 9px;
		height: 9px;
		border: 9px solid transparent;
		border-left: 9px solid #333;
	}
	.workslists2 ul li dl dt {
		display: block;
		white-space: nowrap;
	}
	.workslists2 ul li dl dt span {
		display: inline-block;
		font-size: 15px;
		padding: 4px 14px;
		margin-right: 10px;
		background: #f4bc0c;
	}
	.workslists2 ul li dl dd {
		display: block;
		width: 95%;
		font-size: 16px;
		line-height: 1.8;
		margin-right: 35px;
		white-space: nowrap;
	  overflow: hidden;
	  text-overflow: ellipsis;
	}
}



.worksdetail {
	display: block;
	padding: 100px 0 30px 0;
}
.swiperMain {
	margin-bottom: 30px;
}
.swiperMain .swiper-slide {
	height: 400px;
	background: #FFF;
}
.swiperMain img {
	display: block;
	object-fit: contain;
	width: 100%;
	height: 100%;
}
.swiperThumbnail .swiper-wrapper {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.swiperThumbnail .swiper-slide{
	width: 10% !important;
	background: #FFF;
}
.swiperThumbnail .swiper-slide img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}
.swiper-button-next,
.swiper-button-prev {
	color: #333 !important;
}
.detail-txt {
	display: block;
	background: #EFEFEF;
	padding: 40px;
	margin-top: 55px;
}
.detail-txt dl {
	display:flex;
	justify-content: space-between;
	border-bottom: #333 dotted 1px;
	padding: 25px 0;
}
.detail-txt dl dt {
	font-size: 16px;
	font-weight: bold;
	flex-basis: 16%;
}
.detail-txt dl dd {
	display: block;
	flex-basis: 82%;
	font-size: 16px;
	line-height: 2;
}

@media screen and (max-width:768px) {
	.worksdetail {
		display: block;
		padding: 50px 0 30px 0;
	}
	.swiperMain {
		margin-bottom: 24px;
	}
	.swiperMain .swiper-slide {
		height: 230px;
	}
	.swiperMain img {
		display: block;
		object-fit: contain;
		width: 100%;
		height: 100%;
	}
	.swiperThumbnail .swiper-wrapper {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
	}
	.swiperThumbnail .swiper-slide{
		width: 18% !important;
	}
	.swiperThumbnail .swiper-slide img {
		width: 100%;
		aspect-ratio: 1 / 1;
		object-fit: cover;
	}
	.swiper-button-next,
	.swiper-button-prev {
		color: #fff065 !important;
	}
	.detail-txt {
		display: block;
		background: #EFEFEF;
		padding: 20px;
		margin-top: 25px;
	}
	.detail-txt dl {
		display: block;
		border-bottom: #333 dotted 1px;
		padding: 20px 0;
	}
	.detail-txt dl dt {
		font-size: 16px;
		font-weight: bold;
		flex-basis: 16%;
	}
	.detail-txt dl dd {
		display: block;
		flex-basis: 82%;
		font-size: 15px;
		line-height: 2;
		margin-top: 6px;
	}
}


/* pager */
.pager_wrapper {text-align: center; margin: 40px auto 0;}
.pager1 ,.pager2, .pager_wrapper ul {display: inline-block;overflow: hidden;}
.pager_wrapper ul.pager1 li {float: left; width: 30px; margin: 5px;}
.wp-pagenavi {
	text-align: center;
}
.wp-pagenavi a,
.wp-pagenavi span{display: inline-block; width: 30px; margin: 5px;}
#main .blog .pager_wrapper ul.pager1 li{width: 30px; margin: 5px;}
.pager_wrapper ul.pager2 li{float: left; width: 150px; margin: 10px;}
.pager_wrapper ul.pager1 li a,
.pager_wrapper ul.pager2 li a,
.pager_wrapper ul.pager1 span,
.pager_wrapper ul.pager2 span{
	background: #fff065;
	display: block;
	width: 100%;
	color: #333;
	font-size: 1.7rem;
	padding: 5px 0;
	border: 1px solid #333;
	transition: 0.5s;
    font-weight: bold;
    }
.wp-pagenavi a,
.wp-pagenavi span{
	background: #fff065;
	color: #333;
	font-size: 1.7rem;
	padding: 5px 0;
	border: 1px solid #333;
	transition: 0.5s;
    font-weight: bold;
    }
.pager_wrapper ul.pager2 li a,
.pager_wrapper ul.pager2 a,
.pager_wrapper ul.pager2 span{padding: 13px 0;font-size: 1.5rem;}
.pager_wrapper ul.pager1 li a:hover,
.pager_wrapper ul.pager2 li a:hover,
.pager_wrapper a:hover{
    border: 1px solid #f4bc0c;
    background: #f4bc0c;
    color: #333;
    text-decoration: none;
    }
.pager_wrapper ul.pager1 li.active a,
.pager_wrapper ul.pager1 li.active span,
.pager_wrapper ul.pager1 li span{
    border: 1px solid #333;
    background: #fff;
    color: #333;
    text-decoration: none;
    pointer-events: none;
    }
.wp-pagenavi span{
    border: 1px solid #333;
    background: #fff;
    color: #333;
    text-decoration: none;
    pointer-events: none;
    }
#main .subcon .cases_list li h2{
	width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
        }
#main .subcon .cases_list li .name {
	white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#main .subcon .cases_list .date div.time{width: 20%;color: #666;}
#main .subcon .cases_list .date div.name{width: 78%;color: #666;}

@media all and (max-width: 1400px) {}
@media all and (max-width: 1200px) {
    }
@media all and (max-width: 896px) {
    #main .subcon .cases_list li h2{
        font-size: 2.0rem;
        letter-spacing: 0.05em;
        }
    #main .subcon .cases_area article{
        max-width: 90%;
        margin:0 auto 40px;
        }
    #main .subcon .cases_area article h2{
        font-size: 3.0rem;
        padding-bottom: 20px;
        letter-spacing: 0.05em;
        }
    #main .subcon .cases_area article p{
        font-size: 1.5rem;
        letter-spacing: 0.05em;
        line-height: 1.7;
        }
    #main .subcon .cases_area .cases_img{
        margin:15px auto;
        }
    #main .subcon .cases_area article h3{
        font-size: 2.2rem;
        padding: 30px 0 10px;
        }
    }

@media all and (max-width: 540px) {
    #main .subcon .cases_list li{
        width: 90%;
        margin: 5% 5% 10% 5%;
        }
    #main .subcon .cases_list li h2{
        font-size: 2.0rem;
        }
    #main .subcon .cases_list li .date,
    #main .subcon .cases_area .date{ margin: 10px 0 5px;}
    #main .subcon .cases_list li .tag{margin-bottom: 10px;}
    #main .subcon .cases_list li .tag span,
    #main .subcon .cases_area .tag span{
        font-size: 1.2rem;
        padding: 1px 12px;
        line-height: 1.2;
        margin-right: 3px;
        }

    #main .subcon .cases_area article{
        max-width: 90%;
        }
    #main .subcon .cases_area article h2{
        font-size: 2.4rem;
        padding-bottom: 15px;
        }
    #main .subcon .cases_area article p{
        font-size: 1.4rem;
        letter-spacing: 0.05em;
        }
    #main .subcon .cases_area article h3{
        font-size: 1.8rem;
        padding: 30px 0 5px;
        }
    /* pager */
    .pager2 {display:block;width: 100%;}
    .pager_wrapper ul.pager1 li a,
    .pager_wrapper ul.pager2 li a,
    .pager_wrapper ul.pager1 span,
    .pager_wrapper ul.pager2 span{font-size: 1.5rem;}
    .pager_wrapper ul.pager2 li a,
    .pager_wrapper ul.pager2 span{font-size: 1.4rem;}
    .pager_wrapper ul.pager2 li{float: left; width: 31%; margin: 1%;}

    }




/*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;
		background: #f4bc0c;
		border:#f4bc0c solid 1px;
		color: #FFF;
		font-size: 12px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi a.page {
		color: #464646;
		text-align: center;
		border:#fff solid 1px;
		background: #FFF;
		font-size: 12px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		display: none;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 35px;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 35px;
	}
	.wp-pagenavi a:hover {
		background: #FFF;
		color: #000;
		border:#f4bc0c solid 1px;
	}
	.wp-pagenavi span {
		background: #fff;
		color: #f4bc0c;
	}
}
@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 !important;
		justify-content: center !important;
		text-align: center !important;
		align-items:center !important;
		width: 45px !important;
		height: 45px !important;
		background: #f4bc0c;
		border:#f4bc0c solid 1px;
		color: #FFF;
		font-size: 17px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi a.page {
		color: #464646;
		text-align: center;
		border:#fff solid 1px;
		background: #FFF;
		font-size: 17px;
		font-style: normal;
		font-weight: 800;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		font-size: 16px;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 35px;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 35px;
	}
	.wp-pagenavi a:hover {
		background: #FFF;
		color: #000;
		border:#f4bc0c solid 1px;
	}
	.wp-pagenavi span {
		background: #FFF;
		color: #000;
	}
	
	
}






/* 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;
}
.cmt {
	display: block;
	text-align: center;
	margin-bottom: 40px;
}
.c-tops .boxs {
	display: block;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	background: #FFF;
	box-sizing: border-box;
	padding: 40px 60px 60px 60px;
	text-align: center;
}
.cmt2 {
	display: block;
	text-align: center;
	padding: 15px 0;
}
.c-tops .boxs b,
.c-tops .boxs a {
	display: block;
	position: relative;
	font-size: 35px;
	font-weight: 600;
	font-family: "Lato", sans-serif;
	color: #e2ad06;
	line-height: 1;
	letter-spacing: 3px;
}
.c-tops .boxs small {
	display: block;
	padding-top: 10px;
	font-size: 17px;
	font-weight: 600;
}
.tels.sub {
	margin-top: 20px;
}
.c-tops .boxs .tels.sub b,
.c-tops .boxs .tels.sub a {
	display: block;
	position: relative;
	font-size: 25px;
	font-weight: 600;
	font-family: "Lato", sans-serif;
	color: #000;
	line-height: 1;
	letter-spacing: 3px;
	margin-top: 8px;
}
.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;
}
.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;
	}
	.cmt {
		display: block;
		text-align: left;
		margin-bottom: 24px;
	}
	.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;
		line-height: 1;
		letter-spacing: 3px;
	}
	.c-tops .boxs small {
		display: block;
		padding-top: 10px;
		font-size: 14px;
		font-weight: 600;
	}
	.c-tops .boxs .tels.sub b,
	.c-tops .boxs .tels.sub a {
		display: block;
		position: relative;
		font-size: 17px;
		font-weight: 600;
		font-family: "Lato", sans-serif;
		color: #000;
		line-height: 1;
		letter-spacing: 3px;
		margin-top: 8px;
	}
	.c-cont {
		padding: 50px 0;
	}
	.title03 {
		display: block;
		font-size: 20px;
		letter-spacing: 2px;
		line-height: 1.5;
		background:#EFEFEF;
		padding: 12px 15px;
		margin-bottom: 24px;
	}
}


/* 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: #333;
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 26px; /* 130% */
	letter-spacing: 1.6px;
	padding: 20px;
	background: #F0EAD6;
}
.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;
}
.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;
}
.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;
}
::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: #e2ad06;
  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: #e2ad06 solid 1px;
	color: #333;
	cursor: pointer;
	font-size: 17px;
	background: #e2ad06;
	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: #888;
}
input[type="submit"] {
  -webkit-appearance: none;
}
.addf {
	margin-top: 14px;
}
@media all and (min-width: 769px) {
	.sbt:hover {
		background: #333;
		color: #fff;
	}
}

@media all and (max-width: 768px) {
}


/* 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;
}


.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: #e2ad06;
  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 #c82b16;
  border-bottom: 3px solid #c82b16;
  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: 10px;
		padding-bottom: 50px;
	}
	.form-wraps {
		margin-left: auto;
		margin-right: auto;
		max-width: 1000px;
		padding: 15px 0;
		margin-top: 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;
	}
	.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: 20px;
		padding-top: 6px;
	}
	.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;
	}
	::placeholder {
		font-size: 14px !important;
	}
	.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 span {
		padding: 0 !important;
		margin: 0 !important;
		line-height: 1 !important;
	}
	.blocks-label label {
		display: block;
		width: auto !important;
		margin-bottom: 0px !important;
		padding-bottom: 2px !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;
	max-width: 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 !important;
}
.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 .flx {
	display: flex;
	justify-content: space-between;
}
.recruit1 .flx .txt {
	display: block;
	flex-basis: 62%;
}
.recruit1 .flx .imgs {
	flex-basis: 35%;
}
.icolist {
	display: flex;
	justify-content: space-between;
	position: relative;
	margin-left: 7%;
	margin-right: 7%;
	top: -35px;
	z-index: 5;
}
.icolist li {
	display:flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	flex-basis: 30%;
	aspect-ratio: 1 / 1;
	margin-left: 1%;
	margin-right: 1%;
	background: #fff065;
	font-weight: bold;
}
.icolist li p {
	font-size: 22px;
	font-weight: 900 !important;
	letter-spacing: 3px;
	line-height: 1.5;
}
.title05 {
	display: block;
	text-align: center;
	font-size: 30px;
	letter-spacing: 3px;
	line-height: 1.6;
	font-weight: 600;
	margin-top: 70px;
}
.reclist2 {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	padding-top: 35px;
}
.reclist2 li {
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	width: 18%;
	aspect-ratio: 1 / 1;
	margin-left: 1%;
	margin-right: 1%;
	margin-bottom: 35px;
	background: #fff065;
	font-size: 18px;
	letter-spacing: 2px;
	line-height: 1.6;
	font-weight: 600;
}
.reclist2 li:nth-child(1) {
	background: #fff065 url("../images/recruit/sico1.png") center center no-repeat;
	background-size: 75% auto;
}
.reclist2 li:nth-child(2) {
	background: #fff065 url("../images/recruit/sico2.png") center center no-repeat;
	background-size: 75% auto;
}
.reclist2 li:nth-child(3) {
	background: #fff065 url("../images/recruit/sico3.png") center center no-repeat;
	background-size: 75% auto;
}
.reclist2 li:nth-child(4) {
	background: #fff065 url("../images/recruit/sico4.png") center center no-repeat;
	background-size: 75% auto;
}
.reclist2 li:nth-child(5) {
	background: #fff065 url("../images/recruit/sico5.png") center center no-repeat;
	background-size: 75% auto;
}
.recruit2 {
	padding: 100px 0;
	background: #EFEFEF;
}
.flows2 {
	display: flex;
	margin-top: 50px;
}
.flows2 .one {
	display: block;
	flex-basis: 28%;
	margin-left: 5%;
	box-sizing: border-box;
	background: #FFF;
	position: relative;
}
.flows2 .one::before {
	position: absolute;
	left: -35px;
	top: 0;
	bottom: 0;
	content: "";
	margin:auto;
	box-sizing: border-box;
	width: 14px;
	height: 14px;
	border: 14px solid transparent;
	border-left: 14px solid #333;
}
.flows2 .one:nth-child(1) {
	margin-left: 0;
}
.flows2 .one:nth-child(1)::before {
	display: none;
}
.flows2 .one h3 {
	display: block;
	background: #f4bc0c;
	padding: 10px 23px;
	font-size: 25px;
	line-height: 1.5;
}
.flows2 .one h3 small {
	font-size: 18px;
	margin-right: 10px;
}
.flows2 .one b {
	display: block;
	padding: 15px;
	font-size: 16px;
}
.flows2 .one .txt_01 {
	display: block;
	font-size: 15px;
	line-height: 1.9;
	padding: 0px 15px 15px 15px;
}
.bo-bottom {
	border-bottom: #333 dotted 1px;
}
.recbt {
	margin-top: 40px;
	margin-left: auto;
	margin-right: auto;
	max-width: 400px;
}
.mb50 {
	margin-bottom: 90px !important;
}
@media all and (max-width:768px) {
	.recruit1 {
		display: block;
		padding: 50px 0;
	}
	.recruit1 .flx {
		display: block;
	}
	.recruit1 .flx .txt {
		display: block;
		flex-basis: 62%;
		margin-bottom: 24px;
	}
	.recruit1 .flx .imgs {
		flex-basis: 35%;
	}
	.icolist {
		display: flex;
		justify-content: space-between;
		position: relative;
		margin-left: 2%;
		margin-right: 2%;
		top: -35px;
		z-index: 5;
	}
	.icolist li {
		display:flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		flex-basis: 30%;
		aspect-ratio: 1 / 1;
		margin-left: 1%;
		margin-right: 1%;
		font-weight: bold;
	}
	.icolist li p {
		font-size: 18px;
		font-weight: 900 !important;
		letter-spacing: 3px;
		line-height: 1.5;
	}
	.title05 {
		display: block;
		text-align: center;
		font-size: 20px;
		letter-spacing: 3px;
		line-height: 1.6;
		font-weight: 600;
		margin-top: 30px;
	}
	.reclist2 {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		padding-top: 35px;
	}
	.reclist2 li {
		display: flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		width: 48%;
		aspect-ratio: 1 / 1;
		margin-left: 1%;
		margin-right: 1%;
		margin-bottom: 8px;
		font-size: 15px;
		letter-spacing: 2px;
		line-height: 1.6;
		font-weight: 600;
	}
	.recruit2 {
		padding: 50px 0;
		background: #EFEFEF;
	}
	.flows2 {
		display: block;
		margin-top: 20px;
	}
	.flows2 .one {
		display: block;
		flex-basis: 28%;
		margin-left: 0%;
		margin-bottom: 35px;
		box-sizing: border-box;
		background: #FFF;
		position: relative;
	}
	.flows2 .one::before {
		position: absolute;
		left: 0;
		right: 0;
		top: -25px;
		bottom: auto;
		content: "";
		margin:auto;
		box-sizing: border-box;
		width: 14px;
		height: 14px;
		border: 14px solid transparent;
		border-top: 14px solid #333;
	}
	.flows2 .one:nth-child(1) {
		margin-left: 0;
	}
	.flows2 .one:nth-child(1)::before {
		display: none;
	}
	.flows2 .one h3 {
		display: block;
		background: #f4bc0c;
		padding: 10px 23px;
		font-size: 25px;
		line-height: 1.5;
	}
	.flows2 .one h3 small {
		font-size: 18px;
		margin-right: 10px;
	}
	.flows2 .one b {
		display: block;
		padding: 15px;
		font-size: 16px;
	}
	.flows2 .one .txt_01 {
		display: block;
		font-size: 15px;
		line-height: 1.9;
		padding: 0px 15px 15px 15px;
	}
	.bo-bottom {
		border-bottom: #333 dotted 1px;
	}
	.recbt {
		margin-top: 40px;
		margin-left: auto;
		margin-right: auto;
		max-width: 400px;
	}
	.mb50 {
		margin-bottom: 90px !important;
	}
}




.recruit-bnrs {
	display: block;
	position: relative;
}
.recruit-bnrs::after {
	position: absolute;
	left: 0;
	bottom: 0;
	content: "";
	width: 100%;
	height: calc(100% - 60px);
	background: #F4BC0C;
}
.recruit-bnrs .flx {
	display: flex;
	position: relative;
	z-index: 10;
	padding: 130px 0 30px 40px;
}
.recruit-bnrs .flx .lef {
	display: block;
	flex-basis: 65%;
}
.recruit-bnrs .tit {
	display: flex;
	align-items: center;
	left: -35px;
	top: 0;
	position: absolute;
	z-index: 20;
}
.recruit-bnrs .tit .osw {
	display: block;
}
.recruit-bnrs .tit .osw {
	display: block;
	opacity: 0.6;
	color: #FFF065;
	font-size: 128px;
	font-style:italic;
	font-weight: 700;
	line-height: 0.8;
	letter-spacing: 5.12px;
	text-transform: uppercase;
	margin-right: 40px;
}
.recruit-bnrs .tit .osw::first-letter {
	color: #FF8989;
}
.recruit-bnrs .tit h2 {
	display: block;
	color: #000;
	font-size: 48px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: 1.92px;
}
.recruit-bnrs .imgs {
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 5;
}
.txt-fl {
	display: flex;
}
.txt-fl .mti {
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	min-width: 135px;
	width: 135px;
	height: 135px;
	border-radius: 50%;
	background: #dedcd4;
	margin-right: 25px;
}
.txt-fl .mti b {
	display: block;
	text-align: left;
	color: #000;
	font-size: 24px;
	font-style: normal;
	font-weight: 700;
	line-height: 115%; /* 27.6px */
	letter-spacing: 0.96px;
	text-transform: uppercase;
}
.txt-fl .ri {
	display: block;
	flex-basis: 100%;
	padding-top: 13px;
}
.txt-fl .txt_01 {
	color: #000;
	display: block;
	font-size: 20px;
	font-style: normal;
	font-weight: 700;
	line-height: 180%; /* 36px */
	letter-spacing: 0.8px;
}
.bt-r {
	display: block;
	text-align: right;
	padding-top: 12px;
}
.bt-r span {
	display: inline-block;
	position: relative;
	color: #000;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 180%; /* 28.8px */
	letter-spacing: 0.64px;
	padding-right: 35px;
}
.bt-r span::after {
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	background: url("../images/exps.png") center center no-repeat;
	width: 26px;
	height: 26px;
	border-radius: 50%;
}
@media all and (min-width:769px) and (max-width:1100px) {
	.recruit-bnrs .flx .lef {
		display: block;
		flex-basis: 60%;
	}
	.txt-fl .txt_01 {
		color: #000;
		display: block;
		font-size: 17px;
		font-style: normal;
		font-weight: 700;
		line-height: 180%; /* 36px */
		letter-spacing: 0.8px;
	}
	.ep-none {
		display: none;
	}
	.recruit-bnrs .imgs {
		position: absolute;
		right: 0;
		bottom: 0;
		z-index: 5;
		width: 30%;
	}
}
@media all and (min-width:769px) and (max-width:950px) {
	.recruit-bnrs .tit {
		top: 20px;
	}
	.recruit-bnrs .tit .osw {
		display: block;
		opacity: 0.6;
		color: #FFF065;
		font-size: 78px;
		font-style:italic;
		font-weight: 700;
		line-height: 0.8;
		letter-spacing: 5.12px;
		text-transform: uppercase;
		margin-right: 40px;
	}
	.recruit-bnrs .tit .osw::first-letter {
		color: #FF8989;
	}
	.recruit-bnrs .tit h2 {
		display: block;
		color: #000;
		font-size: 30px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: 1.92px;
	}
}
@media all and (min-width:769px) {
	.recruit-bnrs:hover {
		opacity: 0.7;
	}
}

@media all and (max-width:768px) {
	.recruit-bnrs {
		display: block;
		position: relative;
		padding-bottom: 230px;
	}
	.recruit-bnrs::after {
		position: absolute;
		left: 0;
		bottom: 0;
		content: "";
		width: 100%;
		height: calc(100% - 30px);
		background: #F4BC0C;
	}
	.recruit-bnrs .flx {
		display: block;
		position: relative;
		z-index: 10;
		padding: 130px 20px 20px 20px;
	}
	.recruit-bnrs .flx .lef {
		display: block;
		flex-basis: 65%;
	}
	.recruit-bnrs .tit {
		display: block;
		left: 0px;
		top: 0;
		position: absolute;
		z-index: 20;
	}
	.recruit-bnrs .tit .osw {
		display: block;
	}
	.recruit-bnrs .tit .osw {
		display: block;
		opacity: 0.6;
		color: #FFF065;
		font-size: 68px;
		font-style:italic;
		font-weight: 700;
		line-height: 0.8;
		letter-spacing: 5.12px;
		text-transform: uppercase;
		margin-right: 0px;
	}
	.recruit-bnrs .tit .osw::first-letter {
		color: #FF8989;
	}
	.recruit-bnrs .tit h2 {
		display: block;
		color: #000;
		font-size: 28px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: 1.92px;
		margin-top: 13px;
	}
	.recruit-bnrs .imgs {
		position: absolute;
		right: 0;
		bottom: 0;
		z-index: 5;
		width: 100%;
		text-align: center;
	}
	.recruit-bnrs .imgs img {
		display: inline-block;
		max-width: 270px;
	}
	.txt-fl {
		display: block;
	}
	.txt-fl .mti {
		display: block;
		text-align: center;
		min-width: 100%;
		width: 100%;
		height: auto;
		border-radius: 5px;
		background: #dedcd4;
		margin-right: 0px;
		padding: 13px 0;
	}
	.txt-fl .mti b {
		display: block;
		text-align: center;
		color: #000;
		font-size: 24px;
		font-style: normal;
		font-weight: 700;
		line-height: 115%; /* 27.6px */
		letter-spacing: 0.96px;
		text-transform: uppercase;
	}
	.txt-fl .mti b br {
		display: none;
	}
	.txt-fl .ri {
		display: block;
		flex-basis: 100%;
		padding-top: 13px;
	}
	.txt-fl .txt_01 {
		color: #000;
		display: block;
		font-size: 16px;
		font-style: normal;
		font-weight: 700;
		line-height: 2; /* 36px */
		letter-spacing: 0.8px;
	}
	.bt-r {
		display: block;
		text-align: right;
		padding-top: 12px;
	}
	.bt-r span {
		display: inline-block;
		position: relative;
		color: #000;
		font-size: 16px;
		font-style: normal;
		font-weight: 700;
		line-height: 180%; /* 28.8px */
		letter-spacing: 0.64px;
		padding-right: 35px;
	}
	.bt-r span::after {
		position: absolute;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		background: url("../images/exps.png") center center no-repeat;
		width: 26px;
		height: 26px;
		border-radius: 50%;
	}
	.ep-none {
		display: none;
	}
}
.nones {
	display: none !important;
}
.top-box3 p.yr-wrp {
	margin-top: 20px;
	color: #000;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 1.9; /* 20.8px */
	letter-spacing: 0.64px;
	overflow: hidden;
 display: block !important;
  -webkit-box-orient: horizontal;
  -webkit-line-clamp: 2; /* 行数を指定 */
}
