@charset "utf-8";

.l-primary {
	margin: 70px 0 0;
	overflow: hidden;
	transform: translateZ(0);
}

.l-puzzle {
	max-width: 1036px;
	margin: 70px auto 0;
	position: relative;
}

.l-puzzle .inner {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	position: absolute;
	inset: 0;
	z-index: 10;
}

.l-puzzle .logo {
	width: 200px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.l-puzzle .item {
	text-align: center;
	width: calc(100% / 2);
	height: calc(100% / 2);
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.l-puzzle .item:nth-of-type(1),
.l-puzzle .item:nth-of-type(3) {
	padding-bottom: 60px;
}

.l-puzzle .icon {
	width: 17%;
	margin-inline: auto;
}

.l-puzzle .title {
	font-size: min(3.2vw,32rem);
	font-weight: 900;
	letter-spacing: -.05em;
	margin: 15px 0 0;
	display: inline-block;
	position: relative;
}

.l-puzzle .title:before,
.l-puzzle .title:after {
	content: '';
	width: .95em;
	height: .95em;
	margin: -.5em 0 0 -.75em;
	display: inline-block;
	background: url("/recruit/fresh/_assets/images/wanted/img_02.svg") no-repeat center / 100% 100%;
	position: absolute;
}

.l-puzzle .title:after {
	margin: .5em -.75em 0 0;
	rotate: 180deg;
}

.l-puzzle .text {
	font-size: min(1.6vw,16rem);
	font-weight: 500;
	line-height: 1.5;
	margin-top: 20px;
}

.l-puzzle .image {
	position: relative;
}

.l-puzzle .image .parts {
	position: relative;
	z-index: 10;
}

.l-puzzle .image .parts:nth-of-type(1) {
	width: 140px;
	margin: 190px 0 0 -168px;
	position: absolute;
	top: 0;
	left: 0;
}

.l-puzzle .image .parts:nth-of-type(2) {
	width: 246px;
	margin: 0 -168px -10px 0;
	position: absolute;
	bottom: 0;
	right: 0;
}

.l-culture .title {
	color: var(--white);
	background: var(--green_dark);
	padding: 30px 30px 30px 100px;
	display: inline-block;
	border-radius: 5px;
	position: relative;
	z-index: 10;
}

.l-culture .title:before {
	content: '';
	width: 58px;
	height: 62px;
	background: url("/recruit/fresh/_assets/images/wanted/img_05.svg") no-repeat center / 100% 100%;
	position: absolute;
	top: 50%;
	left: 22px;
	transform: translate(0,-50%);
}

.l-culture .title small {
	font-size: 16rem;
	font-weight: 700;
	display: block;
}

.l-culture .title b {
	font-size: 30rem;
	font-weight: 900;
	margin: 10px 0 0;
	display: block;
}

.l-culture .stage {
	margin: -40px 0 0;
	padding: 100px 0 0;
	background: var(--gray_light);
	border-radius: 5px;
	position: relative;
}

.l-culture .stage:before {
	content: '';
	width: 102px;
	height: 90px;
	margin: 60px 0 0 30px;
	background: url("/recruit/fresh/_assets/images/wanted/img_06.svg") no-repeat center / 100% 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.l-culture .stage .image {
	max-width: 1040px;
	margin-inline: auto;
	padding: 0 30px 60px;
}


