@charset "utf-8";
/* CSS Document */

#mainVisual{
	position: relative;
	max-width: 1401px;
	width: calc(100% - 30px);
	aspect-ratio: 1401/601;
	margin: 0 auto;
}

#mainVisual .btnWrap{
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: center;
	position: absolute;
	right: 32px;
	bottom: 32px;
	overflow: hidden;
	padding: 0 20px 20px;
}

#mainVisual .forFirst{
	border-radius: 50%;
	background: #3a520a;
	width: 120px;
	aspect-ratio: 1/1;
	overflow: hidden;
	transition: 0.3s cubic-bezier(0.55, 0.05, 0.57, 1.16);
	position: relative;
	z-index: 30;
}
#mainVisual .forFirst:hover{
	background: #649209;
}
#mainVisual .forFirst a{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	color: #fff;
	font-size: var(--fs-base);
}
#mainVisual .forFirst a::before{
	content: "";
	display: block;
	background: url("../img/icon_book.png") no-repeat center / contain;
	width: 26px;
	height: 32px;
	margin-bottom: 12px;
}

#mainVisual .loginBtn-box{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	background: #e06024;
	width: 200px;
	aspect-ratio: 1/1;
	margin-top: 24px;
	padding-bottom: 14px;
	position: relative;
}
#mainVisual .loginBtn-box::before{
	content: "";
	display: block;
	background: url("../img/icon_signin.png") no-repeat center / contain;
	width: 44px;
	height: 43px;
	margin-bottom: 16px;
	transform: translateX(3px);
}
#mainVisual .loginBtn-box::after{
	content: "";
	display: block;
	background: url("../img/decoration_txt.svg") no-repeat center / contain;
	width: 226px;
	aspect-ratio: 1/1;
	position: absolute;
	top: -13px;
	left: -13px;
	animation: rotation 14s linear infinite;
}
@keyframes rotation {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(-360deg);
	}
}

#mainVisual .loginBtn-box .newReg{
	display: block;
	background: #fff;
	border-radius: 6px;
	color: #e06024;
	font-weight: 700;
	width: calc(100% - 40px);
	margin: 0 auto;
	padding: 15px 10px 16px;
	transition: background 0.3s cubic-bezier(0.55, 0.05, 0.57, 1.16);
	position: relative;
	z-index: 20;
	line-height: 1.2;
}
#mainVisual .loginBtn-box .newReg:hover{
	background: #ffe8de;
}
#mainVisual .loginBtn-box .logIn{
	color: #fff;
	text-decoration: underline;
	font-weight: 500;
	font-size: var(--fs-base);
	margin-top: 8px;
	position: relative;
	z-index: 20;
}
#mainVisual .loginBtn-box .logIn:hover{
	text-decoration: none;
}



#sec_jobSearch{
	padding: 100px 0;
}
#sec_jobSearch > .contents{
	border: solid 4px #3a520a;
	border-radius: 40px;
	overflow: hidden;
}

#sec_jobSearch .ttl{
	font-size: var(--fs-4xl);
	color: #3a520a;
	background: #d5eba0;
	padding: 9px 15px 13px;
}

#sec_jobSearch form{
	padding: 27px 36px 40px;
}

#sec_jobSearch .item{
	text-align: left;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	width: 100%;
	padding: 15px 0;
	border-bottom: dotted 1px #999;
}

#sec_jobSearch .item .item-ttl{
	width: 210px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-shrink: 0;
	font-size: var(--fs-lg);
	font-weight: 700;
}
#sec_jobSearch .item .item-ttl::before{
	content: "";
	display: block;
	width: 50px;
	height: 50px;
	flex-shrink: 0;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	margin-right: 19px;
}
#sec_jobSearch .item .item-ttl.jobType::before{
	background-image: url("/common/img/icon/icon_jobtype.png")
}
#sec_jobSearch .item .item-ttl.jobKind::before{
	background-image: url("/common/img/icon/icon_type.png")
}
#sec_jobSearch .item .item-ttl.workStyle::before{
	background-image: url("/common/img/icon/icon_employmenttype.png")
}
#sec_jobSearch .item .item-ttl.freeWord::before{
	background-image: url("/common/img/icon/icon_freeword.png")
}
#sec_jobSearch #submit{
	margin-top: 27px;
}
#sec_jobSearch form .item-box-checkbox{
	max-width: 830px;
}


