@charset "UTF-8";

#first-view {
	.contents-flex {
		display: flex;
		justify-content: space-between;
		@media screen and (max-width: 767px) {
			flex-direction: column-reverse;
		}
		.text-contents {
			width: 66.2rem;
			padding: 29.6rem 4rem 4rem 15.6rem;
			box-sizing: border-box;
			@media screen and (max-width: 767px) {
				width: 100%;
				padding: 3.1rem 2rem;
			}
			.staff-words {
				font-family: var(--noto);
				font-style: normal;
				font-weight: 700;
				font-size: 4.9rem;
				line-height: 140%;
				color: #000000;
				margin-bottom: 3rem;
				@media screen and (max-width: 767px) {
					font-size: 2.8rem;
					line-height: 1.6;
				}
			}
			.joined-and-department {
				margin-bottom: 1.4rem;
				font-family: var(--noto);
				font-style: normal;
				font-weight: 700;
				font-size: 1.4rem;
				line-height: 1.7rem;
				letter-spacing: 0.05em;
				color: #000000;
				@media screen and (max-width: 767px) {
					margin-bottom: 1.3rem;
				}
			}
			.staff-name {
				font-family: var(--pop);
				font-style: normal;
				font-weight: 500;
				font-size: 3.6rem;
				line-height: 111%;
				letter-spacing: -0.01em;
				color: #e50012;
				@media screen and (max-width: 767px) {
					font-size: 3.2rem;
				}
			}
		}
		.main-img {
			width: 125.8rem;
			@media screen and (max-width: 767px) {
				width: 100%;
				height: 42.9rem;
				overflow: hidden;
			}
			& img {
				width: 100%;
				vertical-align: top;
				@media screen and (max-width: 767px) {
					height: 100%;
					object-fit: cover;
					object-position: center;
				}
			}
		}
	}
}

#jobs {
	padding-top: 13.8rem;
	padding-bottom: 14.7rem;
	@media screen and (max-width: 767px) {
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
	.block-list {
		display: flex;
		flex-direction: column;
		gap: 10rem;
		@media screen and (max-width: 767px) {
			gap: 4rem;
		}
		.block {
			display: flex;
			gap: 6.5rem;
			@media screen and (max-width: 767px) {
				flex-direction: column-reverse;
				gap: 2rem;
			}
			.text-content {
				width: 74.6rem;
				@media screen and (max-width: 767px) {
					width: 100%;
				}
				.red-label {
					font-family: var(--noto);
					font-style: normal;
					font-weight: 600;
					font-size: 2rem;
					line-height: 150%;
					letter-spacing: 0.03em;
					color: #ffffff;
					display: flex;
					justify-content: center;
					align-items: center;
					padding: 0.8rem 2rem;
					background: #e50012;
					border-radius: 0.4rem;
					margin-bottom: 3rem;
					display: inline-block;
					@media screen and (max-width: 767px) {
						font-size: 1.4rem;
						margin-bottom: 2rem;
					}
				}
				.title {
					font-family: var(--noto);
					font-style: normal;
					font-weight: 700;
					font-size: 3.4rem;
					line-height: 150%;
					letter-spacing: 0.03em;
					color: #000000;
					margin-bottom: 3rem;
					@media screen and (max-width: 767px) {
						font-size: 2.4rem;
						margin-bottom: 2rem;
					}
				}
				.description {
					font-family: var(--noto);
					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;
						line-height: 1.65;
					}
				}
			}
			.img-content {
				width: 63rem;
				@media screen and (max-width: 767px) {
					width: 100%;
				}
			}
		}
		.block:nth-child(2n) {
			flex-direction: row-reverse;
			@media screen and (max-width: 767px) {
				flex-direction: column-reverse;
			}
		}
	}
}

.w1320 {
	max-width: 132rem;
}

