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

#gHeader {
}
.sub-mainVisual {
	display: block;
	padding-top: 100px;
	padding-bottom: 0px;
	overflow: hidden;
	box-sizing: border-box;
	height: 500px;
	margin-left: 30px;
	margin-right: 30px;
	position: relative;
}
.sub-mainVisual .fix-1240 {
	position: relative;
	z-index: 10;
}
.sub-mainVisual .txt {
	display: block;
	position: absolute;
	bottom: 0;
	z-index: 10;
	background: #FFF;
	width: 500px;
	box-sizing: border-box;
	padding: 50px 30px 30px 30px;
}
.sub-mainVisual .txt h1 {
	color: #222;
	font-size: 50px;
	font-style: normal;
	font-weight: 500;
	line-height: 0.8; /* 65px */
	letter-spacing: 2px;
	margin-bottom: 15px;
}
.sub-mainVisual .engs {
	display: block;
	color: #C1CAE3;
	font-size: 40px;
	font-style: normal;
	font-weight: 900;
	line-height: 130%; /* 52px */
}
.sub-mainVisual .imgs {
	display: block;
	position:absolute;
	left: 0;
	top: 100px;
	width: 100%;
	height: calc(100% - 100px);
}
.sub-mainVisual .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media all and (max-width: 768px) {
	.sub-mainVisual {
		display: block;
		padding-top: 55px;
		padding-bottom: 0px;
		overflow: hidden;
		box-sizing: border-box;
		height: 250px;
		margin-left: 4%;
		margin-right: 4%;
		position: relative;
	}
	.sub-mainVisual .txt {
		display: block;
		position: absolute;
		bottom: 0;
		z-index: 10;
		background: #FFF;
		width: 75%;
		box-sizing: border-box;
		padding: 20px 15px 20px 15px;
	}
	.sub-mainVisual .txt h1 {
		color: #222;
		font-size: 24px;
		font-style: normal;
		font-weight: 500;
		line-height: 0.8; /* 65px */
		letter-spacing: 2px;
		margin-bottom: 10px;
	}
	.sub-mainVisual .engs {
		display: block;
		color: #C1CAE3;
		font-size: 18px;
		font-style: normal;
		font-weight: 900;
		line-height: 1; /* 52px */
	}
	.sub-mainVisual .imgs {
		display: block;
		position:absolute;
		left: 0;
		top: 55px;
		width: 100%;
		height: calc(100% - 55px);
	}
	.sub-mainVisual .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}




.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: #222;
}
.subpage-contents p {
	color: #222;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 220%; /* 35.2px */
	letter-spacing: 0.8px;
}
.business1 {
	display: block;
	position: relative;
	background: #F3F3F3;
	margin-top: 100px;
}
.business1 .inner1 {
	position: relative;
	z-index: 10;
}

.business1 .inner1.ri {
	z-index: 20;
}
.business1 .fix-1240 {
	position: relative;
	padding-top: 90px;
}
.business1 .fix-1240::after {
	position: absolute;
	left: -1500px;
	top: 0;
	content: "";
	width: 1500px;
	height: 100%;
	background: #FFF;
}
.business1 .flx {
	display: flex;
}
.business1 .inner1.ri .flx {
	flex-direction: row-reverse;
}
.business1 .txt {
	display: block;
	flex-basis: 58%;
}
.tibox1.sub::before {
	position: absolute;
	left: -6px;
	top: -90px;
	content: "";
	width: 1px;
	height: 90%;
	background: #D9D9D9;
	z-index: -1;
}
.tibox1.sub h2 {
	font-family: "Noto Serif JP";
	font-size: 38px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 49.4px */
	letter-spacing: 1.52px;
	padding-bottom: 5px;
}
.tibox1.sub .engs {
	font-size: 75px;
	font-style: normal;
	font-weight: 900;
	color: #D9D9D9;
	padding-top: 1px;
	line-height: 0.9; /* 97.5px */
}
.business1 .imgs {
	position: absolute;
	right: 0;
	top:90px;
	height: calc(100% - 90px);
	width: 38%;
}
.business1 .ri .imgs {
	position: absolute;
	right: auto;
	left: 0;
}
.business1 .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.business1 .btbox {
	display: block;
	position: relative;
}
.business1 .btbox::after {
	position: absolute;
	left: 0;
	bottom: 85px;
	content: "";
	width: 100%;
	height: 1px;
	background: #D9D9D9;
	z-index: 10;
}
.business1 .btbox .fix-1240 {
	padding-top: 55px;
	padding-bottom: 85px;
}
.bt-b1 {
	display:flex;
	align-items: center;
	margin-left: auto;
	margin-right: auto;
	width: 330px;
	height: 80px;
	box-sizing: border-box;
	padding: 0 35px;
	background: #0F158D;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 23.4px */
}
.bt-b1 span {
	display: block;
	position: relative;
	color: #fff;
	width: 100%;
}
.bt-b1 span::after {
	position: absolute;
	right: -6px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	background:url("../images/arrow-w.png") center center no-repeat;
	background-size: 30px auto;
	width: 42px;
	height: 40px;
}
.business2 {
	padding: 105px 0 120px 0;
}
.fix-1080 {
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
}
.business2 h2 {
	display: block;
	text-align: center;
	color:#0F158D;
	font-size: 44px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%; /* 66px */
	letter-spacing: 1.76px;
	margin-bottom: 80px;
}
.business2 .flx {
	display: flex;
	justify-content: space-between;
	margin-bottom: 50px;
}
.business2 .txt {
	display: block;
	flex-basis: 55%;
}
.business2 .imgs {
	display: block;
	flex-basis: 40%;
}
.business2 .imgs img {
	width: 100%;
}
.business2 .lists1 {
	display: block;
	padding: 30px 40px;
	background: #F3F3F3;
	margin-bottom: 30px;
}
.business2 .lists1 h3 {
	display: block;
	color: #0F158D;
	font-size: 24px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 31.2px */
	letter-spacing: 1.2px;
	margin-bottom: 30px;
}
.business2 .lists1 p {
	display: block;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 180%; /* 28.8px */
	letter-spacing: 0.8px;
}

