.logo02 {
	opacity: 1;
}
.logo01 {
	opacity: 1;
}
#header .navi-item a:hover {
	color: #004898;
	font-weight: 700;
}
#header .navi {
	color: #000;
}
#header {
	border-bottom: solid 1px #000;
	background-color: rgba(255, 255, 255, 1.0);
}
.inner1400 {
	width: 1400px;
	max-width: calc(100% - 40px);
	margin: 0 auto;
}
.inner1200 {
	width: 1200px;
	max-width: calc(100% - 40px);
	margin: 0 auto;
}
.inner1100 {
	width: 1100px;
	max-width: calc(100% - 40px);
	margin: 0 auto;
}
.breadcrumb-container {
	position: relative;
	width: 100%;
	max-width: 100%;
}

.fade-image {
	width: calc(50% + 600px);
	max-width: calc(100% - 100px);
	height: 330px;
	opacity: 0;
	position: relative;
	transition: opacity 1.5s ease, transform 1.5s ease;
	transform: translateY(10px);
	padding-top: 80px;
	margin: 0 0 0 auto;
	z-index: 1;
}
.fade-image img {
	object-fit: cover;
	position: relative;
	width: 100%;
	height: 100%;
}

.fade-image.fadein {
	opacity: 1;
	transform: translateY(0);
}
.subpage_ttl {
	position: absolute;
	color: #fff;
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 75px;
	top: 175px;
	line-height: 1;
	left: 72px;
	letter-spacing: 0.2rem;
}
.subpage_ttl span {
	font-family: "IBM Plex Sans JP", sans-serif;
	font-weight: 700;
	font-size: 20px;
	margin-left: 15px;
}
.subpage_ttl-b {
	position: absolute;
	color: #fff;
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 75px;
	bottom: 60px;
	line-height: 1;
	left: 72px;
	letter-spacing: 0.2rem;
}
.subpage_ttl-b span {
	font-family: "IBM Plex Sans JP", sans-serif;
	font-weight: 700;
	font-size: 20px;
	margin-left: 15px;
}

/* パンくずリスト本体 */
.breadcrumb {
	position: relative;
	overflow: hidden;
	width: 100%;
	box-sizing: border-box;
	margin-top: -50px;
	padding: 50px 0 0 0;
}

.breadcrumb ul {
	position: relative;
	padding: 13px 20px;
	margin: 0 auto;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	z-index: 1;
	max-width: 1000px;
	justify-content: flex-end;
	color: #fff;
	font-size: 14px;
}

.breadcrumb li {
	display: inline;
}

.breadcrumb li::after {
	content: "＞";
	margin-left: 10px;
}

.breadcrumb li:last-child::after {
	content: "";
}

/* 背景アニメーション */
.breadcrumb::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	width: 0%;
	background: #014898;
	z-index: 0;
	transition: width 1s ease;
}

.breadcrumb.show::before {
	width: 100%;
	right: auto;
	left: 0;
}
.content {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 1.5s ease, transform 1.5s ease;
}

.content.fadein {
	opacity: 1;
	transform: translateY(0);
}
.content {
	margin: 0 auto;
	padding: 80px 0;
}

@media screen and (max-width: 1200px) {
	.menu_open-btn-hum span {
		background: #000;
	}
	.fade-image {
		padding-top: 58px;
	}
}
@media screen and (max-width: 769px) {
	.inner1400 {
		width: 1400px;
		max-width: calc(100% - 20px);
		margin: 0 auto;
	}
	.inner1200 {
		width: 1200px;
		max-width: calc(100% - 20px);
		margin: 0 auto;
	}
	.inner1100 {
		width: 1100px;
		max-width: calc(100% - 20px);
		margin: 0 auto;
	}
	.fade-image {
		width: calc(100% - 30px);
		max-width: calc(100% - 30px);
		height: 200px;
		padding-top: 58px;
		margin: 0 0 0 auto;
	}
	.fade-image img {
		object-fit: cover;
		position: relative;
		width: 100%;
		height: 100%;
	}
	.subpage_ttl {
		font-size: 36px;
		top: 105px;
		line-height: 1;
		left: 26px;
	}
	.subpage_ttl span {
		font-size: 12px;
		white-space: nowrap;
		margin: 5px 0 0 0;
	}
	.subpage_ttl-b {
		font-size: 36px;
		top: 105px;
		line-height: 1;
		left: 26px;
	}
	.subpage_ttl-b span {
		font-size: 12px;
		white-space: nowrap;
		margin: 5px 0 0 0;
	}

	/* パンくずリスト本体 */
	.breadcrumb {
		margin-top: -10px;
		padding: 10px 0 0 0;
	}

	.breadcrumb ul {
		padding: 7px 20px;
		font-size: 10px;
	}

	.content.fadein {
		opacity: 1;
		transform: translateY(0);
	}
	.content {
		margin: 0 auto;
		padding: 60px 0;
	}
}
/*　company　*/
#company01 {
	padding: 15px 0 350px;
	width: 1100px;
	max-width: calc(100% - 40px);
	margin: 0 auto;
}
.company_ttl01 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px 80px;
	margin-bottom: 40px;
	max-width: 100%;
}
.company_ttl01 a {
	text-decoration: none;
	font-weight: bold;
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
	font-size: 16px;
	width: 280px;
	position: relative;
}
.company_ttl01 a:before {
	content: "";
	background: #000;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	right: 0;
}
.company_ttl01 a+a:after {
	content: "";
	background: #cccccc;
	width: 80px;
	height: 1px;
	position: absolute;
	bottom: -1px;
	left: -80px;
}
.company01__ttl-box {
	margin-bottom: 20px;
}

.company01__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
}
.company01__ttl01 span {
	color: #014898;
}
.company01__ttl02 {
	font-size: 18px;
}

.company01__flex {
	display: flex;
	flex-wrap: wrap;
	gap: 80px;
	margin: 55px auto;
	max-width: 1000px;
	width: 100%;
	position: relative;
}
.company01 .inner1100 {
	position: relative;
}
.company01 .inner1100:after {
	background: #fff;
	content: "";
	box-shadow: 0px 0px 20px 1px rgba(0, 0, 0, 0.1);
	width: 100vw;
	position: absolute;
	left: 100px;
	top: 20px;
	z-index: -1;
	height: calc(100% + 90px);
}
.company01__img {
	width: 40%;
	text-align: center;
}
.company01__img01 {
	margin-bottom: 10px;
}

.company01__img01 img {
	max-width: 100%;
}

.company01__img-tx01 {
	font-size: 16px;
	text-align: right;
}
.company01__img-tx02 {
	font-size: 26px;
	text-align: right;
}

.company01__content {
	width: calc(60% - 80px);
	font-size: 16px;
	line-height: 2.1;
}


#company02 {
	padding: 250px 0 10px;
	border-radius: 10px;
	position: relative;
	background: rgba(230, 230, 230, 0.6);
}
.company__photo {
	text-align: center;
	margin-bottom: 30px;
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	position: absolute;
	top: 0;
	right: 50%;
	transform: translate(50%, -50%);
}

.company__photo img {
	max-width: 100%;
}
.company__pattern01 {
	position: absolute;
	top: 44px;
	right: -124px;
}
.company__pattern02 {
	position: absolute;
	bottom: 184px;
	left: -195px;
}


.company02__ttl-box {
	text-align: center;
	margin-bottom: 50px;
}
.company02__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
}
.company02__ttl01 span {
	color: #014898;
}
.company02__ttl02 {
	font-size: 18px;
}

.company02__flex {
	width: 1200px;
	max-width: calc(100% - 20px);
	margin: 0 auto;
	display: flex;
	margin-bottom: 40px;
	flex-wrap: wrap;
	background: #014898;
	color: #fff;
}

.company02__img {
	min-width: 200px;
	position: relative;
	width: 35%;
	background: #1556a0;
	padding: 60px 10px 60px 130px;
}

.company02__num {
	position: absolute;
	left: 23px;
	top: 70px;
	text-align: right;
	width: 60px;
}

.company02__img-tx01 {
	font-size: 40px;
	font-weight: bold;
	font-family: "Akshar", sans-serif;
	line-height: 1;
}

.company02__img-tx02 {
	font-size: 20px;
}
.company02__content {
	width: 65%;
	font-size: 30px;
	padding: 50px 30px 50px 80px;
}
.company02__declaration {
	width: 1000px;
	max-width: calc(100% - 40px);
	margin: 110px auto;
}
.company02__box {
	background: #fff;
	position: relative;
	padding: 20px;
	margin-bottom: 50px;
}
.company02__box-ttl {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 34px;
	line-height: 1;
	font-weight: bold;
	position: absolute;
	top: -17px;
	width: 100%;
	text-align: center;
	color: #014898;
	letter-spacing: 0.2rem;
}
.company02__box-ttl02 {
	text-align: center;
	font-size: 18px;
}
.company02__txt01 {
	font-size: 30px;
	font-weight: 700;
	padding: 30px;
	text-align: center;
}
.company02__content ul {
	padding: 30px 0 10px;
	font-size: 18px;
}
.company02__content ul li {
	margin-bottom: 15px;
}
.company02__list01 {
	font-size: 18px;
	width: 840px;
	margin: 40px auto;
	max-width: calc(100% - 40px);
}
.company02__list01 li {
	text-indent: -30px;
	padding-left: 30px;
	font-size: 20px;
	margin-bottom: 10px;
}
.company02__list02 {
	font-size: 18px;
	width: 750px;
	margin: 0px auto 40px;
	max-width: calc(100% - 40px);
}
.company02__list02 li {
	text-indent: -18px;
	padding-left: 18px;
	font-size: 20px;
	margin-bottom: 10px;
}

#company03 {
	background: #ffffff;
	padding: 80px 0 130px;
	border-radius: 10px;
}

.company03__ttl-box {
	margin-bottom: 20px;
}

.company03__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
}
.company03__ttl01 span {
	color: #014898;
}
.company03__table {
	width: 800px;
	max-width: calc(100% - 40px);
	margin: 35px auto 0;
}
.company03__table table {
	width: 100%;
	border-collapse: collapse;
	font-size: 18px;
}
.company03__table tr {
	border-bottom: solid 1px #cccccc;
}

.company03__table th {
	width: 30%;
	padding: 15px 0;
	vertical-align: top;
	color: #014898;
	font-size: 20px;
}

.company03__table td span {
	display: inline-block;
}
.company03__table td ul li {
	margin-bottom: 5px;
	text-indent: -16px;
	padding-left: 16px;
}
.company03__table td {
	width: 70%;
	padding: 17px 0;
	vertical-align: top;
	font-size: 16px;
}
.company03__notice {
	margin-top: 5px;
	text-indent: -16px;
	padding-left: 16px;
}
.company03__box {
	width: 800px;
	max-width: calc(100% - 40px);
	margin: 0 auto 0;
}
.company03__ttl {
	width: 100%;
	padding: 15px 0;
	vertical-align: top;
	color: #014898;
	font-size: 20px;
	font-weight: bold;
}
.company03__img {
	width: 100%;
	padding: 17px 0;
	vertical-align: top;
	font-size: 16px;
}
@media (max-width: 1055px) {
	.company_ttl01 a:nth-child(2n + 1)::after {
		content: none;
	}
}
@media (max-width: 900px) {
	.company02__img-tx01 {
		font-size: 30px;
	}
	.company02__img-tx02 {
		font-size: 16px;
	}
}
@media (max-width: 769px) {
	#company01 {
		padding: 10px 0 140px;
		width: 1100px;
		max-width: calc(100% - 40px);
		margin: 0 auto;
	}
	.company_ttl01 {
		gap: 10px 25px;
		width: 450px;
		margin: 0 auto 40px;
	}
	.company_ttl01 a+a:after {
		width: 25px;
		height: 1px;
		position: absolute;
		bottom: -1px;
		left: -25px;
	}
	.company_ttl01 a img {
		width: 20px;
		height: 20px;
	}
	.company_ttl01 a {
		padding: 8px 0;
		width: 145px;
		font-size: 14px;
	}
	.company01__ttl-box {
		margin-bottom: 10px;
	}

	.company01__ttl01 {
		font-size: 26px;
		text-align: center;
		letter-spacing: 0.05rem;
		margin-bottom: 10px;
	}
	.company01__ttl02 {
		font-size: 12px;
		text-align: center;
	}

	.company01__flex {
		display: block;
	}
	.company01 .inner1100:after {
		box-shadow: 0 0 0 0;
		width: 100vw;
		position: absolute;
		left: -20px;
		top: 15px;
		z-index: -1;
		height: calc(100% + 30px);
	}
	.company01__img {
		width: 100%;
		min-width: auto;
	}
	.company01__img img {
		text-align: center;
		margin: auto;
		width: 280px;
	}
	.company01__img01 {
		margin-bottom: 30px;
	}
	.company01__img01 img {
		max-width: 100%;
	}
	.company01__img-txt {
		display: none;
	}
	.company01__content {
		width: 100%;
		font-size: 14px;
		line-height: 2.15;
	}


	#company02 {
		padding: 130px 0 0;
		position: relative;
		background: rgba(230, 230, 230, 0.6);
	}
	.company__photo img {
		max-width: 100%;
		height: 150px;
		object-fit: cover;
	}

	.company__photo img {
		max-width: 100%;
	}
	.company__pattern01 {
		position: absolute;
		top: 0;
		right: -124px;
	}
	.company__pattern01 img {
		width: 180px;
	}
	.company__pattern02 {
		position: absolute;
		bottom: 0;
		left: -195px;
	}
	.company__pattern02 img {
		width: 250px;
	}
	.company02__ttl-box {
		text-align: center;
		margin-bottom: 37px;
	}
	.company02__ttl01 {
		font-size: 26px;
		text-align: center;
		letter-spacing: 0.05rem;
		margin-bottom: 10px;
	}
	.company02__ttl02 {
		font-size: 14px;
		color: #666;
		margin-top: 5px;
	}
	.company02__flex {
		width: 100%;
		max-width: 100%;
		display: block;
		margin-bottom: 25px;
	}
	.company02__img {
		min-width: 100%;
		position: relative;
		width: 100%;
		padding: 20px 30px 10px 60px;
	}
	.company02__num {
		position: absolute;
		left: 5px;
		top: 24px;
		text-align: right;
		width: 30px;
		height: 30px;
	}
	.company02__num img {
		object-fit: contain;
		width: auto;
		height: 25px;
	}
	.company02__img-tx01 {
		font-size: 22px;
	}
	.company02__img-tx02 {
		font-size: 10px;
	}
	.company02__content {
		width: 100%;
		font-size: 16px;
		padding: 30px 20px 27px 27px;
	}
	.company02__declaration {
		max-width: 100%;
		margin: 50px auto;
	}
	.company02__box {
		background: #fff;
		position: relative;
		padding: 10px;
		margin-bottom: 30px;
	}
	.company02__box-ttl {
		font-size: 22px;
		top: -6px;
		right: 0;
		letter-spacing: 0.05rem;
	}
	.company02__box-ttl02 {
		text-align: center;
		font-size: 12px;
	}
	.company02__txt01 {
		font-size: 16px;
		font-weight: 700;
		padding: 25px;
		line-height: 1.6;
	}
	.company02__content ul {
		padding: 18px 0 0;
		font-size: 13px;
	}
	.company02__content ul li {
		margin-bottom: 8px;
		text-indent: -30px;
		padding-left: 30px;
	}
	.company02__list01 {
		margin: 18px auto;
		max-width: calc(100% - 40px);
	}
	.company02__list01 li {
		text-indent: -14px;
		padding-left: 14px;
		font-size: 14px;
		margin-bottom: 19px;
	}
	.company02__list02 {
		font-size: 18px;
		width: 750px;
		margin: 0px auto 40px;
		max-width: calc(100% - 40px);
	}
	.company02__list02 li {
		text-indent: -14px;
		padding-left: 14px;
		font-size: 14px;
		margin-bottom: 5px;
	}
	#company03 {
		background: #ffffff;
		padding: 45px 0 70px;
		border-radius: 10px;
	}
	.company03__ttl-box {
		margin-bottom: 10px;
		text-align: center;
	}
	.company03__ttl01 {
		font-size: 26px;
		text-align: center;
		letter-spacing: 0.05rem;
		margin-bottom: 10px;
	}
	.company03__table {
		margin: 20px auto 0;
	}
	.company03__table tr {
		border-bottom: solid 1px #cccccc;
		padding: 17px 0 10px;
		display: block;
	}

	.company03__table th {
		width: 100%;
		padding: 5px 0 0;
		font-size: 16px;
		display: block;
	}
	.company03__table td ul li {
		margin-bottom: 5px;
		text-indent: -14px;
		padding-left: 14px;
	}
	.company03__table td {
		width: 100%;
		padding: 3px 0 5px;
		font-size: 14px;
		display: block;
	}
	.company03__notice {
		margin-top: 5px;
		text-indent: -14px;
		padding-left: 14px;
	}
	.company03__box {
		width: 800px;
		max-width: calc(100% - 40px);
		margin: 0 auto 0;
	}
	.company03__ttl {
		width: 100%;
		padding: 15px 0;
		vertical-align: top;
		color: #014898;
		font-size: 20px;
	}
	.company03__img {
		width: 100%;
		padding: 17px 0;
		vertical-align: top;
		font-size: 16px;
	}
}