/* お知らせセクション */
#sec_info{
  padding: 80px 0;
}
#sec_info h2{
  font-size: var(--fs-4xl);
  color: #3a520a;
  margin-bottom: 30px;
}
#sec_info .infoList{
  max-width: 900px;
  margin: 0 auto;
  border: solid 2px #d5eba0;
  border-radius: 20px;
  overflow: hidden;
}
#sec_info a.infoItem{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  border-bottom: dotted 1px #ccc;
  color: #333;
  text-decoration: none !important;
  transition: background 0.2s ease;
  font-size: var(--fs-base);
}
#sec_info .infoItem:last-child{
  border-bottom: none;
}
#sec_info .infoItem:hover{
  background: #f5f9ea;
}
#sec_info .infoItem .date{
  color: #666;
  flex-shrink: 0;
  font-family: 'Roboto', arial, sans-serif;
  font-weight: 500;
}
#sec_info .infoItem .category-badge{
  display: inline-block;
  width: 5em;
  padding: 2px 0;
  border-radius: 3px;
  font-size: var(--fs-xs);
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  text-align: center;
}
#sec_info .infoItem .category-badge.cat-1{
  background: #3a520a;
}
#sec_info .infoItem .category-badge.cat-2{
  background: #e06024;
}
#sec_info .infoItem .ttl{
  font-weight: 500;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
#sec_info .noData{
  text-align: center;
  padding: 30px;
  color: #999;
  font-size: var(--fs-base);
}
#sec_info .btn{
  margin-top: 30px;
  max-width: 240px;
}

#sec_news{
	background: #d5eba0;
	padding: 117px 0 100px;
}
#sec_news > .contents{
	padding: 56px 36px 36px;
	border: solid 4px #fff;
}
#sec_news h2{
	font-size: var(--fs-4xl);
	width: calc(100% - 120px);
	margin: -2.5em auto 34px;
	background: #d5eba0;
	position: relative;
	z-index: 1;
}
#sec_news > .contents .btn{
	margin-top: 40px;
}
.newsContainer{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
	gap: 20px;
}

.newsContainer .card{
	max-width: 360px;
	width: calc(100% / 3 - 13.333px);
}

.newsContainer .card a{
	display: block;
	color: #000;
	background: #fff;
	text-align: left;
	width: 100%;
	height: 100%;
	border-radius: 20px;
	overflow: hidden;
	border: solid 2px #d5eba0;
	text-decoration: none !important;
	transition: 0.3s cubic-bezier(0.55, 0.05, 0.57, 1.16);
}

.newsContainer .card a:hover{
	border: solid 2px #3a520a;
	box-shadow: 5px 5px 10px rgba(0,0,0,0.15);
	transform: translateY(-4px);
}

.newsContainer figure{
	overflow: hidden;
}
.newsContainer figure img{
	transition: transform 0.4s cubic-bezier(0.55, 0.05, 0.57, 1.16);
}
.newsContainer .card a:hover figure img{
	transform: scale(1.03);
}

.newsContainer figure{
	aspect-ratio: 360/220;
}
	.newsContainer figure img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}

.newsContainer .txtBox{
	padding: 17px 20px;
	overflow: hidden;
}

.newsContainer .card .ttl{
	font-size: var(--fs-xl);
	color: #3a520a;
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-height: 1.4;
	height: 57px;
}
	.newsContainer .card .ttl span{
		display: inline;
		background: linear-gradient(#3a520a, #3a520a) 0 100%/0 1px no-repeat;
		transition: background 0.5s cubic-bezier(0.55, 0.05, 0.57, 1.16);
	}
	@media screen and (min-width: 769px){
		.newsContainer .card a:hover .ttl span{
			background-size: 100% 1px;
			text-decoration: none;
		}
	}

.newsContainer .card .credit{
	display: -webkit-box;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	text-align: right;
	color: #666666;
	font-size: var(--fs-base);
	margin-top: 0.8em;
}

.newsContainer .card .content{
	display: -webkit-box;
	font-size: var(--fs-base);
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-height: 1.571;
	margin-top: 0.8em;
	height: 44px;
}

.newsContainer .card .job-info{
	margin-top: 1em;
}

.newsContainer .card .job-info li{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: var(--fs-base);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.newsContainer .card .job-info li + li{
	margin-top: 10px;
}
.newsContainer .card .job-info li::before{
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	flex-shrink: 0;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	margin-right: 10px;
}
.newsContainer .card .job-info li.salary::before{
	background-image: url("/common/img/icon/icon_salary.png");
}
.newsContainer .card .job-info li.place::before{
	background-image: url("/common/img/icon/icon_place.png");
}
.newsContainer .card .job-info li.time::before{
	background-image: url("/common/img/icon/icon_time.png");
}

/* 事業者セクション */
#sec_companies{
	padding: 80px 0;
	text-align: center;
}
#sec_companies h2{
	font-size: var(--fs-4xl);
	color: #3a520a;
	margin-bottom: 20px;
}
#sec_companies .sec-lead{
	font-size: var(--fs-lg);
	color: #333;
	margin-bottom: 30px;
	line-height: 1.8;
}
#sec_companies .btn{
	max-width: 320px;
}

