@charset "UTF-8";
/* ------------------------------
 メインイメージ（PC）
------------------------------ */
.mainimg {
	position: relative;
}
.mainimg .inBlock {
	position: relative;
	z-index: 1;
}
/* scrolldown */
.scrolldown {
	position: absolute;
	z-index: 2;
}
.scrolldown a {
	display: block;
	width: 100%;
	height: 100%;
	animation: 10s linear infinite rotation;
	background: url(../img/icon_rotate.svg) no-repeat 0 0 / cover;
	text-align: center;
}
.scrolldown a {
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
@keyframes rotation {
	0% {
		transform: rotate(0);
	}
	100% {
		transform: rotate(360deg);
	}
}
/* loopText */
.loopText {
	display: flex;
	overflow: hidden;
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
}
.loopText > p {
	flex: 0 0 auto;
	overflow: hidden;
	padding-left: 20px;
	color: #f2f7fd;
	font-family: "Inter", sans-serif;
	font-size: 15rem;
	line-height: .75;
	font-weight: 600;
	white-space: nowrap;
}
.loopText > p:nth-child(odd) {
	animation: loop1 50s -25s linear infinite;
}
.loopText > p:nth-child(even) {
	animation: loop2 50s linear infinite;
}
@keyframes loop1 {
    0% {
		transform: translateX(100%);
    }
    to {
		transform: translateX(-100%);
    }
}
@keyframes loop2 {
    0% {
		transform: translateX(0);
    }
    to {
		transform: translateX(-200%);
    }
}
@media print, screen and (min-width: 768px) {
	.mainimg {
		height: 1080px;
		padding-top: 187px;
		background: url(../img/mainimg_bg.jpg) no-repeat center bottom / cover;
	}
	.mainimg .inBlock img.pc {
		opacity: 0;
		margin-left: 248px;
		margin-right: -103px;
		animation: 1s 1s ease-out forwards fadein;
	}
	.mainimg .inBlock h1 {
		opacity: 0;
		position: absolute;
		top: 48px;
		left: 0;
		z-index: 2;
		animation: 1s 2s ease-out forwards fadein;
	}
	@keyframes fadein {
		0% {
			opacity: 0;
		}
		100% {
			opacity: 1;
		}
	}
	/* scrolldown */
	.scrolldown {
		bottom: 160px;
		right: 32px;
		width: 108px;
		height: 108px;
		background: url(../img/icon_arrow_b.svg) no-repeat center 43px / 17px 24px;
		transition: .3s ease-in-out;
	}
	.scrolldown:hover {
		background: url(../img/icon_arrow_b.svg) no-repeat center 48px / 17px 24px;
	}
}
/* ------------------------------
 メインイメージ（SP）
------------------------------ */
/* リード */
@media screen and (max-width: 767px) {
	.mainimg {
		height: 667px;
		padding-top: 112px;
		background: url(../img/mainimg_bg_sp.jpg) no-repeat center bottom / cover;
	}
	.mainimg .inBlock {
		width: 100%;
		height: 100%;
		margin: 0;
	}
	.mainimg .inBlock img.sp {
		opacity: 0;
		position: absolute;
		bottom: 0;
		left: 50%;
		max-width: initial;
		width: 425px;
		height: 344px;
		margin-left: -213px;
		animation: 1s 1s ease-out forwards fadein;
	}
	.mainimg .inBlock h1 {
		opacity: 0;
		text-align: center;
		animation: 1s 1s ease-out forwards fadein;
	}
	.mainimg .inBlock h1 img {
		width: 167px;
	}
	@keyframes fadein {
		0% {
			opacity: 0;
		}
		100% {
			opacity: 1;
		}
	}
	/* loopText */
	.loopText {
		bottom: -1px;
	}
	.loopText > p {
		font-size: 5.8rem;
	}
	/* scrolldown */
	.scrolldown {
		right: 4.8%;
		bottom: 160px;
		width: 59px;
		height: 59px;
		background: url(../img/icon_arrow_b.svg) no-repeat center 23px / 9px 13px;
	}
}

/* ------------------------------
 イントロ（PC）
------------------------------ */
.introBlock {
	background-color: #f2f7fd;
}
.introBlock .introHeading {
	margin-bottom: 30px;
	font-size: 3.5rem;
	line-height: 1.4;
	font-weight: 900;
}
.introBlock .inBlock {
	position: relative;
}
.introBlock .inBlock img {
	position: absolute;
	left: 50%;
	max-width: initial;
}
@media print, screen and (min-width: 768px) {
	.introBlock {
		height: 960px;
		margin-bottom: 130px;
		padding-top: 160px;
	}
	.introBlock .inBlock {
		height: 100%;
		text-align: center;
	}
	.introBlock p span {
		display: block;
	}
	.introBlock .inBlock img {
		bottom: 110px;
		width: 1216px;
		height: 395px;
		margin-left: -608px;
	}
}
/* ------------------------------
 イントロ（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.introBlock {
		margin-bottom: 70px;
		padding-top: 100px;
	}
	.introBlock .inBlock {
		height: 100%;
		padding-bottom: 255px;
	}
	.introBlock .introHeading {
		margin-bottom: 20px;
		font-size: 2.4rem;
	}
	.introBlock .inBlock img {
		bottom: 30px;
		width: 554px;
		height: 180px;
		margin-left: -260px;
	}
}

/* ------------------------------
 見出し（PC）
------------------------------ */
/* H2 */
.contentsHome h2 {
	margin-bottom: 45px;
	font-size: 8.2rem;
	font-weight: 900;
	line-height: 1.12;
}
.contentsHome h2 strong {
	display: block;
	margin-bottom: 15px;
	font-size: 2.1rem;
	line-height: 1;
	font-weight: 700;
}
.contentsHome h2 strong::before {
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	margin: 0 10px 4px 5px;
	background-color: #2baa8b;
	vertical-align: middle;
}
.contentsHome h2 em {
	background: #3BBC97;
	background: linear-gradient(90deg,rgba(59,188,151,1) 22%, rgba(0,156,229,1) 68%, rgba(162,136,226,1) 100%);
	font-style: normal;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
/* H3 */
.contentsHome h3 {
	font-size: 2.4rem;
	line-height: 1;
	font-weight: 700;
}
@media print, screen and (min-width: 768px) {
	.contentsHome h2 span {
		display: block;
	}
}
/* ------------------------------
 見出し（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.contentsHome h2 {
		margin-bottom: 25px;
		font-size: 3.5rem;
		letter-spacing: .01em;
	}
	.contentsHome h2 strong {
		margin-bottom: 10px;
		font-size: 1.8rem;
	}
	.contentsHome h2 strong::before {
		margin: 0 8px 3px 2px;
	}
	/* H3 */
	.contentsHome h3 {
		font-size: 2rem;
	}
}
@media screen and (max-width: 359px) {
	.contentsHome h2 {
		margin-bottom: 25px;
		font-size: 3.2rem;
	}
}
/* ------------------------------
 採用メッセージ（PC）
------------------------------ */
.messageBlock {
	margin-bottom: 130px;
}
.messageBlock .inBlock {
	position: relative;
}
.messageBlock .inBlock::after {
	content: "MESSAGE";
	position: absolute;
	top: 122px;
	left: 452px;
	z-index: 1;
	color: #eef5fa;
	font-family: "Inter", sans-serif;
	font-size: 22.8rem;
	line-height: 1;
	font-weight: 600;
}
.messageBlock .inBlock > div {
	position: relative;
	z-index: 2;
}
.messageText p {
	position: relative;
	margin-bottom: 40px;
	font-size: 2.5rem;
	line-height: 1.9;
	font-weight: 500;
}
.messageText p::before,
.messageText p::after {
	position: absolute;
	z-index: -1;
	color: #eef5fa;
	font-family: "Inter", sans-serif;
	font-size: 22.8rem;
	line-height: 1;
	font-weight: 600;
}
.messageText p::before {
	content: "“";
	top: -60px;
	left: -13px;
}
.messageText p::after {
	content: "”";
	bottom: -169px;
	right: -31px;
}
.messageImage {
	position: relative;
}
.messageImage img {
	border-radius: 30px;
	border: 2px solid #1a1a1a;
}
.messageImage p {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: -37px;
	right: -31px;
	width: 143px;
	height: 143px;
	border-radius: 50%;
	background-color: #1a1a1a;
	color: #fff;
	font-size: 2rem;
	line-height: 1.5;
	font-weight: 700;
}
.messageImage p span {
	font-size: 1.4rem;
	font-weight: 400;
}
@media print, screen and (min-width: 768px) {
	.messageBlock .inBlock > div {
		margin-top: -1px;
	}
	.messageBlock .pc {
		margin-top: 10px;
	}
}
/* ------------------------------
 採用メッセージ（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.messageBlock {
		margin-bottom: 70px;
	}
	.messageBlock .inBlock::after {
		top: 77px;
		left: 18%;
		font-size: 6.3rem;
	}
	.messageText {
		position: relative;
		width: 100%;
		padding: 10px 0 40px;
	}
	.messageText p {
		margin-bottom: 35px;
		font-size: 1.6rem;
	}
	.messageText p::before,
	.messageText p::after {
		font-size: 13.5rem;
	}
	.messageText p::before {
		top: -10px;
		left: -6px;
	}
	.messageText p::after {
		bottom: -100px;
		right: 100px;
	}
	.messageText .sp {
		position: absolute;
		bottom: 0;
		right: 0;
	}
	.messageImage img {
		border-radius: 15px;
	}
	.messageImage p {
		top: -20px;
		right: -12px;
		width: 90px;
		height: 90px;
		font-size: 1.3rem;
	}
	.messageImage p span {
		font-size: 1rem;
	}
}
@media screen and (max-width: 375px) {
	.messageText .sp {
		right: -5px;
	}
}

/* ------------------------------
 働く環境（PC）
------------------------------ */
.environmentBlock {
	margin-bottom: 260px;
}
.environmentBlock > .inBlock {
	position: relative;
}
.environmentBlock > .inBlock::after {
	content: "ENVIRONMENT";
	position: absolute;
	top: 224px;
	left: 182px;
	z-index: 1;
	color: #eef5fa;
	font-family: "Inter", sans-serif;
	font-size: 22.8rem;
	line-height: 1;
	font-weight: 600;
}
.environmentBlock > .inBlock div {
	position: relative;
	z-index: 2;
}
.environmentImage {
	position: relative;
	z-index: 2;
	margin-top: -1px;
}
.environmentImage::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -130px;
	right: 0;
	z-index: -1;
	width: 87.5%;
	height: 630px;
	border-radius: 50px 0 0 50px;
	background-color: #f2f7fd;
}
.environmentImage01 img {
	border: 2px solid #1a1a1a;
	border-left: none;
	border-radius: 0 30px 30px 0;
}
.environmentImage .inBlock {
	display: flex;
	justify-content: space-between;
}
.environmentImage .inBlock img {
	border: 2px solid #1a1a1a;
	border-radius: 30px;
}
@media print, screen and (min-width: 768px) {
	.environmentBlock > .inBlock div {
		column-gap: 55px;
		margin-bottom: 60px;
	}
	.environmentBlock h2 {
		margin-bottom: 0;
	}
	.environmentBlock .btn {
		margin-bottom: 10px;
	}
	.environmentBlock > .inBlock img {
		position: relative;
		z-index: 2;
		margin-left: -20px;
	}
	.environmentImage01 {
		position: absolute;
		top: 0;
		left: 0;
		width: calc(50% + 66px);
		height: 674px;
		margin-right: calc(50% - 66px);
	}
	.environmentImage01 img {
		width: 100%;
		height: 674px;
		object-fit: cover;
		object-position: right center;
	}
	.environmentImage .inBlock {
		flex-direction: column;
		height: 674px;
		padding-left: 670px;
	}
}
/* ------------------------------
 働く環境（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.environmentBlock {
		margin-bottom: 120px;
	}
	.environmentBlock > .inBlock {
		text-align: center;
	}
	.environmentBlock .inBlock::after {
		top: 77px;
		left: 8%;
		font-size: 6.3rem;
	}
	.environmentBlock > .inBlock > div {
		margin-bottom: 30px;
		text-align: left;
	}
	.environmentBlock > .inBlock img {
		width: 89%;
	}
	.environmentImage::after {
		bottom: -50px;
		width: 88%;
		height: calc(100% - 25px);
		border-radius: 30px 0 0 30px;
	}
	.environmentImage01 {
		width: 95%;
		margin: 0 5% 15px 0;
	}
	.environmentImage01 img {
		border-radius: 0 15px 15px 0;
	}
	.environmentImage .inBlock {
		column-gap: 15px;
	}
	.environmentImage .inBlock img {
		width: calc((100% - 15px) / 2);
		border-radius: 15px;
	}
}

/* ------------------------------
 社員インタビュー（PC）
------------------------------ */
.interviewBlock {
	position: relative;
	margin-bottom: 260px;
}
.interviewBlock::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -106px;
	left: 0;
	width: 87.5%;
	height: 776px;
	border-radius: 0 50px 50px 0;
	background-color: #f2f7fd;
}
.interviewBlock .inBlock {
	margin-bottom: 90px;
	position: relative;
}
.interviewBlock .inBlock::after {
	content: "INTERVIEW";
	position: absolute;
	top: 71px;
	left: 276px;
	z-index: 1;
	color: #eef5fa;
	font-family: "Inter", sans-serif;
	font-size: 22.8rem;
	line-height: 1;
	font-weight: 600;
}
.interviewBlock .inBlock > * {
	position: relative;
	z-index: 2;
}
.interviewBlock .inBlock img {
	position: absolute;
	bottom: -144px;
	right: -43px;
}
.interviewBoxWrap {
	margin-bottom: 30px;
}
.interviewBoxWrap .interviewBox {
	position: relative;
	margin-left: auto;
	margin-right: auto;
}
.interviewBoxWrap .swiper {
	overflow: visible;
	box-sizing: content-box;
}
.interviewBoxWrap .swiper .swiper-slide a {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.interviewImage {
	position: relative;
	margin: 0 9px 9px 0;
	border: 2px solid #1a1a1a;
	border-radius: 25px;
	background: url(../img/interview_bg01.jpg) no-repeat 0 0 / cover;
}
.interviewBox .swiper-slide:nth-child(3n-1) .interviewImage {
	background: url(../img/interview_bg02.jpg) no-repeat 0 0 / cover;
}
.interviewBox .swiper-slide:nth-child(3n) .interviewImage {
	background: url(../img/interview_bg03.jpg) no-repeat 0 0 / cover;
}
.interviewImage::after {
	content: "";
	position: absolute;
	top: 9px;
	left: 9px;
	z-index: -1;
	display: block;
	width: 100%;
	height: 100%;
	border: 2px solid #1a1a1a;
	border-radius: 30px;
	background-color: #fff;
}
.interviewImage img {
	position: relative;
	bottom: 0;
	left: 0;
	width: 100%;
	margin-top: -26px;
	border-radius: 0 0 28px 28px;
}
.interviewImage div {
	position: absolute;
	top: 27px;
	left: 35px;
	color: #fff;
	font-family: "Inter", sans-serif;
	font-size: 4rem;
	line-height: 1;
	font-weight: 600;
}
.interviewImage p {
	position: absolute;
	top: 17px;
	right: 17px;
	font-size: 2.7rem;
	line-height: 1.3;
	font-weight: 700;
	writing-mode: vertical-rl;
}
.interviewImage p span {
	display: inline-block;
	padding: 10px 5px;
	border: 2px solid #1a1a1a;
	background-color: #fff;
}
.interviewImage p span:nth-of-type(2) {
	margin-right: -2px;
	padding-bottom: 0;
}
.interviewBox .profile {
	display: inline-flex;
	align-items: center;
	height: 36px;
	margin-top: 32px;
	padding-right: 55px;
	font-family: "Inter", sans-serif;
	font-size: 2.2rem;
	line-height: 36px;
	font-weight: 600;
	background: url(../img/icon_circle_arrow.svg) no-repeat right 0 / 36px 36px;
}
.interviewBox .profile span {
	display: inline-block;
	margin-left: 25px;
	padding-left: 25px;
	border-left: 1px solid #1a1a1a;
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 1.6rem;
	line-height: 26px;
	font-weight: 500;
}
.interviewBoxWrap .swiper-button-next,
.interviewBoxWrap .swiper-button-prev {
	top: auto;
	bottom: 0;
	right: 0;
	width: 48px;
	height: 48px;
	margin-top: 0;
	border: 2px solid #1a1a1a;
	border-radius: 50%;
	background-color: #fff;
}
.interviewBoxWrap .swiper-button-prev {
	right: 58px;
	left: auto;
}
.interviewBoxWrap .swiper-button-next::after,
.interviewBoxWrap .swiper-button-prev::after {
	content: "";
	display: inline-block;
	width: 18px;
	height: 14px;
	background: url(../img/icon_slide_arrow.svg) 0 0 / cover;
}
.interviewBoxWrap .swiper-button-prev::after {
	transform: scaleX(-1);
}
.interviewBoxWrap .swiper-horizontal > .swiper-scrollbar {
	position: absolute;
	bottom: 21px;
	left: 0;
	z-index: 50;
	height: 6px;
	border-radius: 3px;
	background-color: #1a1a1a;
}
.interviewBoxWrap .swiper-scrollbar-drag {
	background: #4cd3af;
	background: linear-gradient(90deg,rgba(76,211,175,1) 0%, rgba(64,180,221,1) 100%);
}
.interviewBlock .btn {
	position: relative;
	z-index: 1;
}
@media print, screen and (min-width: 768px) {
	.interviewBoxWrap {
		overflow: hidden;
	}
	.interviewBoxWrap .interviewBox {
		width: 1140px;
	}
	.interviewBoxWrap .swiper {
		height: 615px;
		padding: 48px 0 108px;
	}
	.interviewBoxWrap .swiper-horizontal > .swiper-scrollbar {
		width: 997px;
	}
}
/* ------------------------------
 社員インタビュー（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.interviewBlock {
		margin-bottom: 120px;
	}
	.interviewBlock .inBlock {
		margin-bottom: 65px;
	}
	.interviewBlock::after {
		bottom: -50px;
		width: 88%;
		height: 568px;
		border-radius: 0 30px 30px 0;
	}
	.interviewBlock .inBlock::after {
		top: 110px;
		left: 6.3%;
		font-size: 6.3rem;
	}
	.interviewBlock .inBlock img {
		bottom: -105px;
		right: -1px;
		width: 118px;
	}
	.interviewBoxWrap {
		margin-bottom: 20px;
	}
	.interviewBoxWrap .interviewBox {
		width: 90%;
	}
	.interviewBoxWrap .swiper {
		height: auto;
		padding: 36px 2px 78px 0;
	}
	.interviewImage {
		margin: 0 7px 7px 0;
		border-radius: 20px;
	}
	.interviewImage::after {
		top: 7px;
		left: 7px;
		border-radius: 25px;
	}
	.interviewImage img {
		margin-top: -23px;
		border-radius: 0 0 18px 18px;
	}
	.interviewImage div {
		position: absolute;
		top: 18px;
		left: 23px;
		font-size: 2.9rem;
	}
	.interviewImage p {
		top: 15px;
		right: 15px;
		font-size: 2.2rem;
	}
	.interviewBox .profile {
		height: 30px;
		margin-top: 22px;
		padding-right: 45px;
		font-size: 1.8rem;
		line-height: 30px;
		background: url(../img/icon_circle_arrow.svg) no-repeat right 0 / 30px 30px;
	}
	.interviewBox .profile span {
		margin-left: 15px;
		padding-left: 15px;
		font-size: 1.4rem;
		line-height: 22px;
	}
	.interviewBoxWrap .swiper-horizontal > .swiper-scrollbar {
		bottom: 16px;
		width: 72%;
		height: 6px;
		border-radius: 3px;
		background-color: #1a1a1a;
	}
	.interviewBoxWrap .swiper-button-next,
	.interviewBoxWrap .swiper-button-prev {
		right: 0;
		width: 38px;
		height: 38px;
	}
	.interviewBoxWrap .swiper-button-prev {
		right: 46px;
	}
	.interviewBoxWrap .swiper-button-next::after,
	.interviewBoxWrap .swiper-button-prev::after {
		width: 14px;
		height: 11px;
	}
	.interviewBlock .btn {
		margin-left: 5%;
	}
}

/* ------------------------------
 数字で見る（PC）
------------------------------ */
.numbersBlock {
	margin-bottom: 160px;
}
.numbersBlock ul li {
	position: relative;
	display: block;
}
.numbersBlock ul li + li {
	margin-top: 50px;
}
.numbersBlock img {
	border-radius: 30px;
}
.numbersBlock ul li div {
	position: absolute;
}
.numbersBlock ul li div h2 {
	margin-bottom: 30px;
	font-size: 3.2rem;
	line-height: 1;
	font-weight: 700;
}
.numbersBlock ul li div h2 span {
	display: block;
	margin-bottom: 10px;
	color: #72b2e5;
	font-family: "Inter", sans-serif;
	font-size: 1.8rem;
	font-weight: 600;
}
.numbersBlock ul li:last-child div h2 span {
	color: #4fb49c;
}
@media print, screen and (min-width: 768px) {
	.numbersBlock ul li div {
		top: 180px;
		left: 60px;
	}
}
/* ------------------------------
 数字で見る（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.numbersBlock {
		margin-bottom: 70px;
	}
	.numbersBlock img {
		border-radius: 15px;
	}
	.numbersBlock ul li + li {
		margin-top: 25px;
	}
	.numbersBlock ul li div {
		top: 32%;
		left: 0;
		right: 0;
		margin: 0 auto;
		text-align: center;
	}
	.numbersBlock ul li div h2 {
		margin-bottom: 20px;
		font-size: 2.4rem;
	}
	.numbersBlock ul li div h2 span {
		margin-bottom: 8px;
		font-size: 1.5rem;
	}
}

/* ------------------------------
 採用情報（PC）
------------------------------ */
.recruitBlock {
	padding: 255px 0 167px;
	border-radius: 100px 100px 0 0;
}
.recruitBlock .inBlock {
	position: relative;
}
.recruitBlock .inBlock::after {
	content: "RECRUIT";
	position: absolute;
	top: -80px;
	left: 0;
	right: 0;
	z-index: 1;
	margin: 0 auto;
	color: rgba(255,255,255,.2);
	font-family: "Inter", sans-serif;
	font-size: 20rem;
	line-height: 1;
	font-weight: 600;
	text-align: center;
}
.recruitBlock .inBlock > * {
	position: relative;
	z-index: 2;
}
.recruitBlock h2 {
	margin-bottom: 55px;
	color: #fff;
	font-size: 3.6rem;
	line-height: 1;
	font-weight: 700;
	text-align: center;
}
.recruitBlock li {
	border-radius: 30px;
	background-color: #fff;
}
.recruitBlock li a {
	display: flex;
	justify-content: center;
	align-items: center;
	column-gap: 20px;
	width: 100%;
	height: 100%;
	border-radius: 30px;
	background-color: #fff;
	box-shadow: 0 0 12px 0 rgba(127,133,139,.5) ;
}
.recruitBlock li .icon {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background-color: #eaf2fb;
}
.recruitBlock li .shadow {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 30px;
	background-color: rgba(182,190,198,.5);
	filter: blur(12px);
	mix-blend-mode: multiply;
}
@media print, screen and (min-width:768px) {
	.recruitBlock {
		background: url(../img/recruitment_bg.jpg) no-repeat center 0 / cover;
	}
	.recruitBlock li {
		height: 250px;
	}
}
/* ------------------------------
 採用について（SP）
------------------------------ */
@media screen and (max-width: 767px) {
	.recruitBlock {
		padding: 70px 0;
		border-radius: 30px 30px 0 0;
		background: url(../img/recruitment_bg_sp.jpg) no-repeat center 0 / cover;
	}
	.contentsHome .recruitBlock .inBlock {
		width: 100%;
		margin: 0;
	}
	.recruitBlock .inBlock::after {
		top: -5px;
		font-size: 8.9rem;
		letter-spacing: -.02em;
	}
	.recruitBlock h2 {
		margin-bottom: 45px;
		font-size: 2.6rem;
	}
	.recruitBlock .flexBox {
		flex-direction: column;
		width: 80%;
		margin-left: auto;
		margin-right: auto;
	}
	.recruitBlock li {
		width: 100%;
		border-radius: 15px;
	}
	.recruitBlock li a {
		flex-direction: column;
		align-items: center;
		column-gap: 0;
		row-gap: 15px;
		border-radius: 15px;
		aspect-ratio: auto 7 / 4;
	}
	.recruitBlock li .icon {
		width: 68px;
		height: 68px;
	}
	.recruitBlock li:first-child .icon img {
		width: 19px;
		height: 25px;
	}
	.recruitBlock li:nth-child(2) .icon img {
		width: 24px;
		height: 24px;
	}
		.recruitBlock li:last-child .icon img {
		width: 28px;
		height: 21px;
	}
}