/*  products  */

.products01__flex {
	display: flex;
	flex-wrap: wrap;
	margin: 55px auto;
	width: 100%;
}
.products01__img {
	width: calc(50% + 50px);
}

.products01__img img {
	width: 100%;
}
.products01__content {
	width: calc(50% - 50px);
	background-color: #000;
	color: #fff;
	padding: 0 0 0 80px;
	margin: 45px 0 45px 0;
	display: flex;
	align-items: center;
}
.products01__content_box {
	max-width: 470px;
}
.products01__img-tx01 {
	font-size: 28px;
	line-height: 1.8;
}
.products01__img-tx02 {
	margin-top: 50px;
	font-size: 16px;
	line-height: 2.2;
}
.products01__ttl-box {
	margin-bottom: 20px;
}
.products01__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	text-align: center;
}
.products01__ttl01 span {
	color: #014898;
}
.products01__ttl02 {
	font-size: 18px;
	text-align: center;
}

.products01_ttl01 {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 80px;
	margin:0 auto 60px;
	max-width: 1000px;
	width: 100%;
}

.products01_ttl01 a {
	text-decoration: none;
	font-weight: bold;
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
	font-size: 16px;
	width: 280px;
	position: relative;
}
.products01_ttl01 a:before {
	content: "";
	background: #000;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	right: 0;
}
.products01_ttl01 a+a:after {
	content: "";
	background: #cccccc;
	width: 80px;
	height: 1px;
	position: absolute;
	bottom: -1px;
	left: -80px;
}
.products01_ttl01 a:nth-child(3n + 1)::after {
	content: none;
}

.products02 {
	position: relative;
	max-width: 1300px;
	margin: 0 auto;
	background: rgba(230, 230, 230, 0.6);
	padding: 0 0 0 0;
}
.products02__text {
	font-family: "Akshar", sans-serif;
	font-size: 76px;
	font-weight: bold;
	color: #dedede;
	line-height: 1;
	position: absolute;
	top: -5px;
	right: 0;
}
.products02__flex {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto 100px;
	padding: 100px 0 0 0;
}
.products02_content {
	width: calc(50% + 50px);
	padding: 0 0 0 0;
	margin: 0;
}
.products02__content_box {
	max-width: 100%;
}
.products02__img-ttl01 {
	font-size: 36px;
	font-weight: bold;
	line-height: 1.8;
}
.products02__img-tx01 {
	margin-top: 40px;
	font-size: 16px;
	line-height: 2;
}
.products02__img-ttl02 {
	margin-top: 30px;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.8;
}
.products02__img-ttl02::before {
	content: "■";
	color: #014898;
	margin-right: 0.3em;
}
.products02__img-tx02 {
	margin-top: 15px;
	font-size: 14px;
	line-height: 2;
}
.products02__img {
	width: calc(50% - 50px);
	padding: 0 0 0 60px;
	position: relative;
	overflow: visible;
}
.products02__img img {
	position: absolute;
	top: 0;
	left: 60px;
	width: calc(50vw - 110px);
	max-width: none;
	height: auto;
	max-height: 330px;
	object-fit: cover;
}
.products02__flex_02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	gap: 30px;
	max-width: 1220px;
	margin: 200px auto 0;
}
.products02__flex_02_box {
	width: calc(33.333% - 20px);
	background-color: #ffffff;
	padding: 20px 20px 30px 20px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	/* 横, 縦, ぼかし, 色 */
	border: 1px solid #ddd;
	border-radius: 3px;
	margin-bottom: 110px;
}
.products02__flex_02_box_img {
	margin: -128px 0 0 0;
	text-align: center;
}
.products02__flex_02_box_ttl {
	padding: 20px 5px 0 5px;
	font-size: 24px;
	line-height: 1.8;
	font-weight: bold;
}
.products02__flex_02_box_text {
	padding: 5px 5px 0 5px;
	font-size: 14px;
	line-height: 1.8;
}
.products02__flex_02_box_ttl02 {
	padding: 25px 5px 0 5px;
	font-size: 18px;
	line-height: 1.8;
	color: #014898;
	font-weight: bold;
}
.products02__flex_02_box_text02 {
	padding: 5px 5px 0 5px;
	padding: 0 0 3px 0;
	font-size: 12px;
	line-height: 1.8;
	border-bottom: solid 1px #cccccc;
}


.products03 {
	position: relative;
	max-width: 1300px;
	margin: 0 auto 100px;
	padding: 60px 0 50px 0;
}
.products03__text {
	font-family: "Akshar", sans-serif;
	font-size: 80px;
	font-weight: bold;
	color: #e2e9f1;
	line-height: 1;
}
.products03__flex {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto 100px;
	padding: 20px 0 0 0;
}
.products03_content {
	width: calc(50% + 50px);
	padding: 0 0 0 0;
	margin: 0;
}
.products03__content_box {
	max-width: 100%;
}
.products03__img-ttl01 {
	font-size: 36px;
	font-weight: bold;
	line-height: 1.8;
}
.products03__img-tx01 {
	margin-top: 40px;
	font-size: 16px;
	line-height: 2;
}
.products03__img-ttl02 {
	margin-top: 30px;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.8;
}
.products03__img-ttl02::before {
	content: "■";
	color: #014898;
	margin-right: 0.3em;
}
.products03__img-tx02 {
	margin-top: 15px;
	font-size: 14px;
	line-height: 2;
}
.products03__img {
	width: calc(50% - 50px);
	padding: 0 0 0 60px;
	position: relative;
	overflow: visible;
}
.products03__img img {
	position: absolute;
	top: 0;
	right: 60px;
	width: calc(50vw - 110px);
	max-width: none;
	height: auto;
	max-height: 330px;
	object-fit: cover;
}
.products03__flex_02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	max-width: 1100px;
	margin: 100px auto 0;
	background: rgba(230, 230, 230, 0.6);
	padding: 50px 50px;
}
.products03__flex_02_img {
	width: 30%;
}
.products03__flex_02_content_box {
	width: calc(70% - 45px);
}
.products03__flex_02_box_ttl {
	padding: 0 5px 0 5px;
	font-size: 24px;
	line-height: 1.8;
	font-weight: bold;
}
.products03__flex_02_box_text {
	padding: 5px 5px 0 5px;
	font-size: 14px;
	line-height: 1.8;
}
.products03__flex_02_box_ttl02 {
	padding: 25px 5px 0 5px;
	font-size: 18px;
	line-height: 1.8;
	color: #014898;
	font-weight: bold;
}
.products03__flex_02_box_text02 {
	padding: 5px 5px 0 5px;
	padding: 0 0 3px 0;
	font-size: 12px;
	line-height: 1.8;
	border-bottom: solid 1px #cccccc;
}


.products04 {
	position: relative;
	max-width: 1300px;
	margin: 0 auto;
	background: rgba(230, 230, 230, 0.6);
	padding: 0 0 0 0;
}
.products04__text {
	font-family: "Akshar", sans-serif;
	font-size: 76px;
	font-weight: bold;
	color: #dedede;
	line-height: 1;
	position: absolute;
	top: -5px;
	right: 0;
}
.products04__flex {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto 100px;
	padding: 100px 0 0 0;
}
.products04_content {
	width: calc(50% + 50px);
	padding: 0 0 0 0;
	margin: 0;
}
.products04__content_box {
	max-width: 100%;
}
.products04__img-ttl01 {
	font-size: 36px;
	line-height: 1.8;
	font-weight: bold;
}
.products04__img-tx01 {
	margin-top: 40px;
	font-size: 16px;
	line-height: 2;
}
.products04__img-ttl02 {
	margin-top: 30px;
	font-size: 20px;
	line-height: 1.8;
	font-weight: bold;
}
.products04__img-ttl02::before {
	content: "■";
	color: #014898;
	margin-right: 0.3em;
}
.products04__img-tx02 {
	margin-top: 15px;
	font-size: 14px;
	line-height: 2;
}
.products04__img {
	width: calc(50% - 50px);
	padding: 0 0 0 60px;
	position: relative;
	overflow: visible;
}
.products04__img img {
	position: absolute;
	top: 0;
	left: 60px;
	width: calc(50vw - 110px);
	max-width: none;
	height: auto;
	max-height: 330px;
	object-fit: cover;
}
.products04__flex_02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	gap: 30px;
	max-width: 1220px;
	margin: 200px auto 0;
}
.products04__flex_02_box {
	width: calc(33.333% - 20px);
	background-color: #ffffff;
	padding: 20px 20px 30px 20px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	/* 横, 縦, ぼかし, 色 */
	border: 1px solid #ddd;
	border-radius: 3px;
	margin-bottom: 110px;
}
.products08__flex_02_box_img {    
	margin: -160px 0 20px 0;
	text-align: center;
}
.products04__flex_02_box_ttl {
	padding: 20px 5px 0 5px;
	font-size: 24px;
	line-height: 1.8;
	font-weight: bold;
}
.products04__flex_02_box_text {
	padding: 5px 5px 0 5px;
	font-size: 14px;
	line-height: 1.8;
}
.products04__flex_02_box_ttl02 {
	padding: 25px 5px 0 5px;
	font-size: 18px;
	line-height: 1.8;
	color: #014898;
	font-weight: bold;
}
.products04__flex_02_box_text02 {
	padding: 5px 5px 0 5px;
	padding: 0 0 3px 0;
	font-size: 12px;
	line-height: 1.8;
	border-bottom: solid 1px #cccccc;
}

.products05__contact {
	position: relative;
	background-color: #014898;
	max-width: 1100px;
	margin: 100px auto 150px;
	padding: 45px 0;
}
.products05__contact-flex {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px;
	width: calc(100% - 40px);
	max-width: 800px;
	margin: 0 auto;
}
.products05__contact-txt {
	text-align: center;
	color: #fff;
	font-size: 26px;
	line-height: 1.6;
	font-weight: 700;
	width: 100%;
}
.products05__contact-link {
	margin: 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	overflow: hidden;
}
.products05__contact-link a {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	background: #fff;
	color: #000;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 350px;
	padding: 12px 20px 12px 30px;
	font-size: 26px;
	transition: 0.2s;
}
.products05__contact-tel {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 350px;
}
.products05__contact-tel a {
	text-align: center;
}



@media (max-width: 1300px) {
	.products02 {
		width: 90%;
	}
	.products03 {
		width: 90%;
	}
	.products04 {
		width: 90%;
	}
	.products02__flex {
		padding: 100px 40px 0 40px;
	}
	.products03__flex {
		padding: 100px 40px 0 40px;
	}
	.products04__flex {
		padding: 100px 40px 0 40px;
	}
	.products02__flex_02 {
		padding: 0 40px 0 40px;
	}
	.products03__flex_02 {
		padding: 30px 30px;
		width: 80%;
	}
	.products04__flex_02 {
		padding: 0 40px 0 40px;
	}
	.products05__contact {
		width: 80%;
	}
	.products01__img{
		display: flex;
    	align-items: center;
	}
	.products01__content {
		padding: 60px 40px 60px 40px;
		margin: 0 0 0 0;
	}
	.products01__img-tx01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.products01__img-tx02 {
		margin-top: 30px;
		font-size: 16px;
		line-height: 2.2;
	}
}

@media screen and (max-width: 1000px) {
	.products05__contact-flex {
		gap: 20px;
	}
	.products05__contact-tel {
		width: 100%;
	}
	.products05__contact-link {
		margin: 0 auto;
	}
	.products02__text {
		font-size: 50px;
	}
	.products03__text {
		font-size: 50px;
	}
	.products04__text {
		font-size: 50px;
	}
	
}
@media (max-width: 1070px) {
	.products01_ttl01 {
		max-width: 640px;
	}
	.products01_ttl01 a:nth-child(3n + 1)::after {
		content: "";
	}
	.products01_ttl01 a:nth-child(2n + 1)::after {
		content: none;
	}
}
@media (max-width: 769px) {
	.products01__flex {
		margin: 0 auto 50px;
	}
	.products01__img {
		width: 100%;
	}
	.products01__content {
		width: 100%;
		background-color: #000;
		color: #fff;
		padding: 40px 20px;
		margin: 0;
	}
	.products01__content_box {
		max-width: 100%;
	}
	.products01__img-tx01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.products01__img-tx02 {
		margin-top: 30px;
		font-size: 14px;
		line-height: 2.2;
	}
	.products01__ttl-box {
		margin-bottom: 10px;
	}
	.products01__ttl01 {
		font-size: 26px;
	}
	.products01__ttl02 {
		font-size: 12px;
	}
	.products01_ttl01 {
		gap: 10px 25px;
		width: 450px;
		margin: 0 auto 40px;
	}
	.products01_ttl01 a img {
		width: 20px;
		height: 20px;
	}
	.products01_ttl01 a {
		padding: 8px 0;
		width: 145px;
		font-size: 14px;
	}

	.products01_ttl01 a+a:after {
		width: 25px;
		height: 1px;
		position: absolute;
		bottom: -1px;
		left: -25px;
	}
	.products02 {
		width: 100%;
		padding: 0 0 0 0;
	}
	.products02__text {
		font-size: 36px;
		margin-bottom: 30px;
		top: -3px;
		right: 0;
	}
	.products02__flex {
		margin: 0 auto;
		padding: 100px 20px 0 20px;
	}
	.products02_content {
		width: 100%;
		padding: 0 0 0 0;
		margin: 0;
	}
	.products02__img-ttl01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.products02__img-tx01 {
		margin-top: 30px;
		font-size: 14px;
		line-height: 2;
	}
	.products02__img-ttl02 {
		margin-top: 20px;
		font-size: 20px;
		line-height: 1.8;
	}
	.products02__img-tx02 {
		margin-top: 10px;
		font-size: 13px;
		line-height: 2;
	}
	.products02__img {
		width: 100%;
		padding: 30px 0 0 0;
	}
	.products02__img img {
		position: static;
		width: 100%;
	}
	.products02__flex_02 {
		margin: 150px auto 0;
		padding: 0 20px 0 20px;
	}
	.products02__flex_02_box {
		width: 100%;
		margin-bottom: 150px;
	}
	.products02__flex_02_box:last-child {
		margin-bottom: 60px;
	}
	.products02__flex_02_box_img {
		margin: -128px 0 0 0;
		text-align: center;
	}
	.products02__flex_02_box_ttl {
		font-size: 20px;
		line-height: 1.8;
	}
	.products02__flex_02_box_text {
		font-size: 14px;
		line-height: 1.8;
	}
	.products02__flex_02_box_ttl02 {
		font-size: 18px;
		line-height: 1.8;
	}
	.products02__flex_02_box_text02 {
		font-size: 12px;
		line-height: 1.8;
	}

	.products03 {
		margin: 0 auto 60px;
		padding: 50px 0 0 0;
		width: 100%;
	}
	.products03__text {
		font-size: 36px;
		margin-bottom: 10px;
	}
	.products03__flex {
		margin: 0 auto;
		padding: 40px 20px 0 20px;
	}
	.products03_content {
		width: 100%;
		padding: 0 0 0 0;
		margin: 0;
	}
	.products03__img-ttl01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.products03__img-tx01 {
		margin-top: 30px;
		font-size: 14px;
		line-height: 2;
	}
	.products03__img-ttl02 {
		margin-top: 20px;
		font-size: 20px;
		line-height: 1.8;
	}
	.products03__img-tx02 {
		margin-top: 10px;
		font-size: 13px;
		line-height: 2;
	}
	.products03__img {
		width: 100%;
		padding: 30px 0 0 0;
	}
	.products03__img img {
		position: static;
		width: 100%;
	}
	.products03__flex_02 {
		padding: 40px 20px;
		width: 100%;
	}
	.products03__flex_02_img {
		width: 100%;
		text-align: center;
	}
	.products03__flex_02_content_box {
		width: 100%;
	}
	.products03__flex_02_box_ttl {
		margin-top: 15px;
		font-size: 20px;
		line-height: 1.8;
	}
	.products03__flex_02_box_text {
		font-size: 14px;
		line-height: 1.8;
	}
	.products03__flex_02_box_ttl02 {
		font-size: 18px;
		line-height: 1.8;
	}
	.products03__flex_02_box_text02 {
		font-size: 12px;
		line-height: 1.8;
	}

	.products04 {
		padding: 0 0 0 0;
		width: 100%;
	}
	.products04__text {
		font-size: 36px;
		margin-bottom: 30px;
		top: -3px;
		right: 0;
	}
	.products04__flex {
		margin: 0 auto;
		padding: 100px 20px 0 20px;
	}
	.products04_content {
		width: 100%;
		padding: 0 0 0 0;
		margin: 0;
	}
	.products04__img-ttl01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.products04__img-tx01 {
		margin-top: 30px;
		font-size: 14px;
		line-height: 2;
	}
	.products04__img-ttl02 {
		margin-top: 20px;
		font-size: 20px;
		line-height: 1.8;
	}
	.products04__img-tx02 {
		margin-top: 10px;
		font-size: 13px;
		line-height: 2;
	}
	.products04__img {
		width: 100%;
		padding: 30px 0 0 0;
	}
	.products04__img img {
		position: static;
		width: 100%;
	}
	.products04__flex_02 {
		margin: 150px auto 0;
		padding: 0 20px 0 20px;
	}
	.products04__flex_02_box {
		width: 100%;
		margin-bottom: 150px;
	}
	.products04__flex_02_box:last-child {
		margin-bottom: 60px;
	}
	.products08__flex_02_box_img {
		margin: -160px 0 20px 0;
		text-align: center;
	}
	.products04__flex_02_box_ttl {
		font-size: 20px;
		line-height: 1.8;
	}
	.products04__flex_02_box_text {
		font-size: 14px;
		line-height: 1.8;
	}
	.products04__flex_02_box_ttl02 {
		font-size: 18px;
		line-height: 1.8;
	}
	.products04__flex_02_box_text02 {
		font-size: 12px;
		line-height: 1.8;
	}

	.products05__contact {
		width: 100%;
		padding: 30px 0;
		margin: 60px 0 100px 0;
	}
	.products05__contact-txt {
		font-size: 18px;
		line-height: 2;
	}
	.products05__contact-flex {
		gap: 20px;
	}
	.products05__contact-tel {
		width: 100%;
	}
	.products05__contact-tel a {
		margin: 0 auto;
	}
	.products05__contact-tel img {
		width: 260px;
	}
	.products05__contact-link {
		width: 290px;
		margin: 0 auto;
	}
	.products05__contact-link a {
		width: 100%;
		padding: 12px 20px 12px 30px;
	}
	.products05__contact-link img {
		width: 35px;
	}

}