@media all and (min-width: 769px) {
	.bt-b1:hover {
		background: #222;
		opacity: 1;
	}
}
@media all and (max-width: 1079px) {
	.fix-1080 {
		margin-left: 4%;
		margin-right: 4%;
	}
}

@media all and (max-width: 1000px) {
	.tibox1.sub h2 {
		font-size: 28px;
		line-height: 130%; /* 49.4px */
		letter-spacing: 1.52px;
		padding-bottom: 5px;
	}
	.tibox1.sub .engs {
		font-size: 45px;
		padding-top: 4px;
		line-height: 1.1; /* 97.5px */
	}
}

@media all and (max-width: 768px) {
	.subpage-contents p {
		font-size: 15px;
		line-height: 2; /* 28.8px */
		letter-spacing: 1.6px;
	}
	.business1 {
		display: block;
		position: relative;
		background: #F3F3F3;
		margin-top: 0px;
	}
	.business1 .inner1 {
		position: relative;
		z-index: 10;
	}

	.business1 .inner1.ri {
		z-index: 20;
	}
	.business1 .fix-1240 {
		position: relative;
		padding-top: 45px;
	}
	.business1 .fix-1240::after {
		display: none;
	}
	.business1 .flx {
		display: block;
	}
	.business1 .txt {
		display: block;
		flex-basis: 58%;
		margin-bottom: 24px;
	}
	.tibox1.sub::before {
		display: none;
	}
	.tibox1.sub h2 {
		font-family: "Noto Serif JP";
		font-size: 22px;
		font-style: normal;
		font-weight: 500;
		line-height: 130%; /* 49.4px */
		letter-spacing: 1.52px;
		padding-bottom: 5px;
	}
	.tibox1.sub .engs {
		font-size: 19px;
		font-style: normal;
		font-weight: 900;
		color: #D9D9D9;
		padding-top: 4px;
		line-height: 0.9; /* 97.5px */
	}
	.business1 .imgs {
		position:relative;
		right: 4%;
		left: 4%;
		top:0px;
		height: auto;
		width: 92%;
	}
	.business1 .ri .imgs {
		position:relative;
		right: 4%;
		left: 4%;
	}
	.business1 .imgs img {
		width: 100%;
		height: auto;
		object-fit: cover;
	}
	.business1 .btbox {
		display: block;
		position: relative;
	}
	.business1 .btbox::after {
		display: none;
	}
	.business1 .btbox .fix-1240 {
		padding-top: 30px;
		padding-bottom: 45px;
	}
	.bt-b1 {
		display:flex;
		align-items: center;
		margin-left: auto;
		margin-right: auto;
		width: 250px;
		height: 70px;
		box-sizing: border-box;
		padding: 0 35px;
		background: #0F158D;
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 130%; /* 23.4px */
	}
	.bt-b1 span {
		display: block;
		position: relative;
		color: #fff;
		width: 100%;
	}
	.bt-b1 span::after {
		position: absolute;
		right: -6px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		background:url("../images/arrow-w.png") center center no-repeat;
		background-size: 30px auto;
		width: 42px;
		height: 40px;
	}
	.business2 {
		padding: 45px 0 45px 0;
	}
	.fix-1080 {
		margin-left: 4%;
		margin-right: 4%;
	}
	.business2 h2 {
		display: block;
		text-align: center;
		color:#0F158D;
		font-size: 23px;
		font-style: normal;
		font-weight: 500;
		line-height: 150%; /* 66px */
		letter-spacing: 1.76px;
		margin-bottom: 30px;
	}
	.business2 .flx {
		display: block;
		margin-bottom: 40px;
	}
	.business2 .txt {
		display: block;
		flex-basis: 55%;
		margin-bottom: 24px;
	}
	.business2 .imgs {
		display: block;
		flex-basis: 40%;
	}
	.business2 .imgs img {
		width: 100%;
	}
	.business2 .lists1 {
		display: block;
		padding: 20px 20px;
		background: #F3F3F3;
		margin-bottom: 20px;
	}
	.business2 .lists1 h3 {
		display: block;
		color: #0F158D;
		font-size: 18px;
		font-style: normal;
		font-weight: 500;
		line-height: 130%; /* 31.2px */
		letter-spacing: 1.2px;
		margin-bottom: 15px;
	}
	.business2 .lists1 p {
		display: block;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 28.8px */
		letter-spacing: 0.8px;
	}
}





