/*------------------------------------
.hmv
------------------------------------*/
.hmv__inner {
	background-image: url("../images/jobs/hmv-img.jpg");
}
.hmv__ttl {
	background-color: #fef6f5;
}
.hmv__ttl::before,
.hmv__ttl::after {
	background-image: url("../images/hmv-bg_ld.png");
}


/*--------------------------------------------------------------------------
#jobs
--------------------------------------------------------------------------*/
#jobs {
	background-color: #fef6f5;
}
#jobs .ttl {
	display: flex;
	align-items: center;
	background-color: #fff;
	width: fit-content;
	height: 60px;
	font-size: 30px;
	line-height: 1;
	margin-bottom: 50px;
	padding: 0 28px;
}
@media screen and (max-width: 768px) {
	#jobs .ttl {
		height: 50px;
		font-size: 25px;
		margin-bottom: 30px;
		padding: 0 15px;
	}
}


/*------------------------------------
#philosophy
------------------------------------*/
#philosophy {
	padding-top: 120px;
}
#philosophy .container {
	max-width: 1260px;
}
.philosophy__txt {
	max-width: 1060px;
	margin: auto;
}
.philosophy__txt h3 {
	font-size: 28px;
	text-align: center;
	margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
	#philosophy {
		padding-top: 80px;
	}
	.philosophy__txt h3 {
		font-size: 22px;
	}
}


/*------------------------------------
#features
------------------------------------*/
#features {
	position: relative;
	padding: 120px 0 250px;
}
#features::after {
	content: "";
	position: absolute;
	bottom: 0;
	background-image: url("../images/wave_wh.svg");
	background-repeat: no-repeat;
	background-size: 100% auto;
	width: 100%;
	padding-bottom: 5.2083%;
}
#features .container {
	max-width: 1260px;
}
.features-list {
	counter-reset: features;
}
.features__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 35px;
	position: relative;
	background-color: #fff;
	padding: 2.604vw; /*50px*/
	margin-left: 5.2083vw; /*100px*/
}
.features__row:nth-child(even) {
	background-color: #fffbf3;
	margin: 0 5.2083vw 0 0;
}
.features__row:not(:last-child) {
	margin-bottom: 5.2083vw; /*100px*/
}
.features__row::before {
	counter-increment: features;
	content: counter(features, decimal-leading-zero);
	position: absolute;
	top: -40px;
	left: 30px;
	font-size: 6.25vw; /*120px*/
	font-style: italic;
	font-weight: 700;
	letter-spacing: .05em;
	line-height: 1;
	color: #f2a096;
}
.features__row .txt,
.features__row .img {
	width: 50%;
}
.features__row h3 {
	display: flex;
	flex-direction: column;
	align-items: center;
	font-size: 28px;
	text-align: center;
	margin-bottom: 20px;
}
.features__row span {
	font-size: 18px;
	font-weight: 500;
	letter-spacing: .2em;
}
.features__row span::before {
	content: "＼";
}
.features__row span::after {
	content: "／";
}
@media screen and (max-width: 768px) {
	#features {
		padding: 80px 0 100px;
	}
	.features__row {
		flex-direction: column;
		gap: 30px;
		padding: 10.4167vw 5.2083vw; /* 80px 40px*/
	}
	.features__row:not(:last-child) {
		margin-bottom: 6.5104vw; /*50px*/
	}
	.features__row::before {
		top: -5.2083vw; /*40px*/
		left: 3.90625vw; /*30px*/
		font-size: 13.0208vw; /*100px*/
	}
	.features__row .txt,
	.features__row .img {
		width: 100%;
	}
	.features__row h3 {
		font-size: 22px;
		margin-bottom: 10px;
	}
	.features__row span {
		font-size: 14px;
		letter-spacing: 0;
	}
}


/*------------------------------------
#message
------------------------------------*/
#message {
	position: relative;
	background-color: #fff;
	padding: 120px 0 250px;
}
#message::after {
	content: "";
	position: absolute;
	bottom: 0;
	background-image: url("../images/wave_rd.svg");
	background-repeat: no-repeat;
	background-size: 100% auto;
	width: 100%;
	padding-bottom: 5.2083%;
}
#message .container {
	max-width: 920px;
}
#message h2 {
	display: flex;
	flex-direction: column;
	align-items: center;
	font-size: 36px;
	margin-bottom: 40px;
}
#message span {
	font-size: 18px;
	font-weight: 500;
	letter-spacing: .2em;
}
.message__img {
	position: relative;
}
.message__img::after {
	content: "";
	position: absolute;
	top: -100px;
	right: -30px;
	background-image: url("../images/top/gallery-bg.svg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	width: 200px;
	height: 171px;
}
.message__txt {
	position: relative;
	background-color: #fffbf3;
	margin-top: 50px;
	padding: 40px 50px;
}
.message__txt::before,
.message__txt::after {
	content: "";
	position: absolute;
	left: 0;
	background-image: linear-gradient(to right,#9fa0a0 2px,transparent 2px);
	background-repeat: repeat-x;
	background-size: 4px 1px;
	width: 100%;
	height: 1px;
}
.message__txt::before {
	top: 0;
}
.message__txt::after {
	bottom: 0;
}
.message__txt p:not(:last-child) {
	margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
	#message {
		padding: 80px 0 100px;
	}
	#message h2 {
		font-size: 25px;
	}
	#message span {
		font-size: 14px;
		letter-spacing: 0;
	}
	.message__img::after {
		top: -50px;
		right: -10px;
		width: 100px;
		height: 85px;
	}
	.message__txt {
		margin-top: 6.5104vw; /*50px*/
		padding: 5.2083vw 6.5104vw; /*40px 50px*/
	}
}


