@charset "UTF-8";

.common-title.type01 {
	background: url("../../img/page/about/banner.jpg") no-repeat center / cover;
}

#about {
	padding-top: 15rem;
	padding-bottom: 15rem;

	@media screen and (max-width: 767px) {
		padding-top: 6rem;
		padding-bottom: 6rem;
	}

	.top-section {
		padding-bottom: 14.9rem;

		.top-text-img {
			width: 104.9rem;
			margin: 0 auto 5.4rem;
		}

		.top-description {
			font-family: var(--noto);
			font-style: normal;
			font-weight: 500;
			font-size: 1.8rem;
			line-height: 250%;
			text-align: center;
			letter-spacing: 0.08em;
			color: #000000;
			@media screen and (max-width: 767px) {
				font-size: 1.6rem;
				letter-spacing: 0.06em;
			}
		}

		@media screen and (max-width: 767px) {
			padding-bottom: 7.4rem;
			.top-text-img {
				width: 20rem;
				margin: 0 auto 5.35rem;
			}
		}
	}
}

#business {
	background-color: #f8f8f8;
	padding-top: 13.5rem;
	padding-bottom: 10rem;

	@media screen and (max-width: 767px) {
		padding-top: 5rem;
		padding-bottom: 5rem;
	}

	.flex-block {
		display: flex;
		gap: 10rem;
		width: 100%;
		padding-bottom: 15rem;

		@media screen and (max-width: 767px) {
			gap: 5rem;
			padding-bottom: 5rem;
			flex-direction: column;
		}

		.text-contents {
			width: 55%;

			.header {
				font-family: "Noto Sans JP";
				font-style: normal;
				font-weight: 700;
				font-size: 3.4rem;
				line-height: 150%;
				letter-spacing: 0.03em;
				color: #000000;
				padding-bottom: 2rem;
			}

			.description {
				font-family: "Noto Sans JP";
				font-style: normal;
				font-weight: 400;
				font-size: 1.8rem;
				line-height: 200%;
				letter-spacing: 0.08em;
				color: #000000;
			}

			@media screen and (max-width: 767px) {
				width: 100%;
				order: 1;

				.header {
					font-size: 1.8rem;
				}

				.description {
					font-size: 1.6rem;
				}
			}
		}

		.img-contents {
			width: 35%;

			@media screen and (max-width: 767px) {
				width: 100%;
				order: 0;
			}
		}

		.num-title-flex {
			.num {
				font-size: 5rem;

				@media screen and (max-width: 767px) {
					font-size: 4.087rem;
				}
			}

			.title {
				font-size: 2rem;

				@media screen and (max-width: 767px) {
					font-size: 1.6rem;
				}
			}
		}
	}
	.flex-block.last {
		padding-bottom: 0;
	}
	.white-card {
		background-color: #fff;
		padding: 8rem 7.9rem;
		box-sizing: border-box;
		@media screen and (max-width: 767px) {
			padding: 3rem 2rem;

			/* &:first-child {
                padding-top: 3rem;
            } */
		}

		.flex-block {
			display: flex;
			justify-content: space-between;
			gap: 9rem;
			width: 100%;
			max-width: 124rem;
			/* padding-bottom: 8rem; */

			@media screen and (max-width: 767px) {
				flex-direction: column;
				gap: 1.6rem;
				padding-bottom: 5rem;

				&:last-child {
					padding-bottom: 0;
				}
			}

			.text-contents {
				width: 61rem;

				@media screen and (max-width: 767px) {
					width: 100%;
				}
			}

			.num-title-flex {
				display: flex;
				gap: 4rem;
				align-items: center;
				padding-bottom: 3rem;
				margin-bottom: 3rem;
				border-bottom: 1px solid #c3c3c3;

				@media screen and (max-width: 767px) {
					gap: 1.5rem;
					padding-bottom: 2rem;
					margin-bottom: 2.1rem;
					align-items: flex-start;
				}

				.num {
					font-family: "Poppins", sans-serif;
					font-style: normal;
					font-weight: 600;
					font-size: 10.2rem;
					letter-spacing: -0.01em;
					color: #e50012;
					white-space: nowrap;

					@media screen and (max-width: 767px) {
						font-size: 4.5rem;
					}
				}

				.title {
					font-family: "Noto Sans JP";
					font-style: normal;
					font-weight: 700;
					font-size: 3.2rem;
					line-height: 139%;
					letter-spacing: 0.03em;
					color: #000000;

					@media screen and (max-width: 767px) {
						font-size: 2.133rem;
					}
				}
			}

			.description {
				font-family: "Noto Sans JP";
				font-style: normal;
				font-weight: 400;
				font-size: 1.8rem;
				line-height: 200%;
				letter-spacing: 0.08em;
				color: #000000;

				@media screen and (max-width: 767px) {
					font-size: 1.4rem;
				}
			}

			.img-contents {
				width: 54rem;

				@media screen and (max-width: 767px) {
					width: 100%;
					order: 0;
				}
				& img {
					width: 100%;
				}
			}
		}

		.flex-block.reverse {
			flex-direction: row-reverse;

			@media screen and (max-width: 767px) {
				flex-direction: column;
			}
		}
	}
}

#overview {
	padding-top: 12.6rem;

	@media screen and (max-width: 767px) {
		padding-top: 5rem;
	}

	.overview-table {
		width: 120rem;
		max-width: 100%;
		margin: 0 auto;

		@media screen and (max-width: 767px) {
			width: 100%;
		}

		& tbody > tr {
			width: 100%;
			display: flex;
			padding: 3rem 0;
			border-bottom: 1px solid #cccccc;

			@media screen and (max-width: 767px) {
				flex-direction: column;
				gap: 2rem;

				&:first-child {
					padding-top: 0;
				}
			}
		}

		& tbody > tr > th {
			width: 20%;
			font-family: "Noto Sans JP";
			font-style: normal;
			font-weight: 600;
			font-size: 2rem;
			line-height: 3rem;
			letter-spacing: 0.1em;
			color: #e50012;
			text-align: left;
			vertical-align: top;
			@media screen and (max-width: 767px) {
				width: 100%;
				font-size: 1.8rem;
			}
		}

		& tbody > tr > td {
			font-family: "Noto Sans JP";
			font-style: normal;
			font-weight: 400;
			font-size: 1.8rem;
			line-height: 180%;
			letter-spacing: 0.08em;
			color: #000000;
			text-align: left;
			vertical-align: top;
			@media screen and (max-width: 767px) {
				font-size: 1.6rem;
			}
			& a {
				font-family: "Noto Sans JP", sans-serif;
				font-style: normal;
				font-weight: 400;
				font-size: 1.8rem;
				line-height: 190%;
				letter-spacing: 0.02em;
				color: #e50012;
				padding-left: 2.4rem;
				margin-left: 1rem;
				position: relative;
				transition: all 0.3s ease-in;
				&::before {
					content: "";
					position: absolute;
					left: 0;
					top: 50%;
					transform: translateY(-50%);
					width: 1.4rem;
					height: 1.966rem;
					background: url("../../img/page/about/pin.png") no-repeat center / 100% auto;
				}
				&:hover {
					opacity: 0.75;
				}
			}
		}
	}
}

iframe {
	margin-top: 2rem;
	width: 60rem;
	height: 35rem;
	@media screen and (max-width: 767px) {
		margin-top: 1rem;
		width: 100%;
		height: 24rem;
	}
}