/* works----------------------------------------------- */
.works1 {
	display: block;
	padding: 160px 0;
}
.works1 .boxs {
	display: block;
	border-bottom: #D9D9D9 solid 2px;
	padding: 55px 0 0 0;
}
.works1 .boxs .fix-1200 {
	position: relative;
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
	padding-bottom: 55px;
}
.works1 .boxs .fix-1200::after {
	position: absolute;
	right: 46%;
	top: 0;
	width: 2px;
	height: 100%;
	background: #D9D9D9;
	content: "";
}
.works1 .boxs .fix-1200.noimgs::after {
	right: 100%;
}
.works1 .boxs .txt {
	display: block;
	flex-basis: 46%;
}
.works1 .boxs .fix-1200.noimgs .txt {
	flex-basis: 100%;
}
.works1 .boxs .title-box {
	display: flex;
	flex-wrap: wrap;
	border-left: #0F158D solid 6px;
	padding-left: 20px;
	margin-bottom: 45px;
}
.works1 .boxs .title-box .days {
	display: block;
	color: #0F158D;
	font-size: 15px;
	font-style: normal;
	font-weight: 900;
	line-height: 130%; /* 23.4px */
	letter-spacing: 1.8px;
	padding-top: 6px;
	padding-right: 40px;
	font-family: "Urbanist", serif !important;
}
.works1 .boxs .title-box .days b {
	font-size: 18px;
	font-weight:900 !important;
}
.works1 .boxs .title-box .cats {
	display: block;
}
.works1 .boxs .title-box .cats span {
	display: inline-block;
	background: #0F158D;
	color: #FFF;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 1; /* 32px */
	letter-spacing: 0.8px;
	padding: 8px 16px;
}
.works1 .boxs .title-box h2 {
	display: block;
	flex-basis: 100%;
	color: #0F158D;
	font-size: 24px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 31.2px */
	letter-spacing: 0.96px;
	margin-top: 20px;
}
.works1 .boxs .txt_01 {
	display: block;
	padding-left: 26px;
}
.works1 .boxs .imgbox {
	display: block;
	flex-basis: 50%;
}
.works1 .boxs .imgbox img {
	width: 100%;
	height: 100%;
	transition-duration: 0.3s;
	object-fit: cover;
}
.works1 .boxs .imgbox .mimg {
	width: 100%;
	height: 360px;
	overflow: hidden;
	margin-bottom: 15px;
}
.works1 .boxs .imgbox ul {
	display: flex;
	flex-wrap: wrap;
}
.works1 .boxs .imgbox ul li {
	display: block;
	overflow: hidden;
	height: 120px;
	margin-left: 15px;
    flex-basis: calc((100% - (15px * 2)) / 3 - .01px);
}
.works1 .boxs .imgbox ul li:nth-child(3n+1) {
	margin-left: 0px;
}
@media all and (min-width: 769px) {
	.works1 .boxs .imgbox img:hover {
		transform: scale(1.1);
		transition-duration: 0.3s;
		opacity: 1;
	}
}



@media all and (max-width: 768px) {
	.works1 {
		display: block;
		padding: 45px 0;
	}
	.works1 .boxs {
		display: block;
		border-bottom: #D9D9D9 solid 2px;
		padding: 30px 0 0 0;
	}
	.works1 .boxs .fix-1200 {
		position: relative;
		display: block;
		padding-bottom: 30px;
	}
	.works1 .boxs .fix-1200::after {
		display: none;
	}
	.works1 .boxs .fix-1200.noimgs::after {
		display: none;
	}
	.works1 .boxs .txt {
		display: block;
		flex-basis: 46%;
		margin-bottom: 23px;
	}
	.works1 .boxs .fix-1200.noimgs .txt {
		flex-basis: 100%;
	}
	.works1 .boxs .title-box {
		display: flex;
		flex-wrap: wrap;
		border-left: #0F158D solid 6px;
		padding-left: 20px;
		margin-bottom: 25px;
	}
	.works1 .boxs .title-box .days {
		display: block;
		color: #0F158D;
		font-size: 15px;
		font-style: normal;
		font-weight: 900;
		line-height: 130%; /* 23.4px */
		letter-spacing: 1.8px;
		padding-top: 6px;
		padding-right: 40px;
	}
	.works1 .boxs .title-box .days b {
		font-size: 18px;
	}
	.works1 .boxs .title-box .cats {
		display: block;
	}
	.works1 .boxs .title-box .cats span {
		display: inline-block;
		background: #0F158D;
		color: #FFF;
		font-size: 16px;
		font-style: normal;
		font-weight: 700;
		line-height: 1; /* 32px */
		letter-spacing: 0.8px;
		padding: 8px 16px;
	}
	.works1 .boxs .title-box h2 {
		display: block;
		flex-basis: 100%;
		color: #0F158D;
		font-size: 17px;
		font-style: normal;
		font-weight: 500;
		line-height: 1.7; /* 31.2px */
		letter-spacing: 0.96px;
		margin-top: 14px;
	}
	.works1 .boxs .txt_01 {
		display: block;
		padding-left: 26px;
	}
	.works1 .boxs .imgbox {
		display: block;
		flex-basis: 50%;
	}
	.works1 .boxs .imgbox img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.works1 .boxs .imgbox .mimg {
		width: 100%;
		height: 230px;
		margin-bottom: 15px;
	}
	.works1 .boxs .imgbox ul {
		display: flex;
		flex-wrap: wrap;
	}
	.works1 .boxs .imgbox ul li {
		display: block;
		height: 80px;
		margin-left: 15px;
		flex-basis: calc((100% - (15px * 2)) / 3 - .01px);
	}
	.works1 .boxs .imgbox ul li:nth-child(3n+1) {
		margin-left: 0px;
	}
}