@media screen and (max-width: 1280px){
	#mainVisual .btnWrap{
		right: 0;
		bottom: 0;
	}
	
	#mainVisual .forFirst{
		width: 90px;
	}
		#mainVisual .forFirst a{
			font-size: var(--fs-2xs);
		}
		#mainVisual .forFirst a::before{
			margin-bottom: 4px;
		}
	
	#mainVisual .loginBtn-box{
		margin-top: 16px;
		padding-bottom: 9px;
		width: 140px;
	}
		#mainVisual .loginBtn-box::before{
			margin-bottom: 4px;
			width: 38px;
			height: 37px;
		}
		#mainVisual .loginBtn-box::after{
			width: 166px;
		}
	
	#mainVisual .loginBtn-box .newReg,
	#mainVisual .loginBtn-box .logIn{
		font-size: var(--fs-xs);
	}
	
	#mainVisual .loginBtn-box .newReg{
		padding: 8px 5px;
		width: calc(100% - 30px);
	}
	#mainVisual .loginBtn-box .logIn{
		margin-top: 3px;
	}
	
}
@media screen and (max-width: 850px){
	#sec_news > .contents{
		padding: 54px 20px 36px;
	}
	.newsContainer{
		justify-content: space-between;
	}
	.newsContainer .card{
		width: calc(100% / 2 - 10px);
	}
}

@media screen and (max-width: 767px){
	#mainVisual{
		aspect-ratio: 671/1070;
		padding-bottom: 52px;
	}
	#mainVisual .btnWrap{
		padding: 0 14px;
		right: -10px;
	}
	
	#mainVisual .loginBtn-box{
		padding-bottom: 5px;
		width: 120px;
	}
	#mainVisual .loginBtn-box::before{
		margin-bottom: 9px;
	}
	#mainVisual .loginBtn-box::after {
		width: 140px;
		top: -10px;
		left: -10px;
	}
	
	#mainVisual .loginBtn-box .newReg{
		width: calc(100% - 50px);
	}
	#mainVisual .btnWrap .logIn.spStyle{
		color: #e06024;
		font-size: var(--fs-xs);
		text-decoration: underline;
		display: inline-block;
		margin-top: 20px;
	}
	
	#sec_info{
		padding: 50px 0;
	}
	#sec_info h2{
		font-size: var(--fs-3xl);
		margin-bottom: 20px;
	}
	#sec_info .infoItem{
		flex-wrap: wrap;
		gap: 4px 8px;
		padding: 12px 15px;
	}
	#sec_info .infoItem .ttl{
		width: 100%;
		white-space: normal;
		-webkit-line-clamp: 2;
		display: -webkit-box;
		-webkit-box-orient: vertical;
	}
	#sec_info .btn{
		margin-top: 20px;
	}
	#sec_jobSearch,
	#sec_news{
		padding: 60px 0;
	}
	#sec_companies{
		padding: 50px 0;
	}
	#sec_companies h2{
		font-size: var(--fs-3xl);
	}
	#sec_jobSearch > .contents{
		border-width: 2px;
	}
	#sec_jobSearch form{
		padding: 10px 15px 30px;
	}
	form .item-box{
		margin-top: 10px;
	}
	#sec_jobSearch .item{
		flex-direction: column;
	}
	#sec_jobSearch .ttl{
		font-size: var(--fs-3xl);
	}
	#sec_jobSearch .item .item-ttl{
		font-size: var(--fs-md);
		width: 160px;
	}
	#sec_jobSearch .item .item-ttl::before{
		margin-right: 9px;
		width: 40px;
		height: 40px;
	}
	
	#sec_news > .contents{
		padding: 26px 15px 26px;
	}
	#sec_news h2{
		font-size: var(--fs-3xl);
		margin-top: -1.8em;
		width: calc(100% - 100px);
	}
	#sec_news > .contents .btn{
		margin-top: 20px;
	}
	
	.newsContainer .card .ttl{
		font-size: var(--fs-lg);
		height: 52px;
	}
}
@media screen and (max-width: 500px){
	.newsContainer{
		justify-content: center;
	}
	.newsContainer .card{
		width: 100%;
	}
}
@media screen and (max-width: 320px){
	#mainVisual{
		padding-bottom: 102px;
	}
}