@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: 110px 20px 30px;
	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: -110px;
	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: 64px;
	text-align: center;
	position: relative;
	z-index: 1;
}

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

#mainvisual #page-title {
	font-size: 6.4rem;
	font-weight: 700;
	text-align: center;
	text-shadow: 4px 4px 4px #00000040;
}

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

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

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

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

	#mainvisual #page-title {
		font-size: calc(64 / 1399 * 100vw);
		text-shadow: calc(4 / 1399 * 100vw) calc(4 / 1399 * 100vw) calc(4 / 1399 * 100vw) #00000040;
	}

	#mainvisual .main-lead {
		font-size: calc(24 / 1399 * 100vw);
		text-shadow: calc(4 / 1399 * 100vw) calc(4 / 1399 * 100vw) calc(4 / 1399 * 100vw) #00000040;
		margin-top: calc(10 / 1399 * 100vw);
	}
}

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

	#mainvisual::before {
		background-size: calc(758 / 430 * 100vw) auto;
		top: 0;
	}

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

	#mainvisual #page-title {
		font-size: calc(45 / 430 * 100vw);
		text-shadow: calc(4 / 430 * 100vw) calc(4 / 430 * 100vw) calc(4 / 430 * 100vw) #00000040;
	}
	
	#mainvisual .main-lead {
		font-size: calc(17 / 430 * 100vw);
		text-shadow: calc(4 / 430 * 100vw) calc(4 / 430 * 100vw) calc(4 / 430 * 100vw) #00000040;
		margin-top: 0;
	}
}

section {
	padding: 30px 15px;
}

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

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

section .section-title {
	font-size: 4.0rem;
	font-weight: 700;
	margin-bottom: 14px;
}

section .section-copy {
	font-size: 3.2rem;
	font-weight: 700;
	margin-bottom: 5px;
}

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

section .section-lead .strong-text {
	color: #33a8ed;
	font-size: 3.6rem;
	font-weight: 700;
}