/* company----------------------------------------------- */
.company1 {
	display: block;
	margin-top: 100px;
	position: relative;
}
.company1 .bg {
	position: relative;
}
.company1 .bg::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	background: url("../images/company/bg1.jpg") top center no-repeat;
	background-size:cover;
	height: 364px;
	width: 100%;
}
.tibox2 {
	display: block;
	position: relative;
	text-align: center;
	z-index: 10;
	padding: 60px 0;
}
.tibox2 h2 {
	font-size: 48px;
	color: #FFF;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 62.4px */
	letter-spacing: 1.92px;
	margin-bottom: 24px;
}
.tibox2 .engs {
	display: block;
	color: #F4F4F4;
	font-size: 96px;
	font-style: normal;
	font-weight: 900;
	line-height: 0.9; /* 124.8px */
	opacity: 0.3;
}
.company1 .inner {
	position: relative;
}
.company1 .inner::after {
	position: absolute;
	right: 0;
	top: 0;
	content: "";
	width: 50%;
	height: 100%;
	background: #FFF;
}
.company1 .inner .fix-1200 {
	position: relative;
	z-index: 10;
	background: #FFF;
}
.company1 .txt {
	display: block;
	box-sizing: border-box;
	padding-top: 70px;
	padding-left: 120px;
	width: 75%;
}
@media all and (min-width: 769px) {
	.company1 .txt.fl100p2 {
		width: 100%;
		padding-right: 120px;
	}
}
.company1 .imgs {
	position: absolute;
	right: 0;
	top: 70px;
	z-index: 10;
	width: 25%;
	height: calc(100% - 70px)
}
.company1 .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.names-right {
	display: block;
	text-align: right;
	font-size: 26px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 33.8px */
	letter-spacing: 1.04px;
	margin-top: 20px;
}
.names-right small {
	font-size: 20px;
	margin-right: 35px;
}
.company2 {
	display: block;
	padding: 110px 0;
}
.title1 {
	display: block;
	color: #0F158D;
	text-align: center;
	font-family: "Noto Serif JP", serif;
	font-size: 44px;
	font-style: normal;
	font-weight: 500;
	line-height: 1.3; /* 66px */
	letter-spacing: 1.76px;
	margin-bottom: 50px;
}
.comp-tab1 {
	display: block;
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
}
.comp-tab1 table {
	width: 100%;
	border-collapse: collapse;
	border-top: #BEBEBE solid 1px;
}
.comp-tab1 table th {
	text-align: left;
	vertical-align:middle;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 20.8px */
	letter-spacing: 0.8px;
	background: #F3F3F3;
	padding: 20px;
	border-bottom: #BEBEBE solid 1px;
	width: 20%;
}
.comp-tab1 table td {
	text-align: left;
	vertical-align: top;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 20.8px */
	letter-spacing: 0.8px;
	padding: 20px;
	border-bottom: #BEBEBE solid 1px;
}
.company3 {
	display: block;
	position: relative;
	background: #0F158D;
	margin-left: 70px;
	margin-right: 70px;
	padding: 70px 0 125px 0;
	overflow: hidden;
}
.company3::before {
	position: absolute;
	left: 0;
	bottom: 125px;
	content: "";
	width: 100%;
	height: 1px;
	background: #FFF;
}
.company3::after {
	position: absolute;
	left: 0;
	bottom: 0;
	content: "";
	background:url("../images/company/history.png") left bottom repeat-x;
	height: 71px;
	width: 100%;
}
.company3 .title1 {
	color: #FFF;
}
.company3 .boxs {
	position: relative;
	max-width: 750px;
	margin-left: auto;
	margin-right: auto;
	padding: 10px 0;
}
.company3 .boxs::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	width: 1px;
	height: 300%;
	background: #FFF;
}
.company3 dl {
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: #FFF;
	padding-left: 30px;
	padding-top: 20px;
	padding-bottom: 20px;
}
.company3 dl dt {
	display: block;
	font-size: 21px;
	font-style: normal;
	font-weight: 900;
	line-height: 130%; /* 27.3px */
	letter-spacing: 1.05px;
	width: 95px;
}
.company3 dl dd {
	display: block;
	flex-basis: 100%;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 20.8px */
	letter-spacing: 0.8px;
}
.company4 {
	padding: 120px 0;
}
.company4 .gmaps {
	margin-right: 70px;
}
.company4 .gmaps iframe {
	width: 100%;
	height: 495px;
}
@media all and (max-width: 768px) {
	.company1 {
		display: block;
		margin-top: 45px;
		position: relative;
	}
	.company1 .bg {
		position: relative;
	}
	.company1 .bg::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		background: url("../images/company/bg1.jpg") top center no-repeat;
		background-size:cover;
		height: 254px;
		width: 100%;
	}
	.tibox2 {
		display: block;
		position: relative;
		text-align: center;
		z-index: 10;
		padding: 30px 0 70px 0;
	}
	.tibox2 h2 {
		font-size: 24px;
		color: #FFF;
		font-style: normal;
		font-weight: 500;
		line-height: 130%; /* 62.4px */
		letter-spacing: 1.92px;
		margin-bottom: 14px;
	}
	.tibox2 .engs {
		display: block;
		color: #F4F4F4;
		font-size: 24px;
		font-style: normal;
		font-weight: 900;
		line-height: 1; /* 124.8px */
		opacity: 0.3;
	}
	.company1 .inner {
		position: relative;
	}
	.company1 .inner::after {
		position: absolute;
		right: 0;
		top: 0;
		content: "";
		width: 100%;
		height: 100%;
		background: #FFF;
	}
	.company1 .inner .fix-1200 {
		position: relative;
		z-index: 10;
		background: #FFF;
	}
	.company1 .txt {
		display: block;
		box-sizing: border-box;
		padding-top: 20px;
		padding-left: 0px;
		padding-right: 0px;
		padding-bottom: 20px;
		width: 100%;
	}
	.company1 .imgs {
		position:relative;
		right: 0;
		top: 0px;
		z-index: 10;
		width: 100%;
		height: 250px
	}
	.company1 .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.names-right {
		display: block;
		text-align: right;
		font-size: 23px;
		font-style: normal;
		font-weight: 500;
		line-height: 130%; /* 33.8px */
		letter-spacing: 1.04px;
		margin-top: 20px;
	}
	.names-right small {
		font-size: 15px;
		margin-right: 25px;
	}
	.company2 {
		display: block;
		padding: 45px 0;
	}
	.title1 {
		display: block;
		color: #0F158D;
		text-align: center;
		font-family: "Noto Serif JP", serif;
		font-size: 24px;
		font-style: normal;
		font-weight: 500;
		line-height: 1.3; /* 66px */
		letter-spacing: 1.76px;
		margin-bottom: 24px;
	}
	.comp-tab1 {
		display: block;
		max-width: 1080px;
		margin-left: auto;
		margin-right: auto;
	}
	.comp-tab1 table {
		width: 100%;
		border-collapse: collapse;
		border-top: #BEBEBE solid 1px;
	}
	.comp-tab1 table th {
		display: block;
		box-sizing: border-box;
		text-align: left;
		vertical-align:middle;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 20.8px */
		letter-spacing: 0.8px;
		background: #F3F3F3;
		padding: 14px;
		border-bottom: #BEBEBE solid 0px;
		width: 100%;
	}
	.comp-tab1 table td {
		display: block;
		text-align: left;
		vertical-align: top;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 20.8px */
		letter-spacing: 0.8px;
		padding: 14px 14px 25px 14px;
		border-bottom: #BEBEBE solid 1px;
	}
	.company3 {
		display: block;
		position: relative;
		background: #0F158D;
		margin-left: 0px;
		margin-right: 0px;
		padding: 20px 20px 20px 20px;
		overflow: hidden;
	}
	.company3::before {
		display: none;
	}
	.company3::after {
		display: none;
	}
	.company3 .title1 {
		color: #FFF;
	}
	.company3 .boxs {
		position: relative;
		max-width: 750px;
		margin-left: auto;
		margin-right: auto;
		padding: 10px 0;
	}
	.company3 .boxs::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		width: 1px;
		height: 300%;
		background: #FFF;
	}
	.company3 dl {
		display: flex;
		justify-content: space-between;
		align-items: center;
		color: #FFF;
		padding-left: 30px;
		padding-top: 20px;
		padding-bottom: 20px;
	}
	.company3 dl dt {
		display: block;
		font-size: 21px;
		font-style: normal;
		font-weight: 900;
		line-height: 130%; /* 27.3px */
		letter-spacing: 1.05px;
		width: 95px;
	}
	.company3 dl dd {
		display: block;
		flex-basis: 100%;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 20.8px */
		letter-spacing: 0.8px;
	}
	.company4 {
		padding: 45px 0;
	}
	.company4 .gmaps {
		margin-right: 0px;
	}
	.company4 .gmaps iframe {
		width: 100%;
		height: 350px;
	}
}