@media (max-width: 415px) {
	.products08__flex_02_box_img {
		margin: -115px 0 10px 0;
	}
	#products08 .product__card {
		margin-top: 90px;
	}
	.products02__flex_02_box_img {
		margin: -115px 0 0 0;
	}
	.products02__flex_02_box {
		margin-bottom: 120px;
	}
	.products02__flex_02_box:last-child {
		margin-bottom: 50px;
	}
}
.products03,
.products04,
.products05,
.products06,
.products07,
.products08{
    position: relative;
    max-width: 1300px;
    margin: 90px auto;
    background: rgba(230, 230, 230, 0.6);
    padding: 0 0 0 0;
}
.products__area-absolute-txt {
    font-family: "Akshar", sans-serif;
    font-size: 76px;
    font-weight: bold;
    color: #dedede;
    line-height: 1;
    position: absolute;
    top: -5px;
    right: 0;
    letter-spacing: 0.08rem;
    text-align: right;
}
.products__area{
    width: 100%;
    max-width: 1300px;
    padding: 100px 50px 100px;
    margin: 0 auto;
    position: relative;    
    background: rgba(230, 230, 230, 0.6);
}    
.product__cotent-ttl-flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 35px;
}
.product__cotent-ttl-flex02{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 50px;
}
.product__cotent-ttlbox {
  position: relative;
  padding: 0 50px 0;
  overflow: hidden;
  display: flex;
}
.product__cotent-ttlbox02{
  width: 700px;
  max-width: 100%;
  position: relative;
  padding: 0 40px 0;
  overflow: hidden;
}
.product__cotent-ttlbox-img-box{
  width: calc(100% - 700px);
  height: 330px;
  position: relative;
}
.product__cotent-ttlbox-img{
  background-color: #f7f7f7;
  position: absolute;
  z-index: 3;
  top:0;
  left: 0;
  width: 100vw;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
.product__cotent-ttlbox-img img{
  width: 640px;
}
.product__cotent-ttlbox .product__cotent-ttlbox-title {
  width: 500px;
  max-width: 100%;
}
.product__cotent-ttlbox-title {
  font-size: 38px;
  line-height: 1.25;
  font-weight: 700;
  padding: 15px 0;
}
.product__cotent-ttlbox-txt {
  font-size: 16px;
  font-weight: 500;
  line-height: 2;
  padding: 15px 0;
}
.product__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
.product__card {
  display: block;
  background: #fff;
  padding: 35px 30px 30px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border: 1px solid #ddd;
  border-radius: 3px;
}
#products08 .product__card 	{
	margin-top: 115px;
}
.product__card-ttl {
  margin: 2px 0 13px;
  font-size: 24px;
  line-height: 1.35;
  font-weight: 700;
}
.product__card-ttl02 {
	height: 63px;
}
.product__card-txt{
  font-size: 14px;
}


@media (max-width: 1300px) {
  .products03,
  .products04,
  .products05,
  .products06,
  .products07,
  .products08{
    width: 90%;
  }
  .products__area{
    padding: 100px 30px 100px;
  }    
  .product__cotent-ttl-flex{
    margin-bottom: 35px;
    display: block;
  }
  .product__cotent-ttlbox {
    padding: 0 40px 0;
    display: block;
  }
  .product__cotent-ttlbox02{
    padding: 0 50px 0;
    overflow: hidden;
  }
  .product__cotent-ttlbox-img-box{
    width: 100%;
    height: 330px;
    position: relative;
  }
  .product__cotent-ttlbox-img{
    position: relative;
    width: fit-content;
  }
  .product__cotent-ttlbox-img img{
    width: 640px;
  }
  .product__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
  }
  .products__area-absolute-txt{
    font-size: 55px;
    top:-3px;
  }
}

@media (max-width: 769px) {
  .products03,
  .products04,
  .products05,
  .products06,
  .products07,
  .products08{
    width: 100%;
    margin: 60px auto;
  }
  .products__area{
    padding: 80px 20px 80px;
  }    
  .product__cotent-ttl-flex{
    margin-bottom: 20px;
  }
  .product__cotent-ttlbox {
    padding: 0 20px 0;
  }
  .product__cotent-ttlbox02{
    padding: 0 20px 0;
  }
  .product__cotent-ttlbox-title{
    font-size: 24px;
  }
  .product__cotent-ttlbox-img-box{
    height: auto;
  }
  .product__cotent-ttlbox-img img{
    width: 640px;
    max-width: 100%;
  }
  .product__grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
  }
  .products__area-absolute-txt{
    font-size: 36px;
    top:0;
  }
  .product__card-ttl{
    font-size: 20px;
  }
.product__card-ttl02 {
	height: auto;
}

}

/*  business  */

.business01__ttl-box {
	margin-bottom: 20px;
}
.business01__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	text-align: center;
}
.business01__ttl01 span {
	color: #014898;
}
.business01__ttl02 {
	font-size: 18px;
	text-align: center;
}
.business01__ttl03 {
	font-size: 30px;
	text-align: center;
	margin-top: 50px;
}
.business01__text01 {
	font-size: 18px;
	line-height: 2.2;
	padding: 30px 0 0 0;
	max-width: 800px;
	margin: 0 auto;
}

.business02 {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 0 0 0;
}
.business02::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 100%;
	background: rgba(230, 230, 230, 0.6);
	z-index: -1;
	width: 100vw;
}
.business02::after {
	content: '';
	position: absolute;
	top: -50px;
	left: 100%;
	transform: translateX(calc((100vw - 1200px) / 2 - 100px));
	width: 5px;
	height: 160px;
	background-color: #014898;
	z-index: 2;
}
.business02_box {
	max-width: 1000px;
	margin-left: 200px;
	background: rgba(230, 230, 230, 0.6);
}
.business02_box_ttl {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 44px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #014898;
	padding: 75px 0 0 80px;
	display: flex;
	align-items: center;
}
.business02_box_ttl_no {
	font-size: 52px;
	color: #eaeaea;
	text-shadow: -1px -1px 0 #004898, 1px -1px 0 #004898, -1px 1px 0 #004898, 1px 1px 0 #004898;
	padding: 0 0 0 20px;
}
.business02_box_ttl_sub {
	font-size: 30px;
	font-family: "IBM Plex Sans JP", sans-serif;
	color: #000000;
	padding: 0 0 0 20px;
}
.business02_box_img {
	margin-left: -200px;
}
.business02__flex {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	width: 1200px;
	margin: 50px 0 0 -200px;
	padding: 0 0 0 0;
}
.business02__img {
	width: 50%;
	padding: 0;
}
.business02__content {
	width: 50%;
	padding: 0 0 0 55px;
	margin: 0;
}
.business02__content_ttl {
	font-size: 26px;
	line-height: 1.8;
	font-weight: bold;
}
.business02__content_text {
	font-size: 16px;
	line-height: 1.8;
	padding: 20px 0 0 0;
}
.business02_box_ttl02 {
	font-size: 24px;
	line-height: 1;
	font-weight: bold;
	padding: 0 0 5px 0;
	margin: 50px 0 0 80px;
	border-bottom: 1px solid #a0a0a0;
}
.business02__flex_02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	gap: 0 30px;
	margin: 0 0 0 80px;
	padding: 0 0 70px 0;
}
.business02__flex_02_box {
	width: calc(33.333% - 20px);
}
.business02__flex_02_box_img {
	text-align: center;
	padding: 20px 0 0 0;
}
.business02__flex_02_box_text {
	font-size: 20px;
	font-weight: bold;
	padding: 5px 0 0 5px;
}


.business03 {
	position: relative;
	max-width: 1200px;
	margin: 100px auto 0;
	padding: 0 0 0 0;
}
.business03::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 100%;
	background: rgba(230, 230, 230, 0.6);
	z-index: -1;
	width: 100vw;
}
.business03_box {
	max-width: 1000px;
	background: rgba(230, 230, 230, 0.6);
}
.business03_box_ttl {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 44px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #014898;
	padding: 75px 0 0 0;
	display: flex;
	align-items: center;
}
.business03_box_ttl_no {
	font-size: 52px;
	color: #eaeaea;
	text-shadow: -1px -1px 0 #004898, 1px -1px 0 #004898, -1px 1px 0 #004898, 1px 1px 0 #004898;
	padding: 0 0 0 20px;
}
.business03_box_ttl_sub {
	font-size: 30px;
	font-family: "IBM Plex Sans JP", sans-serif;
	color: #000000;
	padding: 0 0 0 20px;
}
.business03__flex {
	display: flex;
	flex-wrap: wrap;
	width: 1200px;
	margin: 50px 0 0 0;
	padding: 0 0 0 0;
}
.business03__img {
	width: 50%;
	padding: 0;
	position: relative;
}
.business03__img::after {
	content: '';
	position: absolute;
	top: 450px;
	right: 100px;
	width: 260px;
	height: 5px;
	background-color: #014898;
	z-index: 2;
}
.business03__content {
	width: 50%;
	padding: 0 55px 0 0;
	margin: 0;
}
.business03__content_ttl {
	font-size: 26px;
	line-height: 1.8;
	font-weight: bold;
}
.business03__content_text {
	font-size: 16px;
	line-height: 1.8;
	padding: 20px 0 0 0;
}
.business03_box_ttl02 {
	font-size: 24px;
	line-height: 1;
	font-weight: bold;
	padding: 0 0 5px 0;
	margin: 50px 80px 0 0;
	border-bottom: 1px solid #a0a0a0;
}
.business03__flex_02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	gap: 0 30px;
	margin: 0 80px 0 0;
	padding: 0 0 70px 0;
}
.business03__flex_02_box {
	width: calc(33.333% - 20px);
}
.business03__flex_02_box_img {
	text-align: center;
	padding: 20px 0 0 0;
}
.business03__flex_02_box_text {
	font-size: 20px;
	font-weight: bold;
	padding: 5px 0 0 5px;
}


.business04 {
	width: 100%;
	margin: 120px 0 0 0;
}
.business04_box {
	position: relative;
}
.business04_img {
	width: 100%;
}
.business04_box_img {
	position: absolute;
	max-width: 500px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.business04_box_bg {
	background: rgba(230, 230, 230, 0.6);
	width: 100%;
	padding: 0 0 140px 0;
}
.business04_box_ttl {
	font-size: 32px;
	font-weight: bold;
	text-align: center;
	padding: 80px 0 0 0;
}
.business04_box_flex {
	display: flex;
	max-width: 1200px;
	margin: 0 auto;
}
.business04_box_flex_left {
	width: calc((100% - 630px) / 2);
	margin: 0 0 0 40px;
}
.business04_box_flex_left img {
	max-width: 177px;
}
.business04_box_flex_center {
	width: 600px;
	font-size: 16px;
	line-height: 1.8;
	text-align: center;
	padding: 20px 0 0 0;
}
.business04_box_flex_right {
	width: calc((100% - 530px) / 2);
	text-align: right;
	margin: -30px 0 0 0;
}
.business04_box_flex_right img {
	max-width: 247px;
}
.business04_box_case01 {
	max-width: 1100px;
	margin: 100px auto 0;
	background-color: #ffffff;
	padding: 0 50px 50px 50px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	border: 1px solid #ddd;
	position: relative;
}
.business04_box_speechbox01 {
	display: flex;
	justify-content: center;
	margin-top: -30px;
}
.business04_box_speech01 {
	position: relative;
	display: inline-flex;
	align-items: center;
	margin-bottom: 20px;
	padding: 12px 35px;
	border-radius: 9999px;
	background-color: #014898;
	text-align: center;
	font-family: "Akshar", sans-serif;
	font-size: 26px;
	font-weight: 600;
	line-height: 1;
	color: #ffffff;
}
.business04_box_speech01 span {
	font-size: 40px;
	padding: 0 0 0 5px;
}
.business04_box_speech01::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	border-style: solid;
	border-width: 20px 10px 0 10px;
	border-color: #014898 transparent transparent;
	translate: -50% 100%;
}
.business04_box_case_flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	max-width: 1000px;
	margin: 10px 0 0 0;
	padding: 0 0 0 0;
}
.business04_box_case_flex_left {
	width: 40%;
}
.business04_box_case_flex_right {
	width: calc(60% - 40px);
}
.business04_box_case_flex_right_ttl {
	font-size: 30px;
	font-weight: bold;
	line-height: 1.8;
	padding: 0 0 0 0;
}
.business04_box_case_flex_right_tag {
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
	padding: 0 0 30px 0;
	border-bottom: 1px solid #a0a0a0;
	margin: 10px 0 10px 0;
}
.business04_box_case_flex_right_tag span {
	background-color: #000000;
	color: #ffffff;
	padding: 5px 10px;
	margin: 0 10px 0 0;
	line-height: 2.8;
	font-weight: 600;
	white-space: nowrap;
}
.business04_box_case_flex_right_text {
	font-size: 16px;
	line-height: 1.8;
	padding: 15px 0 0 0;
}
.business04_box_case_flex02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	gap: 0 30px;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 0 0 0;
}
.business04_box_case_flex02_box {
	width: calc(33.333% - 20px);
}
.business04_box_case02 {
	max-width: 1100px;
	margin: 80px auto 0;
	background-color: #ffffff;
	padding: 0 25px 25px 25px;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	border: 1px solid #ddd;
	position: relative;
	height: calc(100% - 80px);
}
.business04_box_speechbox02 {
	display: flex;
	justify-content: center;
	margin-top: -30px;
}
.business04_box_speech02 {
	position: relative;
	display: inline-flex;
	align-items: center;
	margin-bottom: 20px;
	padding: 12px 35px;
	border-radius: 9999px;
	background-color: #014898;
	text-align: center;
	font-family: "Akshar", sans-serif;
	font-size: 20px;
	font-weight: 600;
	line-height: 1;
	color: #ffffff;
}
.business04_box_speech02 span {
	font-size: 32px;
	padding: 0 0 0 5px;
}
.business04_box_speech02::before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	border-style: solid;
	border-width: 20px 10px 0 10px;
	border-color: #014898 transparent transparent;
	translate: -50% 100%;
}
.business04_box_case_flex02_img {
	padding: 30px 0 30px 0;
	text-align: center;
}
.business04_box_case_flex02_ttl {
	font-size: 30px;
	font-weight: bold;
	line-height: 1.3;
	text-align: center;
	padding: 0 0 0 0;
}
.business04_box_case_flex02_tag {
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
	text-align: center;
	padding: 0 0 30px 0;
	border-bottom: 1px solid #a0a0a0;
	margin: 10px 0 10px 0;
}
.business04_box_case_flex02_tag span {
	background-color: #000000;
	color: #ffffff;
	padding: 5px 10px;
	margin: 0 5px 0 5px;
	line-height: 2.8;
	font-weight: 600;
	white-space: nowrap;
}
.business04_box_case_flex02_text {
	font-size: 16px;
	line-height: 1.8;
	padding: 15px 0 0 0;
}
.business04_box_ttl02 {
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	padding: 60px 0 0 0;
}
.business04__link {
	margin: 35px auto 0;
	display: flex;
	justify-content: center;
	align-items: center;
}