section .section-desc {
	font-size: 1.8rem;
	font-weight: 400;
}

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: 879px) {
	section .section-heading {
		margin-bottom: calc(50 / 879 * 100vw);
	}

	section .section-title {
		font-size: calc(40 / 879 * 100vw);
		margin-bottom: calc(14 / 879 * 100vw);
	}

	section .section-copy {
		font-size: calc(32 / 879 * 100vw);
		margin-bottom: calc(5 / 879 * 100vw);
	}

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

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

	section .section-desc {
		font-size: calc(18 / 879 * 100vw);
	}
	
	section .section_button {
		max-width: calc(500 / 879 * 100vw);
		margin: calc(80 / 879 * 100vw) auto 0;
	}

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

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

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

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

	section .section-title {
		font-size: calc(30 / 430 * 100vw);
		margin-bottom: calc(12 / 430 * 100vw);
	}

	section .section-copy {
		font-size: calc(20 / 430 * 100vw);
		margin-bottom: 5px;
	}

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

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

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

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

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

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

.cards {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 16px;
}

.cards > .card-item {
	width: calc((100% / 2) - (16px / 2));
}

.card-item {
	background-color: #FFE5DA66;
	width: 100%;
	padding: 16px 24px;
	border-radius: 16px;
}

.card-item .card-heading {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 16px;
	margin-bottom: 11px;
}

.card-item .card-footer {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 16px;
	margin-top: 5px;
}

.card-item.card-work.work-type-albite {
	background-color: #ffe5da66;
}

.card-item.card-work.work-type-albite .work-tag {
	background-color: #e86161
}

.card-item.card-work.work-type-fulltime {
	background-color: #e2eef5;
}

.card-item.card-work.work-type-fulltime .work-tag {
	background-color: #23a2ff;
}

.card-item.card-work.work-type-skills {
	background-color: #f0e9f9;
}

.card-item.card-work.work-type-skills .work-tag {
	background-color: #a058ff;
}

.card-work .work-category {
	font-size: 2.6rem;
	font-weight: 700;
}

.card-work .work-name {
	font-size: 1.6rem;
	font-weight: 700;
}

.card-work .work-tag {
	color: #ffffff;
	font-size: 1.6rem;
	font-weight: 500;
	text-align: center;
	width: 138px;
	padding: 7.5px 5px;
	border-radius: 8px;
	margin-left: auto;
}

.card-work .plan-info {
	font-size: 1.4rem;
	font-weight: 500;
}

.card-work .application-num {
	font-size: 1.6rem;
	font-weight: 700;
}

.card-work .application-cost {
	font-size: 1.6rem;
	font-weight: 700;
}

.card-work .application-num .strong-text,
.card-work .application-cost .strong-text {
	color: #33a8ed;
	font-size: 3.0rem;
	font-weight: 700;
}

@media screen and (min-width: 751px) and (max-width: 879px){
	.cards {
		gap: calc(16 / 879 * 100vw);
	}

	.cards > .card-item {
		width: calc((100% / 2) - ((16 / 879 * 100vw) / 2));
	}

	.card-item {
		padding: calc(16 / 879 * 100vw) calc(12 / 879 * 100vw);
		border-radius: calc(16 / 879 * 100vw);
	}

	.card-item .card-heading {
		gap: calc(8 / 879 * 100vw);
		margin-bottom: calc(11 / 879 * 100vw);
	}

	.card-item .card-footer {
		gap: 0;
		margin-top: calc(5 / 879 * 100vw);
	}

	.card-work .work-category {
		font-size: calc(26 / 879 * 100vw);
	}

	.card-work .work-name {
		font-size: calc(16 / 879 * 100vw);
	}

	.card-work .work-tag {
		font-size: calc(16 / 879 * 100vw);
		width: calc(138 / 879 * 100vw);
		padding: calc(7.5 / 879 * 100vw) calc(5 / 879 * 100vw);
		border-radius: calc(8 / 879 * 100vw);
	}

	.card-work .plan-info {
		font-size: calc(14 / 879 * 100vw);
	}

	.card-work .application-num {
		font-size: calc(16 / 879 * 100vw);
	}

	.card-work .application-cost {
		font-size: calc(16 / 879 * 100vw);
	}

	.card-work .application-num .strong-text,
	.card-work .application-cost .strong-text {
		font-size: calc(30 / 879 * 100vw);
	}
}

@media screen and (max-width: 750px) {
	.cards {
		flex-direction: column;
		gap: calc(12 / 430 * 100vw);
	}

	.cards > .card-item {
		width: 100%;
	}

	.card-item {
		padding: calc(16 / 430 * 100vw) calc(14 / 430 * 100vw);
		border-radius: calc(16 / 430 * 100vw);
	}

	.card-item .card-heading {
		gap: calc(10 / 430 * 100vw);
		margin-bottom: 0;
	}

	.card-item .card-footer {
		gap: calc(4 / 430 * 100vw);
		margin-top: calc(16 / 430 * 100vw);
	}

	.card-work .work-category {
		font-size: calc(26 / 430 * 100vw);
	}

	.card-work .work-name {
		font-size: calc(16 / 430 * 100vw);
	}

	.card-work .work-tag {
		font-size: calc(16 / 430 * 100vw);
		width: calc(138 / 430 * 100vw);
		padding: calc(7.5 / 430 * 100vw) calc(5 / 430 * 100vw);
		border-radius: calc(8 / 430 * 100vw);
	}

	.card-work .plan-info {
		font-size: calc(14 / 430 * 100vw);
	}

	.card-work .application-num {
		font-size: calc(16 / 430 * 100vw);
	}

	.card-work .application-cost {
		font-size: calc(16 / 430 * 100vw);
	}

	.card-work .application-num .strong-text,
	.card-work .application-cost .strong-text {
		font-size: calc(30 / 430 * 100vw);
	}
}

.grid-table {
	display: grid;
    grid-template-columns: 100%;
	gap: 16px;
	margin-top: 70px;
}

.grid-table-item {
	color: #000000CC;
	background-color: #b8e1ff;
	display: grid;
    grid-template-columns: 3.6em 2fr 1fr 3.6em;
	align-items: center;
	gap: 12px 80px;
	padding: 23px 50px 23px 46px;
	font-size: 2.0rem;
	line-height: 1.5;
}

.grid-table-item:nth-child(odd) {
	background-color: #8bcdff;
}

.grid-table-item > p {
	padding: 0!important;
	margin: 0!important;
	text-align: left;	
}

.grid-table-item.item-heading {
	color: #ffffff;
	background-color: #309cec;
	font-size: 2.4rem;
    grid-template-columns: 3em 2fr 1fr 3em;
}

.grid-table-item > .cell-heading {
    grid-column: 1 / 2;
}
.grid-table-item > *:nth-child(2),
.grid-table-item > *:nth-child(3n + 5) {
    grid-column: 2 / 3;
}
.grid-table-item > *:nth-child(3),
.grid-table-item > *:nth-child(3n + 6) {
    grid-column: 3 / 4;
}
.grid-table-item:not(.item-heading) > *:nth-child(4),
.grid-table-item:not(.item-heading) > *:nth-child(3n + 7) {
    grid-column: 4 / 5;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: right;
}

.grid-table-item > .heading-text {
}

@media screen and (min-width: 751px) and (max-width: 879px){
	.grid-table {
		gap: calc(16 / 879 * 100vw);
		margin-top: calc(70 / 879 * 100vw);
	}
	
	.grid-table-item {
		gap: calc(12 / 879 * 100vw) calc(80 / 879 * 100vw);
		padding: calc(23 / 879 * 100vw) calc(50 / 879 * 100vw) calc(23 / 879 * 100vw) calc(46 / 879 * 100vw);
		font-size: calc(20 / 879 * 100vw);
	}

	.grid-table-item.item-heading {
		font-size: calc(24 / 879 * 100vw);
	}

	.grid-table-item > *:nth-child(4),
	.grid-table-item > *:nth-child(3n + 7) {
		font-size: calc(24 / 879 * 100vw);
	}
}

@media screen and (max-width: 750px) {
	.grid-table {
		gap: calc(8 / 430 * 100vw);
		margin-top: calc(30 / 879 * 100vw);
	}

	.grid-table-item {
		gap: calc(20 / 430 * 100vw) calc(3 / 430 * 100vw);
		padding: calc(17 / 430 * 100vw) calc(15 / 430 * 100vw) calc(11 / 430 * 100vw);
		font-size: calc(14 / 430 * 100vw);
	}

	.grid-table-item.item-heading {
		font-size: calc(18 / 430 * 100vw);
		grid-template-columns: 2.8em 2fr 1fr 3em;
	}

	.grid-table-item > *:nth-child(4),
	.grid-table-item > *:nth-child(3n + 7) {
		font-size: calc(18 / 430 * 100vw);
	}
}

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

#data-application .summary .section-heading {
	margin-bottom: 0;
}

#data-application .fees {
	padding-top: 22px;
	padding-bottom: 150px;
}

#data-application .achievement {
	padding-top: 116px;
	padding-bottom: 100px;
}

@media screen and (min-width: 751px) and (max-width: 879px) {
	#data-application .fees {
		padding-top: calc(22 / 879 * 100vw);
		padding-bottom: calc(150 / 879 * 100vw);
	}

	#data-application .achievement {
		padding-top: calc(116 / 879 * 100vw);
		padding-bottom: calc(100 / 879 * 100vw);
	}
}

@media screen and (max-width: 750px) {
	#data-application .summary {
		padding-top: calc(30 / 430 * 100vw);
	}

	#data-application .fees {
		padding-top: calc(16 / 430 * 100vw);
		padding-bottom: calc(74 / 430 * 100vw);
	}

	#data-application .fees .section-title {
		margin-bottom: calc(5 / 430 * 100vw);
	}

	#data-application .achievement {
		padding-top: calc(30 / 430 * 100vw);
		padding-bottom: calc(50 / 430 * 100vw);
	}
}