/* recruit----------------------------------------------- */

.recruit1 .bg::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	background:url("../images/recruit/bg.jpg") top center no-repeat;
	background-size:cover;
	height: 364px;
	width: 100%;
}
.pb65 {
	padding-bottom: 65px;
}
.staff1 {
	padding: 100px 0;
}
.staff1 .bg-box {
	background: #F3F3F3;
	padding: 65px 60px;
}
.staff1 .flx {
	display: flex;
	justify-content: space-between;
	padding: 45px 0;
}
.staff1 .flx:nth-of-type(2n) {
	flex-direction: row-reverse;
}
.staff1 .flx .imgs {
	display:block;
	flex-basis: 36%;
}
.staff1 .flx .imgs img {
	width: 100%;
}
.staff1 .flx .txt {
	display: block;
	flex-basis: 60%;
}
.staff1 .flx .txt .names {
	display: block;
	font-size: 28px;
	font-style: normal;
	font-weight: 500;
	line-height: 1.6; /* 61.6px */
	margin-bottom: 15px;
}
.staff1 .flx .txt .names small {
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%; /* 27px */
	letter-spacing: 0.72px;
	margin-left: 40px;
}
.staff1 .flx .txt .txt_01 {
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 180%; /* 32.4px */
	letter-spacing: 0.9px;
}
.faqbox {
	padding-bottom: 30px;
}
.faq-base {
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
}
#faqMenu dt{
	display:block;
	position: relative;
	margin-top: 30px;
	background: #F3F3F3;
	cursor:pointer;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
#faqMenu dt::before {
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 17px;
	height: 4px;
	background: #909090;
}
#faqMenu dt::after {
	position: absolute;
	right: 27px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 4px;
	height: 17px;
	background: #909090;
}
#faqMenu dt.active {
}
#faqMenu dt.active::after {
	display: none;
}
#faqMenu dt span {
	display: block;
	font-size: 24px;
	color: #0F158D;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 31.2px */
	letter-spacing: 1.2px;
	padding: 50px 80px 50px 140px;
}
#faqMenu dt span::before {
	position: absolute;
	left: 30px;
	top: 23px;
	content: "";
	width: 80px;
	height: 80px;
	background: #0F158D url("../images/recruit/quwst.png") center center no-repeat;
	color: #FFF;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: center;
	font-size: 40px;
	font-style: normal;
	font-weight: 900;
	line-height: normal;
	letter-spacing: 14px;
	font-family: "Urbanist", serif !important;
}
#faqMenu dd{
	display:none;
	background: #F3F3F3;
	padding: 5px 35px 35px 140px;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 180%; /* 28.8px */
	letter-spacing: 0.8px;
}
.recruit-tab .btbox2 {
	display: block;
	padding-top: 80px;
	padding-bottom: 60px;
}
.bt-b2 {
	display: flex;
	align-items: center;
	color: #FFF;
	background: #0F158D;
	margin-left: auto;
	margin-right: auto;
	width: 455px;
	height: 80px;
	box-sizing: border-box;
	padding: 18px 35px;
}
.bt-b2 span {
	display: block;
	position: relative;
	width: 100%;
	font-size: 20px;
	color: #FFF;
	font-style: normal;
	font-weight: 500;
	line-height: 130%; /* 26px */
}
.bt-b2 span::after {
	position: absolute;
	right: -12px;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	background: url("../images/recruit/edit_square.png") center center no-repeat;
	width: 42px;
	height: 40px;
}