.business04__link a {
	height: 60px;
}
@media (max-width: 1200px) {
	.business02::after {
		left: 85vw;
		transform: none;
	}
	.business02_box {
		margin-left: 30px;
		max-width: 100%;
	}
	.business02_box_img {
		margin-left: 0px;
	}
	.business02__flex {
		width: 100%;
		margin: 50px 0 0 -30px;
	}
	.business02_box_ttl02 {
		padding: 0 0 5px 0;
		margin: 50px 30px 0 80px;
	}
	.business02__flex_02 {
		margin: 0 30px 0 80px;
		padding: 0 0 70px 0;
	}
	.business03_box {
		margin-right: 30px;
		max-width: 100%;
	}
	.business03__flex {
		width: 100%;
		margin: 50px 0 0 30px;
	}
	.business03_box_ttl {
		padding: 75px 0 0 80px;
	}
	.business03_box_ttl02 {
		margin: 50px 80px 0 30px;
	}
	.business03__flex_02 {
		margin: 0 80px 0 30px;
	}
	.business03__img::after {
		display: none;
	}
	.business04_box_flex_left {
		display: none;
	}
	.business04_box_flex_center {
		width: 100%;
	}
	.business04_box_flex_right {
		display: none;
	}
	.business04_box_case01 {
		padding: 0 25px 25px 25px;
	}
	.business04_box_bg {
		padding: 0 20px 140px 20px;
	}
}

@media (max-width: 769px) {
	.business01__ttl-box {
		margin-bottom: 60px;
	}
	.business01__ttl-box {
		margin-bottom: 10px;
	}
	.business01__ttl01 {
		font-size: 26px;
	}
	.business01__ttl02 {
		font-size: 12px;
	}
	.business01__ttl03 {
		font-size: 22px;
		text-align: center;
		padding: 0 20px 0 20px;
		margin-top: 30px;
	}
	.business01__text01 {
		font-size: 16px;
		line-height: 2.2;
		padding: 30px 20px 0 20px;
	}

	.business02 {
		padding: 0 0 0 0;
	}
	.business02::after {
		top: -30px;
		left: 80vw;
		transform: none;
		width: 5px;
		height: 100px;
	}
	.business02_box {
		margin-left: 0;
	}
	.business02_box_ttl {
		font-size: 30px;
		padding: 40px 0 0 20px;
		flex-wrap: wrap;
	}
	.business02_box_ttl_no {
		font-size: 32px;
	}
	.business02_box_ttl_sub {
		font-size: 20px;
		width: 100%;
		padding: 5px 0 0 0;
	}
	.business02_box_img {
		margin-left: 0;
	}
	.business02__flex {
		width: 100%;
		margin: 40px 0 0 0;
	}
	.business02__img {
		width: 100%;
		text-align: center;
		padding: 25px 20px 50px 20px;
	}
	.business02__content {
		width: 100%;
		padding: 0 20px 0 20px;
		margin: 0;
	}
	.business02__content_ttl {
		font-size: 20px;
		line-height: 1.8;
	}
	.business02__content_text {
		font-size: 14px;
		padding: 20px 0 0 0;
	}
	.business02_box_ttl02 {
		font-size: 20px;
		padding: 0 0 5px 0;
		margin: 30px 20px 0 20px;
	}
	.business02__flex_02 {
		margin: 0 20px 0 20px;
		padding: 0 0 40px 0;
		gap: 0 10px;
	}
	.business02__flex_02_box {
		width: calc(50% - 5px);
	}
	.business02__flex_02_box_img {
		text-align: left;
		padding: 20px 0 0 0;
	}
	.business02__flex_02_box_text {
		font-size: 14px;
		font-weight: bold;
		padding: 5px 0 0 5px;
	}

	.business03 {
		padding: 0 0 0 0;
	}
	.business03::after {
		content: '';
		position: absolute;
		top: -30px;
		left: 80vw;
		transform: none;
		width: 5px;
		height: 100px;
		background-color: #014898;
		z-index: 2;
	}
	.business03_box {
		margin-right: 0;
	}
	.business03_box_ttl {
		font-size: 30px;
		padding: 40px 0 0 20px;
		flex-wrap: wrap;
	}
	.business03_box_ttl_no {
		font-size: 32px;
	}
	.business03_box_ttl_sub {
		font-size: 20px;
		width: 100%;
		padding: 5px 0 0 0;
	}
	.business03_box_img {
		margin-left: 0;
	}
	.business03__flex {
		width: 100%;
		margin: 40px 0 0 0;
	}
	.business03__img {
		width: 100%;
		text-align: center;
		padding: 25px 20px 50px 20px;
	}
	.business03__content {
		width: 100%;
		padding: 0 20px 0 20px;
		margin: 0;
	}
	.business03__content_ttl {
		font-size: 20px;
		line-height: 1.8;
	}
	.business03__content_text {
		font-size: 14px;
		padding: 20px 0 0 0;
	}
	.business03_box_ttl02 {
		font-size: 20px;
		padding: 0 0 5px 0;
		margin: 30px 20px 0 20px;
	}
	.business03__flex_02 {
		margin: 0 20px 0 20px;
		padding: 0 0 40px 0;
		gap: 0 10px;
	}
	.business03__flex_02_box {
		width: calc(50% - 5px);
	}
	.business03__flex_02_box_img {
		text-align: left;
		padding: 20px 0 0 0;
	}
	.business03__flex_02_box_text {
		font-size: 14px;
		font-weight: bold;
		padding: 5px 0 0 5px;
	}

	.business04 {
		width: 100%;
		margin: 60px 0 0 0;
	}
	.business04_box_bg {
		background: rgba(230, 230, 230, 0.6);
		width: 100%;
		padding: 0 0 70px 0;
	}
	.business04_box_ttl {
		font-size: 26px;
		font-weight: bold;
		text-align: center;
		padding: 40px 0 0 0;
	}
	.business04_box_flex {
		display: flex;
		max-width: 1200px;
		margin: 0 auto;
	}
	.business04_box_flex_left {
		display: none;
	}
	.business04_box_flex_center {
		width: 100%;
		font-size: 16px;
		padding: 20px 20px 0 20px;
	}
	.business04_box_flex_right {
		display: none;
	}
	.business04_box_case01 {
		margin: 100px 20px 0 20px;
		padding: 0 20px 20px 20px;
	}
	.business04_box_speechbox01 {
		display: flex;
		justify-content: center;
		margin-top: -30px;
	}
	.business04_box_speech01 {
		font-size: 26px;
	}
	.business04_box_speech01 span {
		font-size: 40px;
		padding: 0 0 0 5px;
	}
	.business04_box_case_flex {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 10px 0 0 0;
		padding: 0 0 0 0;
	}
	.business04_box_case_flex_left {
		width: 100%;
		padding: 20px 0 20px 0;
		text-align: center;
	}
	.business04_box_case_flex_right {
		width: 100%;
	}
	.business04_box_case_flex_right_ttl {
		font-size: 24px;
		font-weight: bold;
		text-align: center;
		padding: 0 0 0 0;
	}
	.business04_box_case_flex_right_tag {
		font-size: 14px;
		font-weight: bold;
		text-align: center;
		line-height: 1;
		padding: 0 0 20px 0;
		border-bottom: 1px solid #a0a0a0;
		margin: 10px 0 10px 0;
	}
	.business04_box_case_flex_right_tag span {
		background-color: #000000;
		color: #ffffff;
		padding: 2px 5px;
		margin: 0 10px 0 0;
	}
	.business04_box_case_flex_right_text {
		font-size: 14px;
		line-height: 1.8;
		padding: 5px 0 0 0;
	}
	.business04_box_case_flex02 {
		padding: 0 0 0 0;
	}
	.business04_box_case_flex02_box {
		width: 100%;
	}
	.business04_box_case02 {
		padding: 0 25px 25px 25px;
		margin: 80px 20px 0 20px;

	}
	.business04_box_speechbox02 {
		display: flex;
		justify-content: center;
		margin-top: -30px;
	}
	.business04_box_case_flex02_ttl {
		font-size: 24px;
		font-weight: bold;
		line-height: 1.3;
		text-align: center;
		padding: 0 0 0 0;
	}
	.business04_box_case_flex02_tag {
		font-size: 14px;
		font-weight: bold;
		line-height: 1;
		text-align: center;
		padding: 0 0 20px 0;
		border-bottom: 1px solid #a0a0a0;
		margin: 10px 0 10px 0;
	}
	.business04_box_case_flex02_tag span {
		background-color: #000000;
		color: #ffffff;
		padding: 2px 5px;
		margin: 0 5px 0 5px;
	}
	.business04_box_case_flex02_text {
		font-size: 14px;
		line-height: 1.8;
		padding: 5px 0 0 0;
	}
	.business04_box_ttl02 {
		font-size: 24px;
		padding: 40px 0 0 0;
	}
	.business04__link {
		margin: 25px auto 0;
		height: 60px;
	}
	.business04__link a {
		width: 240px;
		padding: 8px 20px 8px 30px;
	}
	.business04_box_img {
		width: 65%;
	}

}


/*  technology  */

.technology01__flex {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	margin: 55px auto;
	width: 100%;
}
.technology01__img {
	width: calc(50% + 50px);
}
.technology01__img img {
	width: 100%;
}
.technology01__content {
	width: calc(50% - 50px);
	background-color: #014898;
	color: #fff;
	padding: 0 60px 0 0;
	margin: 45px 0 45px 0;
	display: flex;
	align-items: center;
	justify-content: end;
}
.technology01__content_box {
	max-width: 470px;
}
.technology01__img-tx01 {
	font-size: 36px;
	line-height: 1.8;
}
.technology01__img-tx02 {
	margin-top: 50px;
	font-size: 16px;
	line-height: 2.2;
}

.technology01_ttl01 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px 80px;
	margin-bottom: 40px;
	max-width: 100%;
}

.technology01_ttl01 a {
	text-decoration: none;
	font-weight: bold;
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
	font-size: 16px;
	width: 280px;
	position: relative;
}
.technology01_ttl01 a:before {
	content: "";
	background: #000;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	right: 0;
}
.technology01_ttl01 a+a:after {
	content: "";
	background: #cccccc;
	width: 80px;
	height: 1px;
	position: absolute;
	bottom: -1px;
	left: -80px;
}


.technology02 {
	background: rgba(230, 230, 230, 0.6);
	margin: 10px 0 0 0;
	padding: 90px 0 90px 0;
	position: relative;
}
.technology02_bgimg01 {
	position: absolute;
	top: 50px;
	right: 0;
	max-width: 535px;
}
.technology02_bgimg02 {
	position: absolute;
	bottom: -80px;
	left: 0;
	max-width: 213px;
}
.technology02__ttl-box {
	margin-bottom: 20px;
}
.technology02__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	text-align: center;
}
.technology02__ttl01 span {
	color: #014898;
}
.technology02__ttl02 {
	font-size: 18px;
	text-align: center;
}
.technology02__box {
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
}
.technology02__box-ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 70px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #014898;
	position: absolute;
	top: -30px;
}
.technology02__flex {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	max-width: 1100px;
	margin: 50px 50px 100px 50px;
	background-color: white;
	background: url(../image/common/bg01.png);
	padding: 120px 0;
}
.technology02_content {
	width: calc(50% + 50px);
	padding: 0 0 0 75px;
	margin: 0;
}
.technology02__flex-ttl01 {
	font-weight: 700;
	font-size: 32px;
	line-height: 1.5;
	font-weight: bold;
}
.technology02__flex-tx01 {
	font-size: 16px;
	line-height: 2.2;
	padding: 20px 0 0 0;
}
.technology02__img {
	width: calc(50% - 50px);
	padding: 0 0 0;
	position: relative;
	right: -50px;
	z-index: 1;
}
.technology02__box02 {
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
}
.technology02__box02-ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 70px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #014898;
	position: absolute;
	top: -30px;
	right: 0;
}
.technology02__flex02 {
	display: flex;
	flex-wrap: wrap;
	max-width: 1100px;
	margin: 50px 50px 100px 50px;
	background-color: white;
	background: url(../image/common/bg01.png);
	padding: 120px 0;
}
.technology02_content02 {
	width: calc(50% + 50px);
	padding: 0 75px 0 0;
	margin: 0;
}
.technology02__flex02-ttl01 {
	font-weight: 700;
	font-size: 32px;
	line-height: 1.5;
	font-weight: bold;
}
.technology02__flex02-tx01 {
	font-size: 16px;
	line-height: 2.2;
	padding: 20px 0 0 0;
}
.technology02__img02 {
	width: calc(50% - 50px);
	padding: 0 0 0;
	position: relative;
	left: -50px;
	z-index: 1;
}