#schedule {
	background-color: #f8f8f8;
	padding-top: 12rem;
	padding-bottom: 12rem;
	@media screen and (max-width: 767px) {
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
	.common-header-pages {
		margin-bottom: 6rem;
		@media screen and (max-width: 767px) {
			margin-bottom: 3.4rem;
		}
		.en {
			font-family: var(--pop);
			font-style: normal;
			font-weight: 600;
			font-size: 7.5rem;
			line-height: 111%;
			letter-spacing: -0.01em;
			color: #000000;
			flex-grow: 0;
			@media screen and (max-width: 767px) {
				font-size: 3.8rem;
			}
		}
		.jp {
			font-family: var(--noto);
			font-style: normal;
			font-weight: 700;
			font-size: 1.4rem;
			line-height: 4rem;
			letter-spacing: 0.1em;
			color: #e50012;
			flex-grow: 0;
			padding-left: 1.37rem;
			position: relative;
			@media screen and (max-width: 767px) {
				line-height: 2.16rem;
			}
			&::after {
				content: "";
				position: absolute;
				left: 0;
				top: 50%;
				transform: translateY(-50%) rotate(45deg);
				width: 0.937rem;
				height: 0.937rem;
				background-color: #e50012;
				@media screen and (max-width: 767px) {
					width: 0.523rem;
					height: 0.523rem;
				}
			}
		}
	}
	.schedule-list {
		display: flex;
		flex-direction: column;
		gap: 4.7rem;
		@media screen and (max-width: 767px) {
			gap: 3rem;
		}
		.time-block {
			display: flex;
			@media screen and (max-width: 767px) {
				flex-direction: column;
				gap: 2rem;
			}
			.time {
				width: 18.4rem;
				font-family: var(--jost);
				font-style: normal;
				font-weight: 500;
				font-size: 3.8rem;
				line-height: 1;
				letter-spacing: 0.01em;
				color: #000000;
				padding-left: 4.1rem;
				box-sizing: border-box;
				position: relative;
				@media screen and (max-width: 767px) {
					width: 100%;
					font-size: 1.8rem;
					padding-left: 2.4rem;
				}
				&::before {
					content: "";
					position: absolute;
					left: 0;
					top: 0.7rem;
					width: 2rem;
					height: 2rem;
					background-color: #e50012;
					@media screen and (max-width: 767px) {
						width: 1.2rem;
						height: 1.2rem;
						top: 0.3rem;
					}
				}
			}
			.white-block {
				width: 113.6rem;
				background-color: #ffffff;
				border-radius: 1rem;
				padding: 6rem;
				box-sizing: border-box;
				display: flex;
				gap: 5.4rem;
				@media screen and (max-width: 767px) {
					width: 100%;
					padding: 2rem;
					flex-direction: column;
					gap: 2rem;
				}
				.text-contents {
					width: 100%;
					flex: 1;
					.title {
						font-family: var(--noto);
						font-style: normal;
						font-weight: 700;
						font-size: 2.3rem;
						line-height: 1.2;
						letter-spacing: 0.1em;
						color: #e50012;
						@media screen and (max-width: 767px) {
							font-size: 1.8rem;
						}
					}
					.description {
						font-family: var(--noto);
						font-style: normal;
						font-weight: 400;
						font-size: 1.8rem;
						line-height: 200%;
						letter-spacing: 0.08em;
						color: #000000;
						margin-top: 2rem;
						@media screen and (max-width: 767px) {
							margin-top: 1.6rem;
							font-size: 1.4rem;
							line-height: 1.65;
						}
					}
				}
				.img-contents {
					width: 40rem;
					@media screen and (max-width: 767px) {
						width: 100%;
					}
					& img {
						width: 100%;
						vertical-align: top;
					}
				}
			}
		}
	}
}

#private {
	background-color: #e50012;
	padding-top: 10rem;
	padding-bottom: 10rem;
	@media screen and (max-width: 767px) {
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
	.private-header {
		display: flex;
		align-items: center;
		gap: 2.3rem;
		margin-bottom: 4.1rem;
		@media screen and (max-width: 767px) {
			margin-bottom: 3.4rem;
			gap: 1.6rem;
		}
		.en {
			font-family: var(--pop);
			font-style: normal;
			font-weight: 600;
			font-size: 4.9rem;
			line-height: 111%;
			letter-spacing: -0.01em;
			color: #ffffff;
			flex: none;
			order: 0;
			flex-grow: 0;
			@media screen and (max-width: 767px) {
				font-size: 3.8rem;
			}
		}
		.jp {
			font-family: var(--noto);
			font-style: normal;
			font-weight: 400;
			font-size: 1.6rem;
			line-height: 3.2rem;
			letter-spacing: 0.08em;
			color: #ffffff;
			padding-top: 0.5rem;
			@media screen and (max-width: 767px) {
				font-size: 1.4rem;
			}
		}
	}
	.contents-flex {
		display: flex;
		justify-content: space-between;
		gap: 6.65rem;
		margin-bottom: 8rem;
		@media screen and (max-width: 767px) {
			flex-direction: column-reverse;
			gap: 2rem;
			margin-bottom: 4rem;
		}
		.text-contents {
			width: 100%;
			flex: 1;
			.private-title {
				margin-bottom: 1.7rem;
				font-family: var(--noto);
				font-style: normal;
				font-weight: 700;
				font-size: 2.8rem;
				line-height: 150%;
				letter-spacing: 0.09em;
				color: #ffffff;
				@media screen and (max-width: 767px) {
					font-size: 1.8rem;
				}
			}
			.private-description {
				font-family: var(--noto);
				font-style: normal;
				font-weight: 400;
				font-size: 1.8rem;
				line-height: 200%;
				letter-spacing: 0.08em;
				color: #ffffff;
				@media screen and (max-width: 767px) {
					font-size: 1.4rem;
					line-height: 1.65;
				}
			}
		}
		.img-contents {
			width: 38.4rem;
			@media screen and (max-width: 767px) {
				width: 100%;
			}
			& img {
				width: 100%;
				vertical-align: top;
			}
		}
	}
	.black-btn-container {
		width: 100%;
		display: flex;
		justify-content: center;
		.black-btn {
			width: 30rem;
			height: 7rem;
			background-color: #000000;
			border-radius: 0.6rem;
			padding-left: 3rem;
			display: flex;
			align-items: center;
			position: relative;
			transition: all 0.3s ease-in;
			@media screen and (max-width: 767px) {
				width: 22rem;
				height: 5.133rem;
				padding-left: 2.2rem;
			}
			& span {
				font-family: var(--noto);
				font-style: normal;
				font-weight: 500;
				font-size: 2rem;
				line-height: 1;
				letter-spacing: 0.08em;
				color: #ffffff;
				@media screen and (max-width: 767px) {
					font-size: 1.4rem;
				}
			}
			& img {
				width: 0.9rem;
				height: 1.4rem;
				position: absolute;
				right: 1.8rem;
				top: 50%;
				transform: translateY(-50%);
				@media screen and (max-width: 767px) {
					width: 0.7rem;
					height: 1.2rem;
					right: 1.4rem;
				}
			}
		}
		.black-btn:hover {
			background-color: #fff;
			& span {
				color: #000;
			}
			& img {
				filter: brightness(0) saturate(100%) invert(0%) sepia(94%) saturate(23%) hue-rotate(344deg) brightness(102%) contrast(105%);
			}
		}
	}
}
