@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;800;900&display=swap');

footer {
	margin-top: 0;
}

#mainvisual {
	color: #ffffff;
	background-color: #68d8fd;
	padding: 78px 20px 10px;
	position: relative;
	overflow: hidden;
}

#mainvisual::before {
	background: url("../../images/employer/data/bg_mainvisual.png") no-repeat center top;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: -50px;
	z-index: 1;
}

#mainvisual::after {
	background: radial-gradient(#ffffff29, #231f2029);
	mix-blend-mode: overlay;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 2;
}

#mainvisual .mainvisual-head {
	position: relative;
	z-index: 3;
}

#mainvisual .mainvisual-image {
	margin-top: 1px;
	text-align: center;
	position: relative;
	z-index: 1;
}

#mainvisual .mainvisual-image img {
	width: auto;
	max-width: 100%;
}

#mainvisual #page-title {
	font-size: 7.0rem;
	font-weight: 700;
	text-align: center;
}

#mainvisual .main-lead {
	font-size: 3.2rem;
	font-weight: 700;
	text-align: center;
	margin-top: 10px;
}

@media all and (min-width: 751px) and (max-width: 1399px) {
	#mainvisual {
		padding: calc(78 / 1399 * 100vw) calc(20 / 1399 * 100vw) calc(10 / 1399 * 100vw);
	}

	#mainvisual::before {
		background-size: calc(1415 / 1399 * 100vw) auto;
		top: calc(-50 / 1399 * 100vw);
	}

	#mainvisual .mainvisual-image {
		margin-top: calc(1 / 1399 * 100vw);
	}

	#mainvisual #page-title {
		font-size: calc(70 / 1399 * 100vw);
	}

	#mainvisual .main-lead {
		font-size: calc(32 / 1399 * 100vw);
		margin-top: calc(10 / 1399 * 100vw);
	}
}

@media all and (max-width: 750px) {
	#mainvisual {
		padding: calc(54 / 375 * 100vw) calc(20 / 375 * 100vw) calc(26 / 375 * 100vw);
	}

	#mainvisual::before {
		background-size: calc(637 / 375 * 100vw) auto;
		top: calc(9 / 375 * 100vw);
	}

	#mainvisual .mainvisual-image {
		margin-top: calc(4 / 375 * 100vw);
		width: calc(554 / 375 * 100vw);
		position: relative;
		left: 50%;
		transform: translateX(-50%);
	}

	#mainvisual #page-title {
		font-size: calc(44 / 375 * 100vw);
	}
	
	#mainvisual .main-lead {
		font-size: calc(20 / 375 * 100vw);
		margin-top: 0;
	}
}

section {
	padding: 30px 15px;
}	

section .section-heading {
	text-align: center;
	margin-bottom: 40px;
}

section .section-heading > *:last-child {
	margin-bottom: 0!important;
}

section .section-title {
	font-size: 4.0rem;
	font-weight: 700;
}

section .section-copy {
	font-size: 2.6rem;
	font-weight: 700;
}

section .section-lead {
	font-size: 1.4rem;
	font-weight: 400;
}

section .section-heading > .section-lead {
	margin-top: 25px;
}

section .section_button {
	min-width: max-content;
	width: 100%;
	max-width: 500px;
	margin: 80px auto 0;
}

section .section_button > a {
	color: #ffffff;
	background-color: #ffbe00;
	border: 5px solid #ffbe00;
	border-radius: 16px;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	position: relative;
	padding: 19px 10px;
	text-decoration: none;
}

section .section_button > a:hover {
	color: #ffbe00;
	background-color: #ffffff;
	opacity: 1;
}

section .section_button > a .button_text {
	font-size: 2.4rem;
	font-weight: 700;
	text-align: left;
	text-shadow: 0 4px 4px #00000026;
	flex: 0 1 auto;
}

@media all and (min-width: 751px) and (max-width: 919px) {
	section {
		padding: calc(30 / 919 * 100vw) calc(20 / 919 * 100vw);
	}
}

@media all and (min-width: 751px) and (max-width: 899px) {
	section .section-heading {
		margin-bottom: calc(40 / 899 * 100vw);
	}

	section .section-title {
		font-size: calc(40 / 899 * 100vw);
	}

	section .section-copy {
		font-size: calc(26 / 899 * 100vw);
	}

	section .section-lead {
		font-size: calc(14 / 899 * 100vw);
	}

	section .section-heading > .section-lead {
		margin-top: calc(25 / 899 * 100vw);
	}

	section .section-lead .strong-text {
		font-size: calc(36 / 899 * 100vw);
	}

	section .section_button {
		max-width: calc(500 / 899 * 100vw);
		margin: calc(80 / 899 * 100vw) auto 0;
	}

	section .section_button > a {
		border-width: calc(5 / 899 * 100vw);
		border-radius: calc(16 / 899 * 100vw);
		gap: calc(10 / 899 * 100vw);
		padding: calc(19 / 899 * 100vw) calc(10 / 899 * 100vw);
	}

	section .section_button > a .button_text {
		font-size: calc(24 / 899 * 100vw);
		text-shadow: 0 calc(4 / 899 * 100vw) calc(4 / 899 * 100vw) #00000026;
	}
}

