@charset "utf-8";
/* CSS Document */

#sec_jobs{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	position: relative;
	z-index: 10;
}

/* ------------------------------------------------------------------------ */

/*  #searchContainer

/* ------------------------------------------------------------------------ */

#searchContainer{
	margin-right: 30px;
	border: solid 2px #3a520a;
	border-radius: 20px;
	overflow: hidden;
	flex: 224 1 0%;
	min-width: 220px;
}

#searchContainer .ttl{
	font-size: var(--fs-2xl);
	color: #3a520a;
	background: #d5eba0;
	padding: 9px 15px 13px;
}
#searchContainer .ttl.sp-accordion{
	display: none;
}

#searchContainer form{
	padding: 0 15px 30px;
}

#searchContainer .item{
	text-align: left;
	padding: 15px 0;
	border-bottom: dotted 1px #999;
}

#searchContainer .item .item-ttl{
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-shrink: 0;
	font-size: var(--fs-md);
	font-weight: 700;
	margin-bottom: 10px;
}
#searchContainer .item .item-ttl::before{
	content: "";
	display: block;
	width: 24px;
	height: 24px;
	flex-shrink: 0;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	margin-right: 9px;
}
#searchContainer .item .item-ttl.jobType::before{
	background-image: url("/common/img/icon/icon_jobtype.png")
}
#searchContainer .item .item-ttl.jobKind::before{
	background-image: url("/common/img/icon/icon_type.png")
}
#searchContainer .item .item-ttl.workStyle::before{
	background-image: url("/common/img/icon/icon_employmenttype.png")
}
#searchContainer .item .item-ttl.freeWord::before{
	background-image: url("/common/img/icon/icon_freeword.png")
}

#searchContainer #submit{
	margin-top: 15px;
}
#searchContainer #reset{
	display: inline-block;
	background: #999;
	color: #fff;
	border-radius: 8px;
	padding: 10px 25px;
	font-size: var(--fs-base);
	font-weight: 700;
	text-decoration: none;
	transition: 0.3s;
	margin-top: 20px;
	border: none;
	cursor: pointer;
}
#searchContainer #reset:hover{
	background: #3c3c3c;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* form reset style */
#searchContainer form .item-box{
	width: 100%;
}
#searchContainer form .item-box-checkbox{
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
}
#searchContainer form .item-box-checkbox li{
	margin-bottom: 0;
}
#searchContainer form .checkInput{
	padding-right: 0.5em;
}

#searchContainer form .checkInput .checkBox{
	padding: 4px 0 4px 28px;
}
#searchContainer form .checkInput .checkBox::before{
	width: 20px;
	height: 20px;
	top: 3px;
}
#searchContainer form .checkInput .checkBox::after{
	font-size: var(--fs-md);
	top: 3px;
	left: 3px;
}

@media screen and (min-width: 961px){
	#searchContainer form{
		display: block !important;
	}
}
@media screen and (max-width: 960px){
	#sec_jobs{
		flex-direction: column;
	}
	#searchContainer{
		margin: 0 auto 20px;
		flex: none;
		width: 100%;
	}
	#searchContainer .ttl{
		display: none;
	}
	#searchContainer .ttl.sp-accordion{
		display: block;
		padding: 9px 15px 10px;
		position: relative;
	}
	#searchContainer .ttl.sp-accordion::before{
		display: block;
		content: "検索条件を絞り込む";
		font-weight: 700;
	}
	#searchContainer .ttl.sp-accordion::after{
		content: "\f078";
		font-family: 'FontAwesome';
		position: absolute;
		right: 15px;
		top: calc(100% / 2 - 0.684em);
		transition: transform 0.3s ease;
	}
	#searchContainer .ttl.sp-accordion.active::after{
		transform: rotate(180deg);
	}
	#searchContainer form{
		display: none;
	}
}
@media screen and (max-width: 374px){
	#searchContainer .ttl{
		font-size: var(--fs-2xl);
	}
}

/* ------------------------------------------------------------------------ */

/*  #resultContainer

/* ------------------------------------------------------------------------ */

#resultContainer{
	flex: 750 1 0%;
	min-width: 0;
}

#resultContainer .result-nav{
	align-items: center;
	margin-bottom: 20px;
}

#resultContainer .result-nav .selectBox{
	max-width: 240px;
	width: 90%;
	margin-left: 20px;
}

#sec_result .card{
	border: solid 1px #ccc;
	border-radius: 20px;
	text-align: left;
	padding: 30px 40px;
	margin-bottom: 20px;
	overflow: hidden;
}

#sec_result .card .card-body{
	display: flex;
	gap: 20px;
	align-items: flex-start;
}
#sec_result .card .card-text{
	flex: 1;
	min-width: 0;
}
#sec_result .card .card-thumb{
	flex-shrink: 0;
	width: 200px;
	height: 150px;
	border-radius: 10px;
	overflow: hidden;
}
#sec_result .card .card-thumb img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#sec_result .card .data{
	text-align: right;
	font-size: var(--fs-base);
}