.technology03 {
	margin: 10px 0 0 0;
	padding: 90px 0 90px 0;
	position: relative;
}
.technology03__ttl-box {
	margin-bottom: 20px;
}
.technology03__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	text-align: center;
}
.technology03__ttl01 span {
	color: #014898;
}
.technology03__ttl02 {
	font-size: 18px;
	text-align: center;
}
.technology03__stepbox {
	max-width: 1040px;
	margin: 0 auto;
	padding: 0 20px 0 20px;
}
.technology03__step_flex {
	display: flex;
	background: rgba(230, 230, 230, 0.6);
	padding: 50px 40px 0 40px;
	margin: 40px 0 40px 0;
}
.technology03__step_flex_no {
	width: 100px;
	font-family: "Akshar", sans-serif;
	font-size: 70px;
	line-height: 1;
	font-weight: bold;
	color: #014898;
	text-align: center;
	position: relative;
}
.technology03__step_flex_no_b {
	width: 100px;
	font-family: "Akshar", sans-serif;
	font-size: 70px;
	line-height: 1;
	font-weight: bold;
	color: #014898;
	text-align: center;
	position: relative;
}
.technology03__step_flex_no::after {
	content: '';
	position: absolute;
	bottom: -40px;
	left: 37px;
	color: #333;
	line-height: 1;
	width: 26px;
	height: 26px;
	border: 1px solid currentColor;
	border-left: 0;
	border-bottom: 0;
	box-sizing: border-box;
	transform: translateY(-25%) rotate(135deg);
}
.technology03__step_flex_no_line {
	border-bottom: 1px solid #000000;
}
.technology03__step_flex_no_line_b {
	padding: 0;
}
.technology03__step_flex_no_line::after {
	content: '';
	position: absolute;
	top: 70px;
	left: 50%;
	transform: translateX(-50%);
	width: 1px;
	height: calc(100% - 70px + 40px);
	background-color: #000;
}
.technology03__step_flex_content {
	width: calc(100% - 100px);
	padding: 0 0 50px 30px;
}
.technology03__step_flex_content_flex01 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0;
}
.technology03__step_flex_content_flex01_text {
	width: calc(60% - 50px);
}
.technology03__step_flex_content_flex01_img {
	width: 40%;
}
.technology03__step_flex_content_flex01_text_ttl {
	padding: 10px 0 0 0;
	font-size: 28px;
	line-height: 1.5;
	font-weight: bold;
}
.technology03__step_flex_content_flex01_text_01 {
	padding: 30px 0 0 0;
	font-size: 16px;
	line-height: 2.2;
}

.technology04 {
	margin: 10px 0 0 0;
	padding: 0 0 90px 0;
	position: relative;
}
.technology04__ttl-box {
	margin-bottom: 20px;
}
.technology04__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
	text-align: center;
}
.technology04__ttl01 span {
	color: #014898;
}
.technology04__ttl02 {
	font-size: 18px;
	text-align: center;
}
.technology04_tb_box {
	max-width: 800px;
	margin: 40px auto;
}
.technology04_tb_box table {
	width: 800px;
	border-collapse: collapse;
}
.technology04_tb_box th {
	background-color: #014898;
	color: #fff;
	font-size: 16px;
	padding: 20px 20px;
	text-align: left;
	vertical-align: top;
}
.technology04_tb_box td {
	font-size: 14px;
	padding: 20px 20px;
	text-align: left;
	vertical-align: top;
}
.technology04_tb_box tr:nth-child(even) {
	background: rgba(230, 230, 230, 0.6);
}
.technology04_tb_box tr:nth-child(odd) {
	background: rgba(230, 230, 230, 0.0);
}
.technology04_tb_box_ttl {
	font-size: 16px;
	font-weight: bold;
	color: #014898;
}
.technology04_tb_box .bg {
	font-size: 16px;
	font-weight: bold;
	color: #014898;
	background-color: white;
	background: url(../image/common/bg01.png);
}
.b-bottom-line {
	border-bottom: 1px solid #cccccc;
}
.technology04_tb_box .w20 {
	width: 20%;
}
.technology04_tb_box .w30 {
	width: 30%;
}


@media (max-width: 1300px) {
	
	.technology01__content {
		padding: 20px 40px 20px 40px;
		margin: 35px 0 0 0;
	}
	.technology01__img-tx01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.technology01__img-tx02 {
		margin-top: 30px;
		font-size: 16px;
		line-height: 2.2;
	}
	.technology01__img {
		display: flex;
		align-items: center;
	}
	.technology01__content {
		padding: 60px 40px 60px 40px;
		margin: 0 0 0 0;
	}
}
@media (max-width: 1055px) {
	.technology01_ttl01 a:nth-child(2n + 1)::after {
		content: none;
	}
}


@media (max-width: 769px) {
	.technology01__flex {
		display: flex;
		flex-wrap: wrap;
		flex-direction: row-reverse;
		margin: 0 auto 55px;
		width: 100%;
	}
	.technology01__img {
		width: 100%;
	}
	.technology01__content {
		width: 100%;
		padding: 40px 20px;
		margin: 0;
	}
	.technology01__content_box {
		max-width: 100%;
	}
	.technology01__img-tx01 {
		font-size: 24px;
		line-height: 1.8;
	}
	.technology01__img-tx02 {
		margin-top: 30px;
		font-size: 14px;
		line-height: 2.2;
	}
	.technology01_ttl01 {
		gap: 10px 25px;
		width: 450px;
		margin: 0 auto 40px;
	}
	.technology01_ttl01 a img {
		width: 20px;
		height: 20px;
	}
	.technology01_ttl01 a {
		padding: 8px 0;
		width: 145px;
		font-size: 14px;
		align-items: center;
		line-height: 1.2;
	}

	.technology01_ttl01 a+a:after {
		width: 25px;
		height: 1px;
		position: absolute;
		bottom: -1px;
		left: -25px;
	}
	.technology02 {
		margin: 10px 0 0 0;
		padding: 80px 0 20px 0;
	}
	.technology02_bgimg01 {
		position: absolute;
		top: -30px;
		right: 0;
		max-width: 200px;
	}
	.technology02_bgimg02 {
		position: absolute;
		bottom: -60px;
		left: 0;
		max-width: 150px;
	}
	.technology02__ttl-box {
		margin-bottom: 10px;
	}
	.technology02__ttl01 {
		font-size: 26px;
	}
	.technology02__ttl02 {
		font-size: 12px;
	}
	.technology02__box {
		margin: 0 auto;
	}
	.technology02__box-ttl01 {
		font-size: 26px;
		top: -12px;
		left: 50%;
		transform: translateX(-50%);
	}
	.technology02__flex {
		margin: 50px 20px 50px 20px;
		padding: 35px 0;
	}
	.technology02_content {
		width: 100%;
		padding: 0 20px 0 20px;
		margin: 0;
	}
	.technology02__flex-ttl01 {
		font-size: 20px;
		line-height: 1.5;
		font-weight: bold;
		padding: 30px 0 0 0;
	}
	.technology02__flex-tx01 {
		font-size: 14px;
		line-height: 2.2;
		padding: 20px 0 0 0;
	}
	.technology02__img {
		width: 100%;
		padding: 0 20px 0 20px;
		position: static;
	}
	.technology02__box02 {
		margin: 0 auto;
	}
	.technology02__box02-ttl01 {
		font-size: 26px;
		top: -12px;
		left: 50%;
		right: auto;
		transform: translateX(-50%);
	}
	.technology02__flex02 {
		margin: 50px 20px 50px 20px;
		padding: 35px 0;
	}
	.technology02_content02 {
		width: 100%;
		padding: 0 20px 0 20px;
		margin: 0;
	}
	.technology02__flex02-ttl01 {
		font-size: 20px;
		line-height: 1.5;
		font-weight: bold;
		padding: 30px 0 0 0;
	}
	.technology02__flex02-tx01 {
		font-size: 14px;
		line-height: 2.2;
		padding: 20px 0 0 0;
	}
	.technology02__img02 {
		width: 100%;
		padding: 0 20px 0 20px;
		position: static;
	}

	.technology03 {
		margin: 10px 0 0 0;
		padding: 80px 0 80px 0;
	}
	.technology03__ttl-box {
		margin-bottom: 10px;
	}
	.technology03__ttl01 {
		font-size: 26px;
	}
	.technology03__ttl02 {
		font-size: 12px;
	}
	.technology03__stepbox {
		padding: 0 0 0 0;
	}
	.technology03__step_flex {
		padding: 30px 20px 0 20px;
		margin: 30px 0 40px 0;
	}
	.technology03__step_flex_no {
		width: 50px;
		font-family: "Akshar", sans-serif;
		font-size: 40px;
		line-height: 1;
		font-weight: bold;
		color: #014898;
		text-align: center;
		position: relative;
	}
	.technology03__step_flex_no_b {
		width: 50px;
		font-family: "Akshar", sans-serif;
		font-size: 40px;
		line-height: 1;
		font-weight: bold;
		color: #014898;
		text-align: center;
		position: relative;
	}
	.technology03__step_flex_no::after {
		content: '';
		position: absolute;
		bottom: -40px;
		left: 12px;
		color: #333;
		line-height: 1;
		width: 26px;
		height: 26px;
		border: 1px solid currentColor;
		border-left: 0;
		border-bottom: 0;
		box-sizing: border-box;
		transform: translateY(-25%) rotate(135deg);
	}
	.technology03__step_flex_no_line {
		border-bottom: 1px solid #000000;
	}
	.technology03__step_flex_no_line_b {
		padding: 0;
	}
	.technology03__step_flex_no_line::after {
		content: '';
		position: absolute;
		top: 40px;
		left: 50%;
		transform: translateX(-50%);
		width: 1px;
		height: calc(100% - 40px + 40px);
		background-color: #000;
	}
	.technology03__step_flex_content {
		width: calc(100% - 50px);
		padding: 0 0 30px 20px;
	}
	.technology03__step_flex_content_flex01 {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		padding: 0;
	}
	.technology03__step_flex_content_flex01_text {
		width: 100%;
	}
	.technology03__step_flex_content_flex01_img {
		width: 100%;
	}
	.technology03__step_flex_content_flex01_text_ttl {
		padding: 5px 0 0 0;
		font-size: 20px;
		line-height: 1.5;
		font-weight: bold;
	}
	.technology03__step_flex_content_flex01_text_01 {
		padding: 15px 0 15px 0;
		font-size: 14px;
		line-height: 2.2;
	}

	.technology04 {
		margin: 10px 0 0 0;
		padding: 0 0 80px 0;
	}
	.technology04__ttl-box {
		margin-bottom: 10px;
	}
	.technology04__ttl01 {
		font-size: 26px;
	}
	.technology04__ttl02 {
		font-size: 12px;
	}
	.technology__st-span01{
		position: absolute;
		bottom: -15px;
	}
	

}
@media (max-width: 420px) {
	.technology__subpage_ttl{
		top: 89px;
	}
}


/* ───────── 見出し／注意文 ───────── */
.content-area {
	margin: 100px auto;
	background: rgba(230, 230, 230, 0.6);
	padding: 80px 75px;
}
.contact-title {
	font-size: 30px;
	font-weight: 700;
	text-align: center;
	line-height: 1.6;
	margin-bottom: 40px;
}
.contact-note {
	font-size: 16px;
	text-align: left;
	margin: 0 auto 5px;
	line-height: 1.8;
	text-indent: -18px;
	padding-left: 18px;
	max-width: 760px;
	width: 100%;
}
/* ───────── フォームグリッド ───────── */
.contact-form {
	margin: 90px 0 0;
}
.left-col {
	width: 100%;
	min-width: 180px;
}
.right-col {
	width: 100%;
	display: flex;
	flex-direction: column;
	row-gap: 34px;
}


.form-label {
	font-size: 20px;
	font-weight: 700;
	color: #00459F;
	margin-bottom: 6px;
	display: block;
}
.form-label  + br{
	display: none;
}
.required {
	font-size: 12px;
	font-weight: 700;
	color: #FFFFFF;
	background: #000000;
	padding: 2px 10px;
	margin-left: 25px;
	border-radius: 2px;
	vertical-align: middle;
	height: 20px;
}
/* ───────── テキスト入力・テキストエリア ───────── */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
	width: 100%;
	font-size: 14px;
	color: #333333;
	padding: 12px;
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	box-sizing: border-box;
	background: #fff;
}
.small-input {
	max-width: 200px;
}

/* ───────── ラジオリスト ───────── */
.radio-list {
	list-style: none;
	padding: 0;
	margin: 20px 0;
}
.radio-list li {
	margin-bottom: 8px;
	font-size: 16px;
	margin-left: 10px;
}
.radio-list input[type="radio"] {
	transform: scale(1.1);
	margin-right: 6px;
}
.radio-list label {
	font-size: 14px;
	font-weight: 500;
}

/* ───────── プライバシー同意 ───────── */
.privacy-group {
	margin-top: 30px;
	text-align: center;
}
.form-group input[name="privacy"] {
	transform: scale(1.1);
}
.privacy-text {
	font-size: 16px;
	text-align: center;
	margin-bottom: 10px;
}
.checkbox {
	font-size: 18px;
	text-align: center;
}
.checkbox input {
	margin-right: 6px;
}
.checkbox a {
	color: #00459F;
	text-decoration: underline;
}
/* ───────── 注意文 ───────── */
.form-group.notes {
	font-size: 14px;
	line-height: 1.8;
	text-align: center;
	margin: 20px 20px 0;
}

/* ───────── 送信ボタン ───────── */

#btn-submit{
	font-weight: 500;
    font-size: 18px;
    letter-spacing: 0.05rem;
    background: #000;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
	max-width: 240px;
    padding: 10px 20px 10px 30px;
    position: relative;
	transition: 0.2s;
}

.link-btn-submit p{
	position: relative;
	opacity: 0.6;
    pointer-events: none;
}
.link-btn-submit .link_arrow02 {
    top: 7px;
	pointer-events: none;
}
.link-btn-submit p:hover .link_arrow02{
    background: #fff;
    border: solid 1px #004898;
}
#btn-submit:hover{
  	background:  #004898;
}
.link-btn-submit.close p{
	opacity: 1;
    pointer-events: auto;
}
.link-btn-submit p:hover .link_arrow02:after{
    left: 70%;
    opacity: 0;
}
.link-btn-submit p:hover .link_arrow02:before{
    left: 70%;
    opacity: 1;
}
.wpcf7-spinner{
	display: none !important;
}
.btn-submit {
	margin: 0 auto;
	cursor: pointer;
}
.btn-submit:hover {
	opacity: 0.9;
}
.form-group.link__btn02 {
	margin: 0 auto 0;

}
.form-group.link__btn02 p{
	width: 240px;

}
.btn-arrow {
	margin-left: 8px;
	font-size: 18px;
	line-height: 1;
}
.btn-submit[disabled] {
	opacity: 0.6;
	pointer-events: none;
}
@media screen and (max-width: 769px) {
	.content-area {
		padding: 30px 20px;
		margin: 30px auto 60px;
	}
	.contact-title {
		font-size: 16px;
		margin-bottom: 5px;
	}
	.contact-note {
		text-indent: -13px;
		padding-left: 13px;
		font-size: 13px;
	}
	.required {
		margin-left: 15px;
	}
	.form-group.notes {
		font-size: 13px;
		line-height: 1.8;
		text-align: center;
		margin: 20px 10px 0;
	}

	/* フォームを縦並びに */
	.contact-form {
		display: block;
		margin: 30px 0 0;
	}
	.left-col,
	.right-col {
		width: 100%;
		display: block;
		margin-bottom: 20px;
	}

	/* グループ間のスペース */
	.form-group {
		margin-bottom: 30px;
	}

	/* ラジオリストの余白微調整 */
	.radio-list li {
		margin-bottom: 6px;
	}

	/* ラベル・入力欄 */
	.form-label {
		font-size: 14px;
	}
	input[type="text"],
	input[type="email"],
	input[type="tel"],
	textarea {
		font-size: 14px;
		padding: 10px;
	}
	.small-input {
		max-width: 100%;
	}

	/* プライバシー同意まわり */
	.privacy-text {
		font-size: 12px;
		margin-bottom: 6px;
	}
	.checkbox,
	.checkbox a {
		font-size: 13px;
	}

	.form-group.link__btn02 {
		margin: 20px auto 0;
		justify-content: center;
	}
}
.inner1300 {
	width: 1300px;
	max-width: calc(100% - 40px);
	margin: 0 auto;
}
/* ====== 全体ラッパー ====== */
.history__wrapper {
	margin: 130px auto 97px;
	padding-bottom: 120px;
	position: relative;
	font-family: "Noto Sans JP", sans-serif;
}
.history__bg-title {
	position: absolute;
	top: -76px;
	left: 45px;
	font-size: 104px;
	color: #a0a0a0;
	z-index: 5;
	font-family: "Akshar", sans-serif;
	font-weight: 700;
}
.history__area02 .history__bg-title {
	position: absolute;
	top: -76px;
	left: auto;
	right: 45px;
	font-size: 104px;
	color: #a0a0a0;
	z-index: 5;
	font-family: "Akshar", sans-serif;
	font-weight: 700;
}
.history__area {
	position: relative;
	padding: 0;
	padding: 215px 0 140px;
	background: rgba(230, 230, 230, 0.6);
}
.history__area02 {
	position: relative;
	padding: 0;
	padding: 215px 0 140px;
	background: url(image/common/bg01.png);
}
.history__line {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	width: 200px;
	transform: translate(-50%, 0);
	background-color: #0052a4;
	z-index: 2;
}