@media all and (max-width: 750px) {
	section {
		font-size: calc(14 / 375 * 100vw);
		padding: calc(20 / 375 * 100vw) calc(15 / 375 * 100vw);
	}

	section .section-heading {
		margin-bottom: calc(30 / 375 * 100vw);
	}

	section .section-title {
		font-size: calc(32 / 375 * 100vw);
	}

	section .section-copy {
		font-size: calc(15 / 375 * 100vw);
	}

	section .section-lead {
		font-size: calc(14 / 375 * 100vw);
	}

	section .section-heading > .section-lead {
		margin-top: calc(16 / 375 * 100vw);
	}

	section .section_button {
		max-width: calc(384 / 375 * 100vw);
		margin: calc(32 / 375 * 100vw) auto 0;
	}

	section .section_button > a {
		border-width: calc(5 / 375 * 100vw);
		border-radius: calc(16 / 375 * 100vw);
		gap: calc(10 / 375 * 100vw);
		padding: calc(11 / 375 * 100vw) calc(5 / 375 * 100vw);
	}

	section .section_button > a .button_text {
		font-size: calc(20 / 375 * 100vw);
		text-shadow: 0 calc(4 / 375 * 100vw) calc(4 / 375 * 100vw) #00000026;
	}
}

#foreigner-hired {
	color: #031452;
	font-family: 'Noto Sans JP','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
	font-weight: 500;
}

#foreigner-hired .case {
	padding-top: 80px;
	padding-bottom: 90px;
}

#foreigner-hired .case .case-items {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 32px;
	margin-top: 40px;
	width: 100%;
}

#foreigner-hired .case .case-items > .case-item {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 100%;
}

#foreigner-hired .case .case-heading {
	color: #081163;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 24px;
	width: max-content;
}

#foreigner-hired .case .case-heading .case-category-name {
	font-size: 2.4rem;
	font-weight: 700;
}

#foreigner-hired .case .case-heading .case-heading-lead {
	font-size: 1.6rem;
	font-weight: 500;
}

#foreigner-hired .case .case-body {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 15px;
	width: 100%;
}

#foreigner-hired .case .case-body > .border-block-item {
	width: calc((100% / 3) - (15px * 2 / 3));
}

#foreigner-hired .case .border-block-item {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 7px;
	padding: 13px 14px;
	border: 2px solid #33a8ed;
	border-radius: 8px;
}

#foreigner-hired .case .border-block-item .border-circle-image {
	width: 88px;
	height: 88px;
	flex: 0 0 auto;
	border-radius: 50%;
	border: 4px solid #aadfff;
	overflow: hidden;
	position: relative;
}

#foreigner-hired .case .border-block-item .border-circle-image img {
	width: 100%;
	height: 100%;
	position: absolute;
	object-fit: cover;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#foreigner-hired .case .border-block-item .case-tag {
	background-color: #aadfff;
	width: 127px;
	padding: 3px 8px;
	margin-bottom: 8px;
	border-radius: 20px;
	font-size: 1.4rem;
	font-weight: 500;
}

#foreigner-hired .case .border-block-item .case-text {
	padding: 0 8px;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.7;
}

#foreigner-hired .case .case-items > .case-item:nth-child(even) .border-block-item {
	border-color: #ffbe00;
}

#foreigner-hired .case .case-items > .case-item:nth-child(even) .border-block-item .border-circle-image {
	border-color: #ffeaac;
}

#foreigner-hired .case .case-items > .case-item:nth-child(even) .border-block-item .case-tag {
	background-color: #ffeaac;
}

@media screen and (min-width: 751px) {
	#foreigner-hired .case .case-heading {
		background-color: #aadfff;
	}

	#foreigner-hired .case .case-items > .case-item:nth-child(even) .case-heading {
		background-color: #ffeaac;
	}
}

@media screen and (min-width: 900px) {
	#foreigner-hired .case .case-heading {
		border-radius: 23px;
		padding: 3px 25px 5px;
		margin-bottom: 15px;
	}
}