@media all and (min-width: 769px) {
	#faqMenu dt:hover {
		background:#CBCBCB;
	}
	.bt-b2:hover {
		background: #222;
		opacity: 1;
	}
}
@media all and (max-width: 768px) {
	.recruit1 .bg::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		background:url("../images/recruit/bg.jpg") top center no-repeat;
		background-size:cover;
	}
	.pb65 {
		padding-bottom: 30px;
	}
	.staff1 {
		padding: 45px 0;
	}
	.staff1 .bg-box {
		background: #F3F3F3;
		padding: 15px 0px;
	}
	.staff1 .flx {
		display: block;
		padding: 15px 10px;
	}
	.staff1 .flx:nth-of-type(2n) {
		margin-top: 35px;
	}
	.staff1 .flx .imgs {
		display:block;
		flex-basis: 36%;
		margin-bottom: 14px;
	}
	.staff1 .flx .imgs img {
		width: 100%;
	}
	.staff1 .flx .txt {
		display: block;
		flex-basis: 60%;
	}
	.staff1 .flx .txt .names {
		display: block;
		font-size: 23px;
		font-style: normal;
		font-weight: 500;
		line-height: 1.6; /* 61.6px */
		margin-bottom: 15px;
	}
	.staff1 .flx .txt .names small {
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 150%; /* 27px */
		letter-spacing: 0.72px;
		margin-left: 20px;
	}
	.staff1 .flx .txt .txt_01 {
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 32.4px */
		letter-spacing: 0.9px;
	}
	.faqbox {
		padding-bottom: 30px;
	}
	.faq-base {
		max-width: 1080px;
		margin-left: auto;
		margin-right: auto;
	}
	#faqMenu dt{
		display:block;
		position: relative;
		margin-top: 20px;
		background: #F3F3F3;
		cursor:pointer;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	#faqMenu dt::before {
		position: absolute;
		right: 20px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 17px;
		height: 4px;
		background: #909090;
	}
	#faqMenu dt::after {
		position: absolute;
		right: 27px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 4px;
		height: 17px;
		background: #909090;
	}
	#faqMenu dt.active {
	}
	#faqMenu dt.active::after {
		display: none;
	}
	#faqMenu dt span {
		display: block;
		font-size: 17px;
		color: #0F158D;
		font-style: normal;
		font-weight: 500;
		line-height: 1.7; /* 31.2px */
		letter-spacing: 1.2px;
		padding: 30px 30px 30px 70px;
	}
	#faqMenu dt span::before {
		position: absolute;
		left: 10px;
		top: 23px;
		content: "";
		width: 48px;
		height: 48px;
		background: #0F158D url("../images/recruit/quwst.png") center center no-repeat;
		color: #FFF;
		border-radius: 50%;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		font-size: 40px;
		font-style: normal;
		font-weight: 900;
		line-height: normal;
		letter-spacing: 14px;
		font-family: "Urbanist", serif !important;
	}
	#faqMenu dd{
		display:none;
		background: #F3F3F3;
		padding: 15px 15px 15px 15px;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 28.8px */
		letter-spacing: 0.8px;
	}
	.recruit-tab .btbox2 {
		display: block;
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.bt-b2 {
		display: flex;
		align-items: center;
		color: #FFF;
		background: #0F158D;
		margin-left: auto;
		margin-right: auto;
		width: 255px;
		height: 70px;
		box-sizing: border-box;
		padding: 18px 35px;
	}
	.bt-b2 span {
		display: block;
		position: relative;
		width: 100%;
		font-size: 14px;
		color: #FFF;
		font-style: normal;
		font-weight: 500;
		line-height: 130%; /* 26px */
	}
	.bt-b2 span::after {
		position: absolute;
		right: -12px;
		top: 0;
		bottom: 0;
		margin: auto;
		content: "";
		background: url("../images/recruit/edit_square.png") center center no-repeat;
		width: 42px;
		height: 40px;
	}
}







/*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: 6px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items:center;
		width: 30px;
		height: 30px;
		background:#0F158D;
		color: #FFF;
		font-size:14px;
		font-style: normal;
		font-weight: 900;
		line-height: 130%; /* 28.6px */
		letter-spacing: 2.2px;
		font-family: "Urbanist", serif;
	}
	.wp-pagenavi a.page {
		color: #fff;
		text-align: center;
		font-family: "Urbanist", serif;;
		background: #0F158D;
		font-size:14px;
		font-style: normal;
		font-weight: 900;
		line-height: 130%; /* 28.6px */
		letter-spacing: 2.2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		overflow: hidden;
		text-indent: -9999px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		width: 30px;
		height: 30px;
		border: none;
		background: url("../images/arrow.png") center center no-repeat;
		background-size: 100% auto;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 35px;
		-webkit-transform: rotate(180deg);
		transform: rotate(180deg);
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 35px;
	}
	.wp-pagenavi span {
		background: #333;
		color: #fff;
	}
	
}
@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;
		font-family: "Urbanist", serif;
	}
	.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: 50px;
		height: 50px;
		background:#0F158D;
		color: #FFF;
		font-size: 22px;
		font-style: normal;
		font-weight: 900;
		line-height: 130%; /* 28.6px */
		letter-spacing: 2.2px;
		font-family: "Urbanist", serif;
	}
	.wp-pagenavi a.page {
		color: #fff;
		text-align: center;
		font-family: "Urbanist", serif;;
		background: #0F158D;
		font-size: 22px;
		font-style: normal;
		font-weight: 900;
		line-height: 130%; /* 28.6px */
		letter-spacing: 2.2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		overflow: hidden;
		text-indent: -9999px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		width: 50px;
		height: 50px;
		border: none;
		background: url("../images/arrow.png") center center no-repeat;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 35px;
		-webkit-transform: rotate(180deg);
		transform: rotate(180deg);
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 35px;
	}
	.wp-pagenavi a:hover {
		background: #333;
		color: #fff;
	}
	.wp-pagenavi span {
		background: #333;
		color: #fff;
	}
	.wp-pagenavi .previouspostslink:hover,
	.wp-pagenavi .nextpostslink:hover {
		background: url("../images/arrow.png") center center no-repeat #FFF;
	}
	
	
}






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