/* ====== 各エントリ ====== */
.history__entry {
	position: relative;
	height: 120px;
	/* 各エントリの高さを固定 or 適宜調整 */
	margin-bottom: 40px;
}

/* ●年の丸 */
.history__year {
	position: absolute;
	top: 30px;
	left: 50%;
	transform: translate(-50%, 0);
	position: absolute;
	z-index: 2;
	color: #fff;
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ====== コンテンツ ====== */
.history__content {
	position: absolute;
	top: 0;
	width: calc(50% - 100px);
	background: url(../image/common/bg01.png);
	padding: 50px 60px;
	font-size: 16px;
	line-height: 1.6;
	z-index: 20;
}

.history__area02 .history__content {
	background: rgba(230, 230, 230, 0.6);
}
/* 左側コンテンツ：右端を青帯左端にフラッシュ */
.history__entry--left .history__content {
	right: calc(50% + 100px);
}
/* 右側コンテンツ：左端を青帯右端にフラッシュ */
.history__entry--right .history__content {
	left: calc(50% + 100px);
}

/* 白い三角（内容→青帯） */
.history__content::before {
	content: "";
	position: absolute;
	top: 60px;
	border-top: 12px solid transparent;
	border-bottom: 12px solid transparent;
	z-index: 3;
}
.history__entry--left .history__content::before {
	right: -19px;
	border-left: 20px solid #fbfbfb;
	/* ←白い三角が右向き */
}
.history__entry--right .history__content::before {
	left: -19px;
	border-right: 20px solid #fbfbfb;
	/* ←白い三角が左向き */
}
.history__area02 .history__entry--left .history__content::before {
	right: -19px;
	border-left: 20px solid #eaeaea;
	/* ←白い三角が右向き */
}
.history__area02 .history__entry--right .history__content::before {
	left: -19px;
	border-right: 20px solid #eaeaea;
	/* ←白い三角が左向き */
}

.history__content ul {
	margin: 0 0 12px 0;
	font-size: 20px;
}
.history__content ul li {
	padding-left: 20px;
	position: relative;
}
.history__content ul li+li {
	margin-top: 15px;
}
.history__content ul li.bold {
	color: #0052a4;
	font-weight: 700;
}
.history__content ul li:before {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	background: #0052a4;
	border-radius: 10px;
	top: 11px;
	left: 0;
}


/* 画像＋キャプション */
.history__images {
	display: flex;
	gap: 10px;
	margin-top: 30px;
	justify-content: center;
	align-items: center;
}
.history__images-wrap {
	flex-wrap: wrap;
	gap: 20px;
}
.history__image01 {
	width: 180px;
}
.history__image02 {
	width: 198px;
}
.history__image03 {
	width: 340px;
}
.history__image03 img{
	width: 100%;
}
.history__image-txt {
	margin-top: 15px;
	font-size: 14px;
	line-height: 1.8;
}
.history__image-txt-right {
	text-align: right;
	margin-top: 15px;
	font-size: 14px;
	line-height: 1.8;
}

.history__nav-block {
	margin: 0 auto 0;
	text-align: center;
	font-size: 20px;
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	position: fixed;
	bottom: 60px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 99;
	max-width: 800px;
	width: calc(100svw - 100px);
	background: #000;
	display: flex;
    align-items: center;
	justify-content: center;
	gap: 10px;
}
.history__nav-ttl {
	text-align: center;
	color: #fff;
    line-height: 1.2;
    text-align: left;
    width: 70px;
    font-size: 20px;
}
.history__timeline-nav-box{
	display: flex;
	gap: 0px 40px;
}
.history__timeline-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0px 50px;
	color: #fff;
	font-size: 12px;
	padding: 15px 5px 15px;
	border-radius: 4px;
}
.history__nav-block input,
.history__arrow{
	display: none;
}
.absolute-value {
	position: absolute;
	bottom: 0;
}
.history__nav-item {
	line-height: 1;
	font-weight: 500;
	font-size: 28px;
	padding: 10px 5px;
	position: relative;
}
.history__nav-item:before {
	position: absolute;
	width: 28px;
    right: -35px;
	height: 1px;
	background-color: #fff;
	content: "";
	top: 50%;
}
.history__nav-item:last-child:before {
	content: none;
}
.history__nav-item.active {
	font-weight: 700;
	transition: 0.4s;
	opacity: 1;
}
.to-future {
	padding: 70px 20px;
	text-align: center;
	background: #fff;
	width: 1200px;
	margin: 0 auto;
	max-width: calc(100% - 40px);
	box-shadow: 0px 0px 20px 1px rgba(0, 0, 0, 0.1);
	margin: 0 auto 144px;
}

.to-future__title-wrapper {
	position: relative;
	display: inline-block;
	margin-bottom: 75px;
}

.to-future__title {
	font-family: "Akshar", sans-serif;
	font-size: 72px;
	font-weight: 700;
	letter-spacing: 1px;
	margin: 0;
	position: relative;
	display: inline-block;
	color: #000;
	line-height: 1;
	z-index: 2;
}
.to-future__title img {
	position: absolute;
	bottom: -16px;
	width: 452px;
	right: 50%;
	transform: translate(50%, 0);
	z-index: -1;
}
.to-future__highlight {
	color: #0052a4;
	margin-right: 6px;
}

.to-future__brush {
	position: absolute;
	left: 50%;
	transform: translateX(-50%) translateY(6px);
	top: 100%;
	pointer-events: none;
	z-index: -1;
	width: 220px;
	height: auto;
}

.to-future__lead {
	font-size: 32px;
	font-weight: 600;
	margin: 0 0 35px;
	line-height: 1.4;
}

.to-future__text {
	font-size: 18px;
	line-height: 2.2;
}

@media (max-width: 1000px) {
	.history__content {
		padding: 30px 30px;
		font-size: 16px;
		line-height: 1.6;
	}
}

@media (max-width: 900px) {
	.history__timeline-nav-box {
		gap: 0px 13px;
	}
	.history__nav-item:before {
		width: 7px;
		right: -13px;
	}
}
@media (max-width: 768px) {
	.history__wrapper {
		width: 100%;
		padding: 0 0 20px;
		margin: 85px 0 0 0;
	}
	.history__area,
	.history__area02 {
		padding: 55px 0 50px;
	}
	.history__bg-title,
	.history__area02 .history__bg-title {
		font-size: 38px;
        top: -35px;
        right: 20px;
        left: auto;
	}
	.history__entry--right .history__content,
	.history__entry--left .history__content {
		right: auto;
        left: 56px;
        width: calc(100% - 57px);
        position: relative;
        margin: 0 0 30px 0;
        height: auto;
        padding: 23px 15px;
    }
	.history__entry {
		height: auto;
	}
	.history__space {
		display: none;
	}
	.history__line {
		left: 0;
		transform: translate(0, 0);
		width: 75px;
		margin: 0;
	}
	.history__year {
		position: absolute;
		left: -10px;
        top: 18px;
		transform: translate(0, 0);
		font-size: 24px;
	}

	.history__year::before{
		display: none;
	}
	.history__content {
		position: relative;
		transform: none;
		width: 100%;
		margin-left: 40px;
	}
	#history .history__content::before{
		top: 32px;
		border-top: 5px solid transparent;
		border-bottom: 5px solid transparent;
		right: auto;
		left: -10px;
		border-left: none;
		border-right: 11px solid #fbfbfb;
	}
	#history .history__area02 .history__content::before {
		border-right: 11px solid #eaeaea;
	}
	.history__content ul li {
		font-size: 15px;
        position: relative;
        padding-left: 14px;
		line-height: 1.4;
	}
	.history__content ul li:before {
		width: 7px;
    	height: 7px;
	}
	.history__images{
		margin-top: 25px;
	}
	.history__image01 {
		width: 41%;
	}
	.history__image02 {
		width: 45%;
	}
	.history__image03{
		width: 80%;
	}
	.history__image-txt{
		margin-top: 2px;
		font-size: 10px;
		line-height: 1.6;
	}
	.history__image-txt-right{
		margin-top: 2px;
		font-size: 10px;
		line-height: 1.6;
	}
	.history__arrow{
		display: block;
	}
	.history__timeline-nav {
		gap: 0px 20px;
	}
	.history__nav-ttl {
		padding-top: 16px;
		font-size: 21px;
		width: 100%;
		line-height: 1.2;
		position: relative;
		cursor: pointer;
		z-index: 3;
		display: block;
		text-align: center;
	}
	.history__nav-ttl::after {
		content: "";
		display: inline-block;  /* 要素に合わせて block や inline-block を使い分けてください */
		width: 0;
		height: 0;
		position: absolute;
		top: 0px;
		right: 50%;
		transform: translate(50%, 0);
		border-left: 10px solid transparent;   /* 底辺の両端 */
		border-right: 10px solid transparent;  /* 底辺の両端 */
		border-bottom: 10px solid #fff;        /* 三角形の頂点が上を向く */
		transition: 0.2s;
	}
	#history__nav-open:checked ~.history__nav-ttl::after {
		transform: translate(50%, 0) rotate(180deg);
	}
	.history__timeline-nav-box {
		gap: 0px 20px;
		left: 100px;
		position: absolute;
	}
	.history__nav-block{
		width: 350px;
		gap: 0px 0px;
		border-radius: 10px;
		padding: 10px 0;
		bottom: 30px;
		display: block;
	}
	.history__timeline-nav{
		width: 350px;
		height: 0;
		opacity: 0;
		padding: 0;
		position: relative;
		transition: 0.4s;
	}
	.history__timeline-nav-box {
		display: flex;
		width: 600px;                   /* アイテム数（4つ）×100% */
		transition: transform 0.4s ease;
	}
	#history__nav-open:checked ~ .history__timeline-nav{
		width: 350px;
		height: 0;
		opacity: 1;
		padding: 20px 0;
		height: 70px;
	}
	.history__nav-block {
		overflow: hidden; 
		max-width: 350px;  
		margin: 0 auto;
	}
	#history__nav-open:checked ~ .history__timeline-nav{
		width: 350px;
		height: 0;
		opacity: 1;
		padding: 20px 0;
		height: 70px;
	}
	.history__nav-block:after {
		content:"";
		z-index: 2;
		position: absolute;
		height: 100%;
		width: 100%;
		top:0;
		right: 0;
		background: linear-gradient(
		to right,
		rgba(0, 0, 0, 1) 0%,
		rgba(0, 0, 0, 0) calc((100% - 120px) / 2),
		rgba(0, 0, 0, 0) calc((100% - 120px) / 2),
		rgba(0, 0, 0, 0) calc((100% + 120px) / 2),
		rgba(0, 0, 0, 0) calc((100% + 120px) / 2),
		rgba(0, 0, 0, 1) 100%
		);
	}
	.history__nav-item {
		flex: 0 0 150px;                /* コンテナ幅と同じ幅 */
		display: flex;
		justify-content: center;
		align-items: center;
		pointer-events: none;
		transition-delay: 0.5s;
		padding: 0;
		font-size: 20px;
		font-weight: 400;
	}
	.history__nav-item.active {
		transition-delay: 0.5s;
		font-size: 30px;
	}
	.history__arrow {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		background: none;
		border: none;
		font-size: 20px;
		line-height: 1;
		color: #fff;
		cursor: pointer;
		padding: 0;
		z-index: 10;
		width: 30px;
		height: 30px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.history__arrow--left {
		left: 0.5rem;       
	}
	.history__arrow--left .arrow-box {
		width: 10px;
		height: 10px;
		border-top: solid 2px #fff ;
		border-right: solid 2px #fff ;
		transform: rotate(-130deg);
	}
	.history__arrow--right {
		right: 0.5rem;
	}
	.history__arrow--right .arrow-box {
		width: 10px;
		height: 10px;
		border-top: solid 2px #fff ;
		border-left: solid 2px #fff ;
		transform: rotate(130deg);
	}
	.history__arrow.disabled {
		opacity: 0.3;
		pointer-events: none;
	}
	.history__nav-item:after{
		width: 20px;
		content:"";
		background-color: #fff;
		width: 18px;
		height: 1px;
		right: -19px;
		position: absolute;
	}
	.history__nav-item:last-child::after,
	.history__nav-item::before{
		content:none;
	}
	.to-future {
		padding: 45px 5px 40px;
        margin: 0 auto 90px;
        width: 100%;
        max-width: 100%;
	}
	.to-future .inner1300{
        width: 100%;
        max-width: 100%;
	}
	.to-future__title-wrapper {
		margin-bottom: 47px;
	}

	.to-future__title {
		font-size: 38px;
	}
	.to-future__title img {
		bottom: -10px;
		width: 230px;
	}
	.to-future__highlight {
		color: #0052a4;
		margin-right: 4px;
	}
	.to-future__lead {
		font-size: 19px;
		margin: 0 0 20px;
		line-height: 1.4;
	}
	.to-future__text {
		font-size: 12px;
		line-height: 2.2;
	}
	
}

.recruit-bg01 {
	position: absolute;
	top: -200px;
	left: 0px;
	max-width: 420px;
}
.recruit-bg02 {
	position: absolute;
	bottom: 0;
	right: 0px;
	max-width: 315px;
}
.recruit__ttl-box02 {
	text-align: center;
}
.recruit__ttl01 {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	font-size: 52px;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.2rem;
}
.recruit__ttl01 span {
	color: #014898;
}
.recruit__ttl02 {
	font-size: 18px;
}
:root {
	--blue: #0a43a8;
	--blue-weak: #0e57d1;
	--text: #333;
	--gray: #777;
	--border: #e5e8ee;
	--bg: #f7f8fb;
}
/* ===== Hero ===== */
.recruit-hero {
	position: relative;
}
.hero-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 8px;
	padding: 12px 12px 0;
	background: #f2f4f8;
}
.hero-ph {
	aspect-ratio: 16/7;
	overflow: hidden;
	border-radius: 8px;
}
.hero-ph img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.hero-label {
	position: absolute;
	left: 24px;
	bottom: 18px;
	background: rgba(10, 67, 168, .95);
	color: #fff;
	padding: 16px 20px;
	border-left: 6px solid #fff;
}
.hero-label__en {
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 900;
	letter-spacing: .08em;
}
.hero-label__ja {
	font-size: 12px;
	margin-top: 4px;
	opacity: .9;
}

/* ===== Intro ===== */
.recruit-intro {
	position: relative;
	padding: 48px 0 24px;
	overflow: hidden;
}
.recruit__intro-layout {
	display: flex;
	align-items: center;
	width: 880px;
	max-width: 100%;
	margin: 77px auto;
	gap: 120px;
}
.recruit__intro-copy {
	width: 25%;
	position: relative;
}
.recruit__intro-copy:after {
	content: "";
	width: 1px;
	height: 1px;
	background: #000;
	position: absolute;
	top: 80%;
	right: 30%;
	transform-origin: top right;
	transform: translateY(20px) rotate(-25deg);
	transition: all 1.2s ease 1.2s;
	width: 1px;
	z-index: -1;
}
.recruit__intro-copy::before {
	content: "";
	width: 1px;
	height: 1px;
	background: #000;
	position: absolute;
	top: 10%;
	right: 98%;
	transform-origin: bottom right;
	transform: translateY(20px) rotate(35deg);
	transition: all 1.2s ease 1.2s;
	width: 1px;
	z-index: -1;
}
.show .recruit__intro-copy::before,
.show .recruit__intro-copy::after{
	width: 600px;

}
.recruit__intro-text {
	font-size: 23px;
	width: 60%;
	line-height: 2.4;
	margin-top: 137px;
}

/* ローカルナビ */
.recruit__local-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px 50px;
	margin-bottom: 50px;
	max-width: 100%;
}
.recruit__local-nav a {
	text-decoration: none;
	font-weight: bold;
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
	font-size: 18px;
	width: 260px;
	position: relative;
}
.recruit__local-nav a:before {
	content: "";
	background: #000;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	right: 0;
}
.recruit__local-nav a+a:after {
	content: "";
	background: #cccccc;
	width: 50px;
	height: 1px;
	position: absolute;
	bottom: -1px;
	left: -50px;
}
.company01__ttl-box {
	margin-bottom: 20px;
}