@media screen and (min-width: 751px) and (max-width: 899px) {
	#foreigner-hired .case {
		padding-top: calc(80 / 899 * 100vw);
		padding-bottom: calc(90 / 899 * 100vw);
	}

	#foreigner-hired .case .case-items {
		gap: calc(32 / 899 * 100vw);
		margin-top: calc(40 / 899 * 100vw);
	}

	#foreigner-hired .case .case-heading {
		gap: calc(24 / 899 * 100vw);
		border-radius: calc(23 / 899 * 100vw);
		padding: calc(3 / 899 * 100vw) calc(25 / 899 * 100vw) calc(5 / 899 * 100vw);
		margin-bottom: calc(15 / 899 * 100vw);
	}
	#foreigner-hired .case .case-heading .case-category-name {
		font-size: calc(24 / 899 * 100vw);
	}

	#foreigner-hired .case .case-heading .case-heading-lead {
		font-size: calc(16 / 899 * 100vw);
	}

	#foreigner-hired .case .case-body {
		gap: calc(15 / 899 * 100vw);
	}

	#foreigner-hired .case .case-body > .border-block-item {
		width: calc((100% / 3) - ((15 / 899 * 100vw) * 2 / 3));
	}

	#foreigner-hired .case .border-block-item {
		gap: calc(7 / 899 * 100vw);
		padding: calc(13 / 899 * 100vw) calc(14 / 899 * 100vw);
		border-width: calc(2 / 899 * 100vw);
		border-radius: calc(8 / 899 * 100vw);
	}

	#foreigner-hired .case .border-block-item .border-circle-image {
		width: calc(88 / 899 * 100vw);
		height: calc(88 / 899 * 100vw);
		border-width: calc(4 / 899 * 100vw);
	}

	#foreigner-hired .case .border-block-item .case-tag {
		width: calc(127 / 899 * 100vw);
		padding: calc(3 / 899 * 100vw) calc(8 / 899 * 100vw);
		margin-bottom: calc(8 / 899 * 100vw);
		border-radius: calc(20 / 899 * 100vw);
		font-size: calc(14 / 899 * 100vw);
	}

	#foreigner-hired .case .border-block-item .case-text {
		padding: 0;
		font-size: calc(14 / 899 * 100vw);
	}
}

@media screen and (max-width: 750px) {
	#foreigner-hired .case {
		padding-top: calc(16 / 375 * 100vw);
		padding-bottom: calc(62 / 375 * 100vw);
	}

	#foreigner-hired .case .case-items {
		gap: calc(24 / 375 * 100vw);
		margin-top: calc(32 / 375 * 100vw);
	}

	#foreigner-hired .case .case-heading {
		flex-direction: column;
		align-items: flex-start;
		gap: calc(10 / 375 * 100vw);
		width: 100%;
		margin-bottom: calc(15 / 375 * 100vw);
	}

	#foreigner-hired .case .case-heading .case-category-name {
		background-color: #aadfff;
		border-radius: calc(10 / 375 * 100vw);
		width: 100%;
		padding: calc(5 / 375 * 100vw) calc(10 / 375 * 100vw);
		font-size: calc(20 / 375 * 100vw);
	}

	#foreigner-hired .case .case-heading .case-heading-lead {
		font-size: calc(14 / 375 * 100vw);
	}

	#foreigner-hired .case .case-body {
		flex-direction: column;
		gap: calc(10 / 375 * 100vw);
	}

	#foreigner-hired .case .case-body > .border-block-item {
		width: 100%;
	}

	#foreigner-hired .case .border-block-item {
		gap: calc(15 / 375 * 100vw);
		padding: calc(8 / 375 * 100vw) calc(13 / 375 * 100vw);
		border-width: calc(2 / 375 * 100vw);
		border-radius: calc(8 / 375 * 100vw);
	}

	#foreigner-hired .case .border-block-item .border-circle-image {
		width: calc(90 / 375 * 100vw);
		height: calc(90 / 375 * 100vw);
		border-width: calc(4 / 375 * 100vw);
	}

	#foreigner-hired .case .border-block-item .case-tag {
		width: calc(127 / 375 * 100vw);
		padding: calc(1.5 / 375 * 100vw) calc(8 / 375 * 100vw);
		margin-bottom: calc(8 / 375 * 100vw);
		border-radius: calc(20 / 375 * 100vw);
		font-size: calc(14 / 375 * 100vw);
	}

	#foreigner-hired .case .border-block-item .case-text {
		padding: 0;
		font-size: calc(14 / 375 * 100vw);
	}

	#foreigner-hired .case .case-items > .case-item:nth-child(even) .case-heading .case-category-name {
		background-color: #ffeaac;
	}
}