.contact1 .bg::before {
	background: #0F158D ;
}
.cc-top {
	display: block;
	text-align: center;
	padding: 60px 0 170px 0;
}
.cc-top .urb {
	text-align: center;
	font-size: 48px;
	color: #0F158D !important;
	font-style: normal;
	font-weight: 700;
	line-height: 140%; /* 67.2px */
	letter-spacing: 1.92px;
}
.cc-top .urb a {
	color: #0F158D !important;
}
.cc-top .urb small {
	font-size: 38px;
}
.cc-top span {
	display: block;
	margin-top: 7px;
	font-size: 22px;
	font-style: normal;
	font-weight: 500;
	line-height: 140%; /* 30.8px */
	letter-spacing: 1.1px;
}
.c-cont {
	background: #F3F3F3;
	margin-left: 30px;
	margin-right: 30px;
	padding: 70px 0;
	margin-bottom: 150px;
}
.mcont {
	text-align: center;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 180%; /* 32.4px */
	letter-spacing: 0.9px;
	margin-bottom: 45px;
}
.form-wraps {
	background: #FFF;
	max-width: 1150px;
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	padding: 60px 35px 35px 35px;
}
@media all and (max-width: 768px) {
	.cc-top {
		display: block;
		text-align: center;
		padding: 30px 0 40px 0;
	}
	.cc-top .urb {
		text-align: center;
		font-size: 27px;
		color: #0F158D !important;
		font-style: normal;
		font-weight: 700;
		line-height: 140%; /* 67.2px */
		letter-spacing: 1.92px;
	}
	.cc-top .urb a {
		color: #0F158D !important;
	}
	.cc-top .urb small {
		font-size: 17px;
	}
	.cc-top span {
		display: block;
		margin-top: 7px;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 140%; /* 30.8px */
		letter-spacing: 1.1px;
	}
	.c-cont {
		background: #F3F3F3;
		margin-left: 0px;
		margin-right: 0px;
		padding: 30px 0;
		margin-bottom: 40px;
	}
	.mcont {
		text-align:left;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 32.4px */
		letter-spacing: 0.9px;
		margin-bottom: 35px;
	}
	.form-wraps {
		background: #FFF;
		max-width: 1150px;
		box-sizing: border-box;
		margin-left: auto;
		margin-right: auto;
		padding: 20px 15px 25px 15px;
	}
}


/* ----------------------------------------------- */
.forms-base {
	display: block;
	padding-top: 90px;
	margin-left: 4%;
	margin-right: 4%;
	padding-bottom: 90px;
}
.forms-base .title01 {
	margin-bottom: 40px;
}
.form-wraps .txt_01 {
	padding-top: 45px;
	text-align: center;
	margin-bottom: 50px;
}
.forms-table {
	width: 100%;
	max-width: 750px;
	margin-left: auto;
	margin-right: auto;
	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 0;
}
.forms-table th.requier::after {
	margin-left: 25px;
	content: "必須";
	background: #0F158D;
	color: #FFF;
	font-size: 15px;
	font-style: normal;
	font-weight: 500;
	line-height: 27px; /* 150% */
	letter-spacing: 1.8px;
	padding: 4px 11px 6px 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: #F3F3F3;
	border: #F3F3F3 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: #F3F3F3;
	border: #F3F3F3 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: #F3F3F3;
	border: #F3F3F3 solid 1px;
}
::placeholder {
	font-size: 18px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	color:rgba(0, 0, 0, 0.30);
}
.form-in {
	margin-bottom: 10px;
}
.select-over {
	display: block;
	width: 60%;
}
.select-over select {
	width: 100%;
	height: 60px;
	background: #F3F3F3;
	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: #F3F3F3 solid 1px;
}
.select-over select option:nth-child(1) {
	
}
select:invalid {
    color:rgba(0, 0, 0, 0.30) !important;
}
select option:first-child {
    color: rgba(0, 0, 0, 0.30) !important;
}

select:invalid {
    color:rgba(0, 0, 0, 0.30);
}

select option {
    color: #333;
}
.mmcs {
	position: relative;
}
.mmcs::before {
	position: absolute;
	right: 3px;
	top: 0;
	content: "";
	width: 20px;
	height: 100%;
	background: #F3F3F3;
	pointer-events: none;
}
.mmcs::after {
	position: absolute;
	right: 20px;
	top: 5px;
	content: "";
	pointer-events: none;
	box-sizing: border-box;
	width: 10px;
	height: 9px;
	border: 10px solid transparent;
	border-top: 15px solid #0F158D;
	z-index: 2;
}
/* 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: 21px;
  height: 21px;
  border-radius: 50%;
	background: #F3F3F3;
	border: 1px solid #222;
}

input.radioBtn::after {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  background: #0F158D;
  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: 350px;
	height: 70px;
	padding-left: 35px;
	padding-right: 35px;
	border: #0F158D solid 1px;
	color: #FFF;
	cursor: pointer;
	text-align: left;
	font-size: 17px;
	background: #0F158D url("../images/arrow-w.png") right 20px center no-repeat;
	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 {
	text-align: right;
	background: #333 url("../images/arrow-w2.png") left 20px center no-repeat;
}
input[type="submit"] {
  -webkit-appearance: none;
}
.addf {
	margin-top: 14px;
}
@media all and (min-width: 769px) {
	.sbt:hover {
		background: #222 url("../images/arrow-w.png") right 20px center no-repeat;
		color: #fff;
	}
	.sbt.v2:hover {
		background: #0F158D url("../images/arrow-w2.png") left 20px center no-repeat;
		color: #fff;
	}
}


/* privacy__policy */
.privacy__policy--area {
	margin-top: 50px;
  max-width: 750px;
	margin-left: auto;
	margin-right: auto;
	
  
}
.privacy__policy {
  padding: 20px 0px 40px 0px;
}
.privacy__policy .scr {
	height: 220px;
	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: #0F158D;
  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 #0F158D;
  border-bottom: 3px solid #0F158D;
  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 .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: 0px;
		padding-top: 0px;
	}
	.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: 12px;
		letter-spacing: 0;
	}
	.form-in {
		margin-bottom: 10px;
	}
	.select-over {
		display: block;
		width: 100%;
	}
	.select-over select {
		width: 100%;
		height: 55px;
		font-size: 15px;
		letter-spacing: 0px;
		color: #3F3B3A !important;
		padding-left: 20px;
		padding-right: 20px;
	}
	.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;
		cursor: pointer;
		font-size: 15px;
		margin-bottom: 15px;
	}
	.form_consent_txt {
		background: none !important;
		font-size: 14px !important;
	}
	.form_consent_txt span {
		font-size: 14px !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;
	}
	.mw_wp_form_confirm th {
		background: #EFEFEF;
	}
	.mw_wp_form_confirm td,
	.mw_wp_form_confirm td.bl-labs{
		padding: 20px 20px 25px 20px !important;
		font-family: "Noto Sans JP", serif;
		font-size: 15px;
		font-weight: 500;
	}
	td.bl-labs label {
		display: block;
		margin-left: 0 !important;
	}
}