/* ===== OUR WORK ===== */
#work{
	padding-top: 45px;
}
.our-work {
	padding: 147px 0 250px;
	background: rgba(230, 230, 230, 0.6);
}
.our-work .inner1100 {
	position: relative;
	z-index: 2;
}
.our-work .inner1200 {
	position: relative;
	z-index: 1;
}
.our-work .inner1200:after {
	background: url(../image/common/bg01.png);
	content: "";
	box-shadow: 0px 0px 20px 1px rgba(0, 0, 0, 0.1);
	width: 100vw;
	position: absolute;
	left: 110px;
	top: -120px;
	z-index: -1;
	height: calc(100% + 150px);
}
.recruit-work-grid {
	display: flex;
	justify-content: space-between;
	margin-top: 40px;
	font-size: 16px;
	line-height: 2;
	z-index: 2;
	position: relative;
}
.recruit-work-lead-ttl {
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 10px;
	position: relative;
	width: fit-content;
	z-index: 2;
	position: relative;
}
.recruit-work-lead-ttl:before {
	background: #000;
	position: absolute;
	right: -70px;
	width: 50px;
	height: 1px;
	content: "";
	top: 50%;
	transform: translate(0 -50%);
}
.recruit__ttl-box {
	z-index: 2;
	position: relative;
}

.recruit__ttl-box-top45 {
	padding-top: 45px;
}
.recruit-work-lead-txt {
	line-height: 2;
	margin-bottom: 52px;
}
.recruit-work-photos {
	display: block;
	text-align: center;
	width: 42%;
	position: relative;
}
.recruit-work-photos-img {
	margin: 25px auto;
	padding: 0 50px;
}
.recruit-work-photos-img02 {
	margin: 30px auto 0;
	position: absolute;
}
.recruit-work-lead {
	width: 47%;
}

.recruit-bg03 {
	position: absolute;
	top: 2%;
	right: 0px;
	max-width: 364px;
	z-index: -1;
}
.recruit-bg04 {
	position: absolute;
	bottom: 20px;
	max-width: 502px;
	z-index: -1;
}

.recruit-interview {
	padding: 80px 0;
	position: relative;
	background: rgba(230, 230, 230, 0.6);
}
.recruit-interview-modal {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 999;
  transition: 0.4s;
}
.recruit-interview-modal input {
	display: none;
}
.recruit-interview-list {
	display: flex;
	flex-wrap: wrap;
	gap: 95px 30px;
	margin: 75px auto;
	justify-content: center;
}
.recruit-interview-item {
	width: calc(33.33% - 20px);
}
.recruit-interview-card {
	display: block;
	overflow: hidden;
}
.recruit-interview-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.card-meta {
	border-left: solid 1px #004898;
	padding: 40px 15px 15px;
	margin: -30px 0 0 20px;
	font-size: 26px;
	font-weight: 700;
	z-index: 1;
	position: relative;
}
.card-lead {
	font-weight: 700;
	font-size: 18px;
	padding: 10px 0;
	min-height: 70px;
	display: flex;
	align-items: center;
}
.card-name {
	font-size: 11px;
}
.card-sub {
	font-size: 18px;
	margin-top: 2px;
}
.card-sub span {
	font-size: 16px;
}
.card-plus {
	width: 40px;
	height: 40px;
	background: #000;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	bottom: 23px;
	right: 15px;
	border-radius: 100px;
}
.card-plus img {
	width: auto;
	height: auto;
}

.recruit__data {
	padding: 68px 0 50px;
}
.recruit__data-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 50px auto;
}
.recruit__data-grid-txt{
	text-align: right;
	margin-top: -15px;
	width: 100%;
}
.recruit__data-item01 {
	width: calc(50% - 10px);
}
.recruit__data-item01-border {
	border: 1px solid #ccc;
}
.recruit__data-item {
	width: 100%;
	padding: 30px 20px;
	border: 1px solid #ccc;
	position: relative;
}
.recruit__data-item01-border .recruit__data-item {
	border: none;
}
.recruit__data-item+.recruit__data-item {
	margin-top: 20px;

}
.recruit__data-num {
	font-size: 60px;
	text-align: center;
}
.recruit__data-num02 {
	text-align: center;
}
.recruit__data-item-flex {
	display: flex;
	justify-content: space-between;
	border: 1px solid #ccc;
}
.recruit__data-item-txt01 {
	margin: 60px auto 0;
	max-width: 335px;
	font-size: 30px;
	font-weight: 700;
	line-height: 1.4;
}
.recruit__data-num .num {
	font-size: 120px;
	font-weight: 700;
	color: #014898;
	line-height: 1;
}
.recruit__data-num .word {
	font-size: 50px;
	font-weight: 700;
}
.recruit__data-item-img {
	text-align: center;
}
.recruit__data-item-txt02 {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 700;
	font-size: 30px;
	margin: 30px auto;
	text-align: center;
}
.recruit__data-item-txt02-02 {
	line-height: 1.2;
}
.recruit__data-item-txt02 span.thank {
	font-size: 22px;
}
.recruit__data-item-txt02 span.num {
	font-size: 64px;
	color: #014898;
}
.recruit__data-item-txt02 span.year {
	font-size: 45px;
	color: #014898;
}
.recruit__data-num02 {
	width: 47%;
}
.recruit__data-item-img02 {
	width: 50%;
}
.recruit__data-item-img02 img {
	display: block;
	margin: 75px 0 10px;
}
.recruit__data-num02 .recruit__data-item-txt01 {
	margin: 15px auto 0 20px;
	font-size: 28px;
}
.recruit__data-cap {
	font-size: 18px;
}
.recruit__data-cap span {
	font-size: 27px;
}
.recruit__data-item-img02 {
	font-size: 16px;
}
.recruit__data-item-img03 {
	width: 47%;
}
.recruit__data-item-img03 img {
	display: block;
	margin: 20px 0 10px;
}
.recruit__data-item02 {
	width: calc(33.33% - 13.3334px);
}
.recruit__data-num03 .recruit__data-item-txt01 {
	margin: 15px auto 15px 20px;
	text-align: left;
}
.recruit__data-item .word {
	text-align: right;
	font-size: 36px;
}
.recruit__data-num03 .num02 {
	font-size: 110px;
}
.recruit__data-item-txt03 {
	font-size: 50px;
	color: #014898;
	margin-bottom: 15px;
}
.recruit__data-num03 .num03 {
	font-size: 100px;
}
.recruit__data-item02 .word {
	line-height: 1;
	margin-top: -15px;
	padding-bottom: 20px;
}
.recruit__data-item-txt04 {
	font-size: 30px;
	font-weight: 700;
	display: flex;
	align-items: start;
	margin: 0 30px;
}
.recruit__data-item-absolute01 {
	position: absolute;
	display: flex;
	align-items: center;
	gap: 10px;
	bottom: 20px;
	left: 20px;
}
.recruit__data-item-absolute02 {
	position: absolute;
	bottom: 20px;
	left: 20px;
}
.recruit__data-item-absolute03 {
	position: absolute;
	bottom: 20px;
	right: 20px;
}

.recruitment-tabs {
	max-width: 100%;
	display: flex;
	flex-wrap: wrap;
	background: #fff;
}

/* 全体ラッパー */
#requirements{
	padding-top: 45px;
}
.recruit__tabs-wrapper {
	display: flex;
	flex-wrap: wrap;
	background: #fff;
	margin: 72px auto;
}

/* タブラベル */
.recruit__tabs-wrapper>input[type="radio"] {
	display: none;
}
.recruit__tabs-wrapper>.recruit__tab-label {
	display: flex;
	flex: 1;
	justify-content: center;
	align-items: center;
	padding: 16px 0;
	background: #f2f2f2;
	color: #666;
	font-weight: bold;
	cursor: pointer;
	position: relative;
	border-right: 1px solid #ddd;
	width: 33.3333%;
}
.recruit__tabs-wrapper>.recruit__tab-label:last-of-type {
	border-right: none;
}
/* 選択中のタブ */
#tab-new:checked+.recruit__tab-label,
#tab-mid:checked+.recruit__tab-label,
#tab-part:checked+.recruit__tab-label {
	background: #000;
	color: #fff;
}
/* 選択中タブの下に逆三角 */
#tab-new:checked+.recruit__tab-label::after,
#tab-mid:checked+.recruit__tab-label::after,
#tab-part:checked+.recruit__tab-label::after {
	content: "";
	position: absolute;
	bottom: -8px;
	left: 50%;
	transform: translateX(-50%);
	border-left: 8px solid transparent;
	border-right: 8px solid transparent;
	border-top: 8px solid #000;
}

/* コンテンツ切替 */
.recruit__tab-content {
	margin-top: 24px;
	width: 100%;
}
.recruit__content {
	max-width: calc(100% - 20px);
	width: 1000px;
	margin: 0 auto;
	padding-top: 20px;
	display: none;
}
#tab-new:checked~.recruit__tab-content #new,
#tab-mid:checked~.recruit__tab-content #mid,
#tab-part:checked~.recruit__tab-content #part {
	display: block;
}

/* dl の横並び */
.recruit__details .recruit__item {
	display: flex;
	padding: 20px 0;
	border-bottom: 1px solid #e0e0e0;
	align-items: flex-start;
	width: 800px;
	max-width: 100%;
	margin: 0 auto;
}
.recruit__details .recruit__item:last-child {
	border-bottom: none;
}
.recruit__term {
	width: 28%;
	flex-shrink: 0;
	color: #02599c;
	font-weight: bold;
	font-size: 20px;
}
.recruit__desc {
	width: 72%;
}
.recruit__desc>div {
	margin-bottom: 8px;
}
.recruit__desc ul {
	list-style: disc inside;
	margin-top: 8px;
}
.recruit__label {
	font-weight: bold;
}
.recruit__note {
	font-size: 14px;
	color: #666;
	margin-top: 8px;
}

/* 研修制度 */
.recruit__training {
	background: #f2f2f2;
	padding: 40px;
	margin: 40px 0;
}
.recruit__training-title {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 16px;
}
.recruit__training-content{
	display: flex;
	gap:30px;
	margin-bottom: 30px;
}
.recruit__training-content-ttl{
	font-size: 16px;
    background: #014898;
    color: #fff;
    padding: 8px 10px;
    line-height: 1.2;
	width: 110px;
	font-weight: 700;
	text-align: center;
	height: 100%;
}
.recruit__training-content-txt{
	width: calc(100% - 140px);
	font-size: 16px;
    padding: 8px 0;
    line-height: 1.4;
	display: flex;
	height: 100%;
}
.recruit__content-none{
	padding: 30px 0 60px;
	font-size: 20px;
}
@media screen and (max-width: 769px) {
	.recruit__training-content{
		display: block;
		margin-bottom: 15px;
	}
	.recruit__training-content-txt{
		width: 100%;
	}
}
/* エントリーボタン */

.recruit__entry-btn {
	margin: 60px auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.recruit__entry-btn a {
	font-family: "Akshar", sans-serif;
	font-weight: 700;
	background: #000;
	color: #fff;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 240px;
	padding: 10px 20px 10px 30px;
	margin: 0 auto;
}
.recruit__entry-btn a img {
	transition: 0.2s;
}
.recruit__entry-btn a:hover img {
	transform: translate(5px, 0);
}

/* ===== INTERVIEW モーダル ===== */
.iv-modal {
	position: fixed;
	pointer-events: none;
	inset: 0;
	z-index: 9999;
  transition: 0.4s;
  opacity: 0;
}
input:checked+.iv-modal {
	pointer-events: auto;
  opacity: 1;
}
.iv-modal__bg {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .6);
	backdrop-filter: blur(2px);
  transition: 0.4s;
}
.iv-modal__dialog {
	position: relative;
	width: 1200px;
	max-width: 92svw;
	max-height: calc(88vh - 50px);
	margin: 0 auto 0;
	background: #fff;
	border-radius: 8px;
	overflow: auto;
	box-shadow: 0 20px 40px rgba(0, 0, 0, .35);
  transition: 0.4s;
}
.iv-modal__close-box {
	position: relative;
	width: 1200px;
	max-width: calc(100% - 40px);
	margin: 8vh auto 5px;
	text-align: right;
  transition: 0.4s;
}
.iv-modal__close {
	font-size: 40px;
	margin: 0 0 auto 10px;
	color: #fff;
	text-decoration: none;
	z-index: 3;
	line-height: 1;
}

/* 上部の青い帯＋人物写真 */
.iv-hero {
	position: relative;
	background: #014898;
	padding: 26px 26px 25px;
}
.iv-hero__ph {
	width: 1000px;
	max-width: 100%;
	text-align: right;
	margin: 25px auto;
}
.iv-hero__ph img {
	width: 90%;
}
.iv-hero__lead {
	padding: 25px 5px 40px;
	background: #014898;
	color: #fff;
	width: 450px;
	margin-top: -220px;
	text-align: left;
	font-size: 34px;
	position: relative;
	line-height: 1.4;
}
.iv-hero__lead .lead-txt {
	height: 140px;
	display: flex;
	align-items: center;
}
.lead-meta {
	border-left: solid 2px #fff;
	font-size: 12px;
	margin: 20px 0 0;
	padding: 8px 20px;
	font-size: 14px;
}
.lead-meta .year {
	display: block;
}
.lead-meta .department {
	font-size: 16px;
	display: inline-block;
	margin: 0 10px 0 0;
}
.lead-meta .name {
	font-size: 18px;
}
.lead-meta .notice {
	font-size: 12px;
	display: block;
}
/* 本文 */
.iv-body {
	background: #fff;
	width: 85%;
	margin: 0 auto 0;
	position: relative;
	z-index: 1;
	background: #fff;
}
.iv-outline {
	display: flex;
	flex-wrap: wrap;
	padding: 40px 60px 0;
	box-shadow: 0 6px 14px rgba(0, 0, 0, .12);
}
.iv-outline__hd {
	color: #014898;
	font-size: 18px;
	margin: 0 20px 30px 0;
}
.iv-outline__bd {
	font-size: 16px;
	margin-bottom: 30px;
	width: calc(100% - 65px);
	line-height: 2.2;
}

.iv-section {
	max-width: 820px;
	margin: 80px auto 80px;
}
.iv-section h3 {
	font-size: 24px;
}
.iv-section h3 span {
	color: var(--blue);
	font-family: "Akshar", sans-serif;
	font-size: 30px;
	margin-right: 30px;
}
.iv-section__txt {
	margin: 0 0 0 auto;
	max-width: 750px;
}
.iv-with-photo {
	max-width: 100%;
	display: flex;
	gap: 60px;
}
.iv-with-photo .iv-section__txt {
	margin-left: 30px;
}
.iv-section__content {
	width: 53%;
}
.iv-section__ph {
	width: 100%;
	margin: 0 auto;
	max-width: 780px;
}
/* スケジュール */
.iv-schedule {
	max-width: 860px;
	margin: 190px auto 100px;
	width: 100%;

}
.iv-schedule__list {
	margin-top: 12px;
}
.iv-schedule__list li {
	display: grid;
	grid-template-columns: 72px auto 1fr;
	gap: 14px;
	align-items: center;
	padding: 10px 8px;
	border-bottom: 1px dashed #d8deea;
}
.iv-schedule__list li:last-child {
	border-bottom: none;
}
.iv-schedule time {
	font-weight: 900;
	color: #3b5aa0;
}
.sch-tag {
	border: 1.5px solid var(--blue);
	color: var(--blue);
	font-weight: 700;
	font-size: 12px;
	padding: 4px 10px;
	border-radius: 999px;
}
.sch-tag.is-rest {
	background: #fff;
}
.sch-tag.is-end {
	background: var(--blue);
	color: #fff;
	border-color: var(--blue);
}