/*------------------------------------
#role
------------------------------------*/
#role {
	padding: 120px 0;
}
.role__inner {
	position: relative;
}
.role__row {
	max-width: 1260px;
	width: calc(100% - 7.29vw);
	margin: auto;
}
.role__row > * {
	width: 50%;
}
.role__row .img {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
}
.role__row img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.role__row .txt {
	margin-left: auto;
	padding: 100px 0 100px 100px;
}
.role__row .txt > p {
	margin-bottom: 40px;
}
.role__detail {
	background-color: #fff;
	border: 2px solid #f2a096;
	padding: 32px 40px;
}
.role__detail .rounded {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #f2a096;
	border-radius: 20px;
	width: fit-content;
	height: 40px;
	font-size: 18px;
	line-height: 1;
	color: #fff;
	padding: 0 28px;
}
.role__detail .flex {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin-top: 16px;
}
.role__detail li {
	position: relative;
	line-height: 1.5;
	padding-left: 15px;
}
.role__detail li:not(:last-child) {
	margin-bottom: 10px;
}
.role__detail li::before {
	content: "";
	display: block;
	position: absolute;
	top: 8px;
	left: 0;
	background-color: #9fa0a0;
	border-radius: 50%;
	width: 8px;
	height: 8px;
}
@media screen and (max-width: 768px) {
	#role {
		padding: 80px 0;
	}
	.role__row {
		width: 100%;
	}
	.role__row > * {
		width: 100%;
	}
	.role__row .img {
		height: auto;
	}
	.role__row .img {
		position: static;
	}
	.role__row .txt {
		padding: 30px 3.6458vw 0; /*70px*/
	}
	.role__row .txt > p {
		margin-bottom: 30px;
	}
	.role__detail {
		padding: 6.5104vw; /*50px*/
	}
	.role__detail .rounded {
		font-size: 16px;
		padding: 0 15px;
	}
}

/*.role__block*/
.role__block {
	position: relative;
	background-color: #fff;
	border: 2px solid #f2a096;
	width: calc(100% - 7.29vw);
	max-width: 800px;
	margin: 80px auto 0;
	padding: 50px;
}
.role__block .rounded {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: -30px;
	left: 20px;
	background-color: #f2a096;
	border-radius: 25px;
	width: fit-content;
	height: 50px;
	font-size: 24px;
	line-height: 1;
	color: #fff;
	padding: 0 30px;
}
.role__box {
	position: relative;
	padding-left: 30px;
}
.role__box:not(:last-child) {
	padding-bottom: 30px;
}
.role__box .line {
	display: block;
	position: absolute;
	top: 2px;
	left: 0;
	width: 16px;
	height: 100%;
}
.role__box .line:before,
.role__box .line:after {
	content: "";
	display: block;
	position: absolute;
}
.role__box .line:before {
	border: 2px solid #f2a096;
	border-radius: 50%;
	width: 16px;
	height: 16px;
}
.role__box .line:after {
	top: 16px;
	left: 50%;
	transform: translateX(-50%);
	background-color: #f2a096;
	width: 2px;
	height: calc(100% - 16px);
}
@media screen and (max-width: 768px) {
	.role__block {
		margin-top: 10.4167vw; /*80px*/
		padding: 10.4167vw 6.5104vw 6.5104vw; /*80px 50px 50px*/
	}
	.role__block .rounded {
		top: -20px;
		height: 40px;
		font-size: 16px;
		padding: 0 15px;
	}
}

/*.preferred*/
.preferred::after {
	content: "★資格をお持ちでなくとも、ご応募いただけます";
	position: absolute;
	bottom: -50px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	width: 100%;
	font-size: 20px;
	font-weight: 700;
	text-align: center;
}
.preferred-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 20px;
}
.preferred-list li {
	position: relative;
	width: calc((100% - 40px) / 3);
	font-weight: 700;
	line-height: 1.5;
	padding-left: 15px;
}
.preferred-list li::before {
	content: "";
	display: block;
	position: absolute;
	top: 8px;
	left: 0;
	background-color: #9fa0a0;
	border-radius: 50%;
	width: 8px;
	height: 8px;
}
@media screen and (max-width: 768px) {
	.preferred::after {
		font-size: 16px;
	}
	.preferred-list li {
		width: 100%;
	}
}

/*.btn*/
.btn {
	margin-top: 100px;
}
@media screen and (max-width: 768px) {}