.nones {
	display: none !important;
}



.mw_wp_form_confirm .mmcs::before,
.mw_wp_form_confirm .mmcs::after{
	display: none !important;
}

.company7 {
	padding: 60px 0;
}
.s404bases {
	text-align: center;
}
.s404bases h2 {
	display: block;
	padding: 15px 0;
	text-align: center;
	background: #EFEFEF;
}


.rinen1 {
	background: #FBFBFB;
	margin-top: 90px;
}
.rinenlist {
	display: block;
	max-width: 930px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 60px;
}
.rinenlist h3 {
	display: block;
	color: #2D3540;
	font-size: 20px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	margin-bottom: 19px;
}
.rinenlist span {
	color: #0F158D;
	font-size: 20px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	margin-right: 14px;
}
.rinenlist .txt_03 {
	display: block;
	color: #2D3540;
	font-size: 15px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
	padding-bottom: 50px;
}
@media all and (max-width:768px) {
	.rinen1 {
		background: #FBFBFB;
		margin-top: 40px;
	}
	.rinenlist {
		display: block;
		max-width: 930px;
		margin-left: auto;
		margin-right: auto;
		padding-top: 20px;
	}
	.rinenlist h3 {
		display: block;
		color: #2D3540;
		font-size: 18px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		margin-bottom: 14px;
	}
	.rinenlist span {
		color: #0F158D;
		font-size: 18px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		margin-right: 10px;
	}
	.rinenlist .txt_03 {
		display: block;
		color: #2D3540;
		font-size: 15px;
		font-style: normal;
		font-weight: 600;
		line-height: normal;
		padding-bottom: 30px;
	}
}


.kanren {
	display: block;
	margin-top: 0 !important;
}
.dti {
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	align-items: center;
	border-bottom: #E2E2E2 solid 1px
}
.dti p {
	display: block;
	flex-basis: 210px;
	color: #818181;
	font-size: 15px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
}
.dti table {
	width: 100%;
	border-left: #E2E2E2 solid 1px
}
.dti table td {
	text-align: left;
	vertical-align: middle;
	color: #818181;
	font-size: 15px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
	padding-top: 30px;
	padding-bottom: 30px;
}
.we1 {
	padding-left: 25px;
	padding-right: 25px;
}
.we2 {
	width: 190px;
}
.we3 {
	width: 155px;
}
.dti2 {
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	align-items: center;
	border-bottom: #E2E2E2 solid 1px
}
.dti2 p {
	display: block;
	flex-basis: 210px;
	color: #2D3540;
	font-size: 15px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
}
.dti2 table {
	width: 100%;
	border-left: #E2E2E2 solid 1px
}
.dti2 table td {
	text-align: left;
	vertical-align: middle;
	color: #2D3540;
	font-size: 15px;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
	padding-top: 30px;
	padding-bottom: 30px;
}
.we3 a {
	display: block;
	text-align: center;
	color: #FFF;
	font-size: 14px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	border-radius: 6px;
	background: #0F158D;
	padding: 10px 0;
}
@media all and (min-width:769px) {
	.we3 a:hover {
		background: #333;
	}
}
@media all and (max-width:768px) {
	.we1 {
		padding-left: 25px;
		padding-right: 25px;
	}
	.we2 {
		width: auto;
	}
	.we3 {
		width: auto;
	}
	.dti2 {
		max-width: 1100px;
		margin-left: auto;
		margin-right: auto;
		display: block;
		border: #E2E2E2 solid 1px;
		margin-bottom: 15px;
	}
	.dti2 p {
		display: block;
		flex-basis: 210px;
		color: #2D3540;
		font-size: 15px;
		font-style: normal;
		font-weight: 600;
		line-height: normal;
		background: #EFEFEF;
		padding: 16px;
	}
	.dti2 table {
		width: 100%;
		border-left: #E2E2E2 solid 0px
	}
	.dti2 table td {
		display: block;
		text-align: left;
		vertical-align: middle;
		color: #2D3540;
		font-size: 15px;
		font-style: normal;
		font-weight: 600;
		line-height: normal;
		padding-top: 15px;
		padding-bottom: 15px;
		padding-left: 15px;
		padding-right: 15px;
	}
	.we3 a {
		display: block;
		text-align: center;
		color: #FFF;
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		border-radius: 6px;
		background: #0F158D;
		padding: 10px 0;
	}
}

.bnrs-btn {
	background: none !important;
	padding: 0 !important;
}


.img-list04 {
	display: block;
}
.img-list04 ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.img-list04 li {
	display: block;
	flex-basis: 48%;
	margin-bottom: 35px;
}
.img-list04 li img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}
@media all and (max-width:768px) {
	.img-list04 li {
		display: block;
		flex-basis: 48%;
		margin-bottom: 20px;
	}
}