.r-anchor-target {
  scroll-margin-top: 80px;
}
@media (max-width: 1250px) {
.recruit__data-item-txt01 {
	font-size: 2.5vw;
}
.recruit__data-num {
	font-size: 5vw;
}
.recruit__data-num .num {
	font-size: 10vw;
}
.recruit__data-num .word {
	font-size: 4.16;
}
.recruit__data-item-txt02 {
	font-size: 2.5vw;
}
.recruit__data-item-txt02 span.thank {
	font-size: 1.83vw;
}
.recruit__data-item-txt02 span.num {
	font-size: 5.33vw;
}
.recruit__data-item-txt02 span.year {
	font-size: 3.75vw;
}
.recruit__data-num02 .recruit__data-item-txt01 {
	font-size: 2.33vw;
}
.recruit__data-cap {
	font-size: 1.5vw;
}
.recruit__data-cap span {
	font-size: 2.25vw;
}
.recruit__data-item-img02 {
	font-size: 1.33vw;
}
.recruit__data-item .word {
	font-size: 3vw;
}
.recruit__data-num03 .num02 {
	font-size: 9.16vw;
}
.recruit__data-item-txt03 {
	font-size: 3.16vw;
}
.recruit__data-num03 .num03 {
	font-size: 7.33vw;
}
.recruit__data-item-txt04 {
	font-size: 2.5vw;
}
.recruit__data-num03 .recruit__data-item-txt01 {
	margin: 15px auto 15px 0;
}
.recruit__data-item-txt04 {
    margin: 0 15px;
	padding: 0 0 10px;
}
.recruit__h100{
	height: 100%;
}
}

@media (max-width: 1024px) {
	.recruit__intro-layout {
		grid-template-columns: 1fr;
	}
	.recruit-work-grid {
		grid-template-columns: 1fr;
	}
	.recruit-interview-list {
		grid-template-columns: repeat(2, 1fr);
	}
	.iv-hero__lead {
		position: static;
		transform: none;
		width: auto;
		margin-top: 12px;
	}
	.iv-with-photo {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 640px) {
	.recruit__data-grid {
		grid-template-columns: 1fr 1fr;
	}
	.req-dl .row {
		grid-template-columns: 1fr;
	}
	.req-steps {
		grid-template-columns: 1fr;
	}
	.hero-grid {
		grid-template-columns: 1fr;
	}
	.iv-hero__lead {
		font-size: 30px;
	}
	
}

.recruit__career {
	background: #f2f2f2;
	padding: 40px;
}
.recruit__career__title {
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 14px;
}
.recruit__career__boxes {
	display: flex;
	align-items: flex-end;
}
.recruit__career__item {
	position: relative;
	flex: 1;
	text-align: center;
}
.recruit__career__step {
	position: absolute;
	top: -50px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 26px;
	font-weight: bold;
}
/* ボックス本体 */
.recruit__career__content {
	padding: 10px;
	color: #fff;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.recruit__career__content-center {
	width: 100%;
}
.recruit__career__heading {
	font-size: 30px;
	margin-bottom: 10px;
	text-align: center;
}
/* リスト */
.recruit__career__list {
	text-align: left;
	width: 90%;
	margin: 0 auto;
}
.recruit__career__list li {
	font-size: 16px;
	line-height: 1.4;
	text-indent: -16px;
	padding-left: 16px;
}

/*===== STEPごとの色・高さ =====*/
/* STEP01 */
.recruit__career__item--1 .recruit__career__content {
	background: #9cc3e3;
	height: 140px;
}
.recruit__career__item--1 .recruit__career__step {
	color: #9cc3e3;
}

/* STEP02 */
.recruit__career__item--2 .recruit__career__content {
	background: #5e8bc8;
	height: 200px;
}
.recruit__career__item--2 .recruit__career__step {
	color: #5e8bc8;
}

/* STEP03 */
.recruit__career__item--3 .recruit__career__content {
	background: #004b9b;
	height: 260px;
}
.recruit__career__item--3 .recruit__career__step {
	color: #004b9b;
}

.schedule {
	max-width: 700px;
	margin: 40px auto;
	padding: 0 20px;
}

.title {
	text-align: center;
	font-size: 2rem;
	margin-bottom: 40px;
}
.title span {
	color: #0046b8;
}
.title small {
	display: block;
	font-size: 0.8rem;
	color: #666;
}

.timeline {
	border-left: 4px solid #666;
	position: relative;
	margin-left: 150px;
	margin-top: 50px;
}

.time-block {
	position: relative;
	margin-bottom: 40px;
}

.time-block::before {
	content: "";
	position: absolute;
	top: 35px;
	left: -12px;
	width: 20px;
	height: 20px;
	background: #0046b8;
	border-radius: 50%;
	z-index: 1;
}

.time-block_02 {
	position: relative;
	margin-bottom: 23px;
	min-height: 80px;
}
.time-block_02:first-child {
	margin-bottom: 72px;
}

.time-block_02::before {
	content: "";
	position: absolute;
	top: -6px;
	left: -53px;
	width: 100px;
	height: 100px;
	background: #fff;
	border: solid #0046b8 3px;
	border-radius: 50%;
	z-index: 1;
}

.time {
	font-weight: bold;
	color: #0046b8;
	margin-bottom: 5px;
	line-height: 1.2;
	position: absolute;
	right: calc(100% + 40px);
	top: 35px;
	font-size: 20px;
}

.time_02 {
	font-weight: bold;
	color: #0046b8;
	margin-bottom: 5px;
	line-height: 1.2;
	position: absolute;
	right: calc(100% + 75px);
	top: 35px;
	font-size: 20px;
}

.time_ttl {
	font-weight: bold;
	color: #0046b8;
	line-height: 1.2;
	position: absolute;
	top: -3px;
	left: -54px;
	width: 100px;
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	z-index: 2;
}

.time.icon {
	background-color: #0046b8;
	color: #fff;
	width: 70px;
	height: 70px;
	border-radius: 50%;
	text-align: center;
	padding-top: 14px;
	font-size: 1rem;
	font-weight: bold;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.time.icon span {
	font-size: 0.75rem;
	margin-top: 2px;
}

.desc {
	padding: 15px 60px;
	margin-left: 80px;
	background: #ebebeb;
	position: relative;
	min-height: 90px;
	display: flex;
	align-items: center;
}
.desc:before {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
	left: -20px;
	border-right: 20px solid #ebebeb;
	z-index: 1;
}
.desc02 {
	padding: 10px 15px;
	margin-left: 10px;
}
.time-block_02-center {
	margin: 70px 0px;
}
.scroll-infinity {
	margin-bottom: 75px;
	overflow: hidden;
}
.scroll-infinity__wrap {
	display: flex;
	width: fit-content;
}
.scroll-infinity__list--left {
	animation: infinity-scroll-left 80s infinite linear 0.5s both;
}
.scroll-infinity__list {
	display: flex;
	list-style: none;
	width: max-content;
}
.scroll-infinity__list img {
	width: 100%;
	height: 380px;
	margin: 0 10px;
}
@media screen and (max-width: 1300px) {
	.recruit__local-nav {
		width: 600px;
		margin: 0 auto 10px;
	}
	.recruit__local-nav a:nth-child(2n - 1)::after {
		content: none;
	}
}
@media screen and (max-width: 1000px) {
	.recruit__career__content {
		padding: 10px;
	}
	.recruit__career__heading {
		font-size: 24px;
		margin-bottom: 5px;
		line-height: 1.4;
	}
	.recruit__career__list li {
		font-size: 14px;
	}
	.our-work {
		padding: 147px 0 150px;
	}
}
@media screen and (max-width: 769px) {
	.recruit-bg01 {
		top: -20px;
		max-width: 100px;
	}
	.recruit-bg02 {
		max-width: 100px;
	}
	.recruit-bg03 {
		max-width: 120px;
	}
	.recruit-bg04 {
		max-width: 120px;
	}
	.recruit__intro-layout {
		max-width: 100%;
		display: block;
		gap: 15px;
		margin: 0 auto 30px;
	}
	.recruit__intro-text {
		font-size: 16px;
		margin-top: 20px;
		width: 100%;
	}
	.recruit__intro-copy {
		width: 360px;
		max-width: 100%;
	}

	.recruit__intro-copy:after {
		transform: translateY(20px) rotate(-45deg);
		width: 600px;
		z-index: -1;
		opacity: 0;
	}
	.recruit__intro-copy::before {
		transform: translateY(10px) rotate(45deg);
		opacity: 0.3;
		top: 0;
    	right: 30%;
	}
	.our-work {
		padding: 40px 0 40px;
		background: url(../image/common/bg01.png);
	}
	.our-work .inner1200:after {
		content: none;
	}
	.recruit__local-nav {
		gap: 20px 10px;
		margin-bottom: 10px;
	}
	.recruit__local-nav a {
		width: calc(50% - 20px);
		padding: 10px 0;
		font-size: 16px;
		display: flex;
        align-items: center;
	}

	.recruit__local-nav a+a:after {
		width: 10px;
		left: -10px;
	}
	.recruit__local-nav img {
		width: 30px;
		height: 30px;
	}
	.recruit__ttl01 {
		font-size: 26px;
	}
	.recruit__ttl02 {
		font-size: 12px;
	}
	.recruit-work-grid {
		display: block;
		margin-top: 20px;
	}
	.recruit-work-photos {
		width: 100%;
	}
	.recruit-work-photos-img {
		margin: 20px auto;
		padding: 0 0;
	}
	.recruit-work-photos-img02 {
		margin: 20px auto 0;
		position: static;
	}
	.recruit-work-lead {
		width: 100%;
		margin-top: 20px;
	}
	.recruit-work-lead-txt {
		margin-bottom: 20px;
	}
	.recruit-interview {
		padding: 40px 0;
	}
	.recruit-interview-list {
		gap: 40px 20px;
		margin: 30px auto;
	}
	.recruit-interview-item {
		width: calc(50% - 10px);
	}
	.card-meta {
		padding: 20px 10px 10px;
		margin: -10px 0 0 10px;
		font-size: 20px;
		font-weight: 700;
	}
	.card-name {
		width: calc(100% - 40px);
	}
	.card-sub {
		font-size: 16px;
		width: calc(100% - 40px);
	}
	.card-plus {
		width: 30px;
		height: 30px;
	}
	.card-plus img {
		width: 15px;
		height: 15px;
	}
	.recruit__data {
		padding: 40px 0 40px;
	}
	.recruit__data-item01 {
		width: 100%;
	}
	.recruit__data-grid {
		margin: 30px auto;
	}
	.recruit__data-item-txt01,
	.recruit__data-num02 .recruit__data-item-txt01 {
		margin: 0 auto 0;
		font-size: 20px;
	}
	.recruit__data-num .num {
		font-size: 50px;
	}
	.recruit__data-item .word {
		font-size: 20px;
	}
	.recruit__data-item-txt02 {
		font-size: 18px;
		margin: 20px auto;
	}
	.recruit__data-item-txt02 span.thank {
		font-size: 18px;
	}
	.recruit__data-item-txt02 span.num {
		font-size: 30px;
	}
	.recruit__data-item-txt02 span.year {
		font-size: 26px;
	}
	.recruit__data-item-flex {
		display: block;
	}
	.recruit__data-num {
		width: 100%;
	}
	.recruit__data-item-img02 {
		width: 100%;
	}
	.recruit__data-item-img02 img {
		display: block;
		margin: 20px 0 10px;
	}
	.recruit__data-item-img02 {
		width: 60%;
		margin: 0 auto;
	}
	.recruit__data-item-img03 {
		width: 60%;
		margin: 0 auto;
	}
	.recruit__data-item-absolute03 {
		width: 100px;
	}
	.recruit__data-item02 {
		width: 100%;
	}
	.scroll-infinity {
		margin-bottom: 30px;
	}
	.scroll-infinity__list img {
		height: 200px;
	}
	.recruit__tabs-wrapper {
		margin: 30px auto;
	}
	.recruit__term {
		width: 130px;
		font-size: 16px;
	}
	.recruit__desc {
		width: 100%;
	}
	.recruit__details .recruit__item {
		padding: 5px 0;
		display: block;
	}
	.recruit__career {
		background: #f2f2f2;
		padding: 40px 20px;
	}
	.recruit__career__heading {
		font-size: 20px;
	}
	.recruit__career__list li {
		font-size: 12px;
	}
	.recruit__career__list {
		width: 100%;
	}
	.recruit__career__step {
		font-size: 20px;
		top: -30px;
	}
	.recruit__career__boxes {
		display: block;
	}
	.recruit__career__item--1 .recruit__career__content {
		height: auto;
		margin-top: 50px;
	}
	.recruit__career__item--2 .recruit__career__content {
		height: auto;
		margin-top: 50px;
	}
	.recruit__career__item--3 .recruit__career__content {
		height: auto;
		margin-top: 50px;
	}
	.iv-section {
		max-width: 780px;
		margin: 40px auto 40px;
	}
	.iv-section h3 {
		font-size: 18px;
	}
	.iv-section h3 span {
		font-size: 20px;
		margin-right: 10px;
	}
	.iv-schedule {
		margin: 60px auto 100px;
	}
	.schedule {
		max-width: 700px;
		margin: 40px auto;
		padding: 0 20px;
	}
	.timeline {
		margin-left: 80px;
	}

	.time-block {
		position: relative;
		margin-bottom: 40px;
	}

	.time-block::before {
		top: 14px;
	}
	.time-block_02 {
		margin-bottom: 15px;
		min-height: 40px;
	}
	.time-block_02:first-child {
		margin-bottom: 30px;
	}
	.time-block_02:last-child {
		margin-bottom: 0;
	}
	.time-block_02::before {
		top: -1px;
		left: -29px;
		width: 50px;
		height: 50px;
	}

	.time {
		right: calc(100% + 30px);
		top: 12px;
	}
	.time_02 {
		right: calc(100% + 40px);
		top: 12px;
	}
	.time_ttl {
		top: -1px;
		left: -28px;
		width: 50px;
		height: 50px;
		font-size: 14px;
	}
	.desc {
		padding: 13px 20px;
		margin-left: 38px;
		min-height: auto;
	}
	.desc:before {lead-txt
		top: 24px;
		border-top: 10px solid transparent;
		border-bottom: 10px solid transparent;
		left: -10px;
		border-right: 10px solid #ebebeb;
	}
	.desc02 {
		padding: 10px 15px;
		margin-left: 10px;
		border-radius: 8px;
	}

	.time-block_02-center {
		margin: 40px 0px;
	}
	.iv-modal__dialog {
		max-height: calc(100% - 90px);
		max-width: calc(100% - 60px);
	}
	.iv-modal__close-box {
		margin: 30px auto -18px;
        z-index: 2;
	}
	.iv-modal__close {
		font-size: 40px;
		margin: 0 10px auto 10px;
	}
	.iv-hero__ph {
		margin: 5px auto;
	}
	.iv-hero__ph img {
		width: 100%;
	}
	.iv-hero__lead {
		padding: 0 5px 20px;
		font-size: 24px;
		position: relative;
	}
	.recruit__data-cap {
		font-size: 18px;
	}
	.recruit__data-cap span {
		font-size: 27px;
	}
	.recruit__data-item-img02 {
		font-size: 16px;
	}
	.recruit__data-item-txt04 {
		font-size: 20px;
		justify-content: center;
	}
}

@media screen and (max-width: 500px) {
	.recruit-interview-item {
		width: 100%;
	}
	.iv-hero__lead {
		font-size: 17px;
	}
	.iv-hero__lead .lead-txt {
		height: 110px;
	}
}
@keyframes infinity-scroll-left {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-100%);
	}
}

.policy-area h2{
	margin:28px 0 30px;
	padding-left:12px;
	border-left:4px solid #000088;
	font-size:26px;
	line-height: 1.2;
	font-weight:900;
}
.policy-area h3{
	margin:20px 0 15px;
	font-size:22px;
	font-weight:800;
}
.policy-area p{
	margin-bottom: 30px;
}
.policy-area ul { 
	padding-left: 40px;
    list-style: disc;
	margin: -10px 0 30px;
}
@media screen and (max-width: 769px) {
	.policy__st-span01{
		position: absolute;
		bottom: -15px;
	}
}

@media (max-width: 420px) {
	.policy__subpage_ttl{
		top: 89px;
	}
}

@media (max-width: 720px){
	.news-article h2 {
	font-size: 22px;
	}
	.news-article h3 {
	font-size: 20px;
	}
}