#sec_result .card .ttl{
	font-size: var(--fs-2xl);
	color: #3a520a;
	margin-top: 15px;
}

#sec_result .card .credit{
	text-align: right;
	font-size: var(--fs-base);
	color: #666;
	margin-top: 1em;
}

#sec_result .card .content{
	margin-top: 1em;
	font-size: var(--fs-md);
}

#sec_result .job-info{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
}
#sec_result .job-info dl{
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
	width: calc(100% / 2);
	box-sizing: border-box;
	font-size: var(--fs-md);
	margin-top: 20px;
	padding-right: 15px;
}

#sec_result .job-info dt{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-shrink: 0;
	font-weight: 700;
	margin-right: 0;
	margin-bottom: 5px;
}
#sec_result .job-info dd{
	min-width: 0;
	word-break: break-word;
}
#sec_result .job-info dt::before{
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	flex-shrink: 0;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	margin-right: 10px;
}
#sec_result .job-info .salary dt::before{
	background-image: url("/common/img/icon/icon_salary.png");
}
#sec_result .job-info .place dt::before{
	background-image: url("/common/img/icon/icon_place.png");
}
#sec_result .job-info .style dt::before{
	background-image: url("/common/img/icon/icon_employmenttype.png");
}
#sec_result .job-info .time dt::before{
	background-image: url("/common/img/icon/icon_time.png");
}

#sec_result .card .next{
	text-align: center;
	border-top: dotted 1px #999;
	margin-top: 20px;
	padding-top: 20px;
}

#sec_result .card .next .btn{
	max-width: 320px;
	padding: 14px 20px;
	font-size: var(--fs-lg);
}

/* ピックアップ */
#sec_result .card.pickup{
	position: relative;
	background: #fffee5;
	border: solid 2px #e06024;
	margin-bottom: 40px;
}
#sec_result .card.pickup::before{
	content: "ピックアップ";
	background: #e06024;
	color: #fff;
	position: absolute;
	top: 0;
	left: 18px;
	font-size: var(--fs-base);
	font-weight: 700;
	width: 110px;
	text-align: center;
	padding: 4px 0 5px;
}

#sec_result .card .lead{
	background: #fff;
	border: solid 1px #e06024;
	padding: 10px;
	margin-top: 10px;
	font-size: var(--fs-base);
	font-weight: 700;
	color: #e06024;
	line-height: 1.3;
}

@media screen and (max-width: 767px){
	#resultContainer .result-nav{
		flex-direction: column;
	}
	#resultContainer .result-nav .selectBox{
		margin: 20px 0 0 auto;
	}
	#sec_result .card{
		padding: 20px 15px;
	}
	#sec_result .card.pickup{
		padding-top: 35px;
	}
	#sec_result .card.pickup::before{
		width: 86px;
	}

	#sec_result .card .card-body{
		flex-direction: column;
	}
	#sec_result .card .card-thumb{
		width: 100%;
		height: 180px;
		order: -1;
	}
	#sec_result .job-info{
		flex-direction: column;
	}
	#sec_result .job-info dl{
		margin-top: 10px;
		width: 100%;
	}
	#searchContainer .ttl{
		font-size: var(--fs-2xl);
	}
}

/* no result
--------------------------------------------------------------------------- */

.no_result{
	text-align: center;
	padding: 40px 20px;
	color: #666;
	font-size: var(--fs-lg);
}

/* ------------------------------------------------------------------------ */

/*  pagination

/* ------------------------------------------------------------------------ */

.pagination{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 5px;
	margin-top: 30px;
	padding-bottom: 10px;
	flex-wrap: wrap;
}
.pagination a,
.pagination span{
	display: inline-block;
	padding: 8px 14px;
	border: 1px solid #ccc;
	text-decoration: none;
	color: #333;
	border-radius: 4px;
	font-size: var(--fs-base);
	line-height: 1;
	transition: background-color 0.2s ease, color 0.2s ease;
}
.pagination .active{
	background: #3a520a;
	color: #fff;
	border-color: #3a520a;
	font-weight: 700;
}
.pagination a:hover{
	background: #f0f0f0;
}
.pagination .disabled{
	color: #999;
	pointer-events: none;
	cursor: default;
}
.pagination .dots{
	border: none;
	padding: 8px 6px;
	color: #999;
}

@media screen and (max-width: 767px){
	.pagination{
		gap: 3px;
		margin-top: 20px;
	}
	.pagination a,
	.pagination span{
		padding: 6px 10px;
		font-size: var(--fs-sm);
	}
}

/* 企業情報テーブル最終行のボーダー非表示
   ※ border は tr に設定されているため tr を対象にする
--------------------------------------------------------------------------- */

.infoContainer .tblStyle01 tr:last-child{
	border-bottom: none;
}
