@charset "utf-8";
section {
		padding: 110px 30px;
}
section.strength_section {
		padding-left: 20px;
		padding-right: 20px;
}
@media(max-width: 960px) {
		section {
				padding: 80px 30px;
		}
}
@media(max-width: 767px) {
		section {
				padding: 60px 20px;
		}
}
.develop_section {
		background: #224BA1;
		overflow: hidden
}
.strength_section, .case_section {
		background: #E6ECF0;
}
section hgroup {
		text-align: center;
		margin: 0 0 50px;
}
section hgroup h2 {
		font-size: 44px;
		font-weight: 700;
		line-height: 1;
		color: #353e4a;
		margin: 0 0 20px;
}
section hgroup p {
		font-family: "Poppins";
		font-weight: 700;
		font-size: 22px;
		color: #224BA1;
}
@media(max-width: 1200px) {
		section hgroup h2 {
				font-size: 34px;
				margin: 0 0 15px;
		}
		section hgroup p {
				font-size: 18px;
		}
}
@media(max-width: 767px) {
		section hgroup {
				margin-bottom: 30px;
		}
		section hgroup h2 {
				font-size: 26px;
				margin: 0 0 10px;
		}
		section hgroup p {
				font-size: 16px;
		}
}
section.develop_section hgroup h2 {
		color: #fff;
}
section.develop_section hgroup p {
		color: #C2D3D8;
}
section hgroup + p {
		line-height: 2.0;
		font-size: 115%;
		text-align: center;
		font-weight: 500;
		margin: 0 0 40px;
		opacity: 0;
		transition: opacity 0.35s;
}
section.strength_section hgroup.fadeInNmlActive + p {
		opacity: 1;
}
@media screen and (orientation: portrait) and (max-width: 767px) {
		section hgroup + p {
				text-align: left;
		}
		section hgroup + p br {
				display: none
		}
}
@media screen and (orientation: portrait) and (max-width: 767px) {
		section hgroup + p {
				margin: 0 0 30px;
		}
}
/* ============= */
section.business_section {
		padding-left: 20px;
		padding-right: 20px;
}
.step_flex {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		max-width: 1350px;
		margin: 0 auto;
}
.step-item {
		width: 225px;
		transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s;
		transform: translateX(-100px);
		opacity: 0;
}
.step-item::after {
		content: '';
		display: block;
		position: relative;
		left: 50%;
		width: 100%;
		height: auto;
		aspect-ratio: 10 / 3.12;
		background-repeat: no-repeat;
		background-position: left bottom;
		background-size: 100%;
		background-image: url("../images/step-1_caption.png");
		transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
		transform: translateX(-80px);
}
.step_flex .step-item:nth-child(2) {
		transition-delay: 0.15s
}
.step_flex .step-item:nth-child(3) {
		transition-delay: 0.3s
}
.step_flex .step-item:nth-child(4) {
		transition-delay: 0.45s
}
.step_flex .step-item:nth-child(5) {
		transition-delay: 0.6s
}
.step_flex .step-item:nth-child(6) {
		transition-delay: 0.75s
}
.step_flex .step-item:nth-child(2)::after {
		background-image: url("../images/step-2_caption.png");
}
.step_flex .step-item:nth-child(3)::after {
		background-image: url("../images/step-3_caption.png");
}
.step_flex .step-item:nth-child(4)::after {
		background-image: url("../images/step-4_caption.png");
}
.step_flex .step-item:nth-child(5)::after {
		background-image: url("../images/step-5_caption.png");
}
.step_flex .step-item:nth-child(6)::after {
		display: none
}
.isActive .step-item {
		opacity: 1;
		transform: translateX(0)
}
.isActive .step-item::after {
		transform: translateX(0)
}
.step-item img {
		width: 100%;
		height: auto;
}
.area_figure {
		max-width: 1365px;
		margin: 0 auto
}
.area_figure img {
		width: 100%;
		height: auto;
}
@media(max-width: 1400px) {
		.step-item {
				width: calc(100% / 6);
		}
}
@media(max-width: 960px) {
		.step_flex {
				padding-left: 0;
				padding-right: 0;
		}
}
@media screen and (orientation: landscape) and (max-width: 1000px) {
		.step_flex {
				padding-left: 12vw;
				padding-right: 12vw;
		}
}
@media(max-width: 767px) {
		section.business_section {
				padding-left: 20px;
				padding-right: 20px;
		}
		.step_flex {
				padding-left: 0;
				padding-right: 0;
		}
}
@media screen and (orientation: portrait) and (max-width: 767px) {
		.step-item {
				width: calc(100% / 3);
				margin: 0 0 15px
		}
		.step-item::after {
				left: 0
		}
}
/* ============= */
.strength_flex {
		max-width: 1270px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
}
.strength_item {
		width: 280px;
		aspect-ratio: 1 / 1;
		position: relative;
		display: flex;
		justify-content: center;
		align-items: center;
		opacity: 0;
		transform: scale(1.25);
		transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.25s;
}
.strength_flex .strength_item:nth-child(2) {
		transition-delay: 0.15s;
}
.strength_flex .strength_item:nth-child(3) {
		transition-delay: 0.3s;
}
.strength_flex .strength_item:nth-child(4) {
		transition-delay: 0.45s;
}
.isActive .strength_item {
		opacity: 1;
		transform: scale(1);
}
.strength_item_in {
		padding-top: 25px;
}
.strength_item::before {
		content: '';
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		border-radius: 50%;
		background: #fff;
		z-index: 0
}
.strength_item::after {
		content: '1';
		display: block;
		position: absolute;
		top: 17px;
		left: 30px;
		font-size: 42px;
		font-family: "Poppins";
		color: #224ba1;
		font-weight: 700;
}
.strength_flex .strength_item:nth-child(2)::after {
		content: '2';
}
.strength_flex .strength_item:nth-child(3)::after {
		content: '3';
}
.strength_flex .strength_item:nth-child(4)::after {
		content: '4';
}
.strength_thumb {
		width: 185px;
		margin: 0 auto 15px;
		position: relative;
		z-index: 1
}
.strength_thumb img {
		width: 100%;
		height: auto;
}
.strength_item_in {
		padding-top: 15px;
}
.strength_item p {
		text-align: center;
		line-height: 1.6;
		font-weight: 600;
		position: relative;
		z-index: 1;
		font-size: 115%;
}
@media(max-width: 1300px) {
		.strength_item::after {
				top: 1.5vw;
				left: 1.8vw;
				font-size: 3.5vw;
		}
		.strength_item {
				width: calc(calc(100% - 80px) / 4);
		}
		.strength_item_in {
				padding-top: 5px;
		}
		.strength_thumb {
				width: 64%;
				margin: 0 auto 5px;
				position: relative;
				z-index: 1
		}
}
@media(max-width: 1100px) {
		.strength_item {
				width: calc(calc(100% - 60px) / 4);
		}
		.strength_item p {
				font-size: 1.6vw;
		}
}
@media screen and (orientation: portrait) and (max-width: 767px) {
		.strength_flex {
				display: flex;
				justify-content: space-between;
				flex-wrap: wrap;
		}
		.strength_item_in {
				padding-top: 0;
				margin-top: -10px;
		}
		.strength_item {
				width: calc(50% - 8px);
				margin-bottom: 16px;
		}
		.strength_thumb {
				width: 70%;
				margin: 0 auto 5px;
		}
		.strength_item::after {
				top: 4vw;
				left: 4vw;
				font-size: 24px;
		}
		.strength_item p {
				font-size: 13px;
		}
}
/* ============= */
.dev_wrap {
		max-width: 1100px;
		margin: 0 auto;
		position: relative;
}
.dev_wrap::before, .dev_wrap::after {
		content: '';
		display: block;
		position: absolute;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: 100%;
		z-index: 0;
		pointer-events: none;
}
.dev_wrap::before {
		background-image: url("../images/service_dev_bg-1.png");
		width: 235px;
		height: 245px;
		right: -300px;
		top: -160px;
}
.dev_wrap::after {
		background-image: url("../images/service_dev_bg-2.png");
		width: 450px;
		height: 350px;
		bottom: -30px;
		left: -400px;
}
@media(max-width: 960px) {
		.dev_wrap::before {
				width: 120px;
				height: 125px;
				right: -80px;
				top: 60px;
		}
		.dev_wrap::after {
				width: 225px;
				height: 175px;
				bottom: -50px;
				left: -100px;
		}
}
.dev_inner {
		background: #fff;
		border-radius: 8px;
		box-sizing: border-box;
		padding: 40px 70px;
		position: relative;
		z-index: 1
}
.dev_inner table {
		width: 100%;
}
.dev_inner .wp-block-table td, .dev_inner .wp-block-table th {
		border: none;
		padding: 18px 0;
		border-bottom: 1px solid #C2D3D8;
		line-height: 2.0;
}
.dev_inner .wp-block-table tr:last-child td {
		border: none;
}
.dev_inner .wp-block-table tr td:first-child {
		width: 16%;
		font-weight: 700;
}
@media(max-width: 1200px) {
		.dev_inner {
				padding: 30px;
		}
}
@media(max-width: 960px) {
		.dev_inner .wp-block-table td, .dev_inner .wp-block-table th {
				font-size: 15px;
		}
}
@media(max-width: 767px) {
		.dev_inner {
				padding: 15px;
		}
		.dev_inner .wp-block-table td, .dev_inner .wp-block-table th {
				display: block;
				padding: 0;
				border: none;
				width: auto;
		}
		.dev_inner .wp-block-table tr td:first-child {
				padding: 12px 0 5px;
				width: auto;
				font-size: 17px;
		}
		.dev_inner .wp-block-table tr td:nth-child(2) {
				padding-bottom: 12px;
				border-bottom: 1px solid #C2D3D8 !important;
		}
}
/* ============= */
.case_wrap {
		max-width: 1100px;
		margin: 0 auto 35px;
		display: flex;
		align-items: center;
		background: #3356A1;
		border-radius: 8px 0 0 8px;
}
.case_section .case_wrap:nth-of-type(even) {
		background: #607FC1;
}
.case_wrap h3 {
		width: 150px;
		font-size: 18px;
		color: #fff;
		font-weight: 500;
		text-align: center;
}
.case_wrap .wp-block-table {
		background: #fff;
		padding: 20px 30px;
		flex: 1;
		box-sizing: border-box;
		margin: 0 !important
}
.case_wrap table {
		width: 100%;
}
.case_wrap .wp-block-table td, .case_wrap .wp-block-table th {
		border: none;
		padding: 12px 0;
		border-bottom: 1px solid #C2D3D8;
		line-height: 2.0;
}
.case_wrap .wp-block-table tr:last-child td {
		border: none;
}
.case_wrap .wp-block-table tr td:first-child {
		width: 20%;
		font-weight: 600;
}
.case_wrap .wp-block-table tr td:nth-child(2) {
		width: 25%;
}
@media(max-width: 960px) {
		.case_wrap .wp-block-table {
				padding: 10px 20px;
		}
		.case_wrap h3 {
				width: 120px;
				font-size: 16px;
		}
		.case_wrap .wp-block-table td, .case_wrap .wp-block-table th {
				padding: 10px 0;
				font-size: 15px;
		}
}
@media(max-width: 767px) {
		.case_wrap h3 {
				font-size: 17px;
		}
}
@media screen and (orientation: portrait) and (max-width: 767px) {
		.case_wrap {
				display: block;
				background: none !important;
		}
		.case_wrap h3 {
				width: auto;
				font-size: 17px;
				font-weight: 700;
				color: #fff;
				text-align: left;
				padding: 15px 10px;
				border-radius: 6px 6px 0 0;
				background: #3356A1;
		}
		.case_section .case_wrap:nth-of-type(even) h3 {
				background: #607FC1;
		}
		.case_wrap .wp-block-table {
				padding: 0 15px;
		}
		.case_section .case_wrap table tr {
				display: flex;
				flex-wrap: wrap;
		}
		.case_section .case_wrap table td {
				box-sizing: border-box;
		}
		/* 1列目 */
		.case_section .case_wrap table td:nth-child(1) {
				border: none;
				width: auto;
				padding: 15px 15px 2px 0;
				font-weight: 700;
				font-size: 17px;
		}
		/* 2列目 */
		.case_section .case_wrap table td:nth-child(2) {
				border: none;
				width: auto;
				padding: 15px 0 2px;
				font-size: 16px;
				font-weight: 700;
		}
		/* 3列目 */
		.case_section .case_wrap table td:nth-child(3) {
				display: block;
				width: 100%;
				padding: 0 0 15px;
		}
}