@charset "UTF-8";

/* ===================================================================
	求人の共通css
=================================================================== */

input:focus {
background-color: var(--bs-dorapita03);
}


/* 全体 */
.job_detail {
}
.job_detail_wrap {
	max-width: var(--def-max-width);
	width: var(--def-width);
	margin: 0 auto;
	filter: drop-shadow(0px 2px 2px rgba(0,0,0,0.2));
}

/* 求人内容 */
.job_detail_inner {
	position: relative;
	padding: 40px 5.7% 75px;
	border-radius: 10px;
	border: solid 5px var(--bs-dorapita03);
	background: var(--main-bg-color);
}


/* タブ */
.job_tab {
	position: relative;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-evenly;
	max-width: 450px;
	width: 94%;
	margin: 0 3% -5px;
}
.job_tab li {
	width: 45%;
	color: var(--bs-dark);
	font-weight: 700;
	text-align: center;
}
.job_tab li a,
.job_tab li span {
	display: block;
	height: 100%;
	padding: 10px 0;
	border-radius: 10px 10px 0 0;
	border: solid 5px var(--bs-dorapita03);
	border-bottom: none;
}
.job_tab li a {
	background: var(--bs-dorapita03);
	transition: all .3s;
}
.job_tab li a:hover {
	background: var(--bs-dorapita04);
	border-color: var(--bs-dorapita04);
}
.job_tab li.current span {
	background: var(--main-bg-color);
	color: var(--bs-dorapita);
}


/* NEWアイコン */
.icon_new {
	display: inline-block;
	position: relative;
	width: 3.6em;
	height: 2em;
	margin-right: 25px;
	padding: 0;
	background: var(--bs-primary-dark);
	line-height: 2;
	text-align: center;
	font-size: 1rem;
	color: var(--bs-white);
}
.icon_new:before {
	position: absolute;
	content: '';
	right: -13px;
	top: 0;
	border: none;
	border-left: solid 13px var(--bs-primary-dark);
	border-bottom: solid 2em transparent;
}
.sp_icon_new {
	display: none;
}


/* キープボタン */
.keep_btn {
	position: absolute;
	top: 15px;
	right: 15px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 1.8em;
	height: 1.8em;
	border-radius: 50%;
	border: 1px solid var(--bs-dorapita03);
	background: #fff;
	line-height: 1.8;
	text-align: center;
	font-size: 18px;
	color: var(--bs-dorapita04);
	z-index: 99;
	cursor: pointer;
}
.keep_btn.active {
	border: 1px solid var(--bs-primary);
	color: var(--bs-primary);
}


/* 求人のタグ */
.job_tag,
a.job_tag {
	display: inline-block;
	margin-right: 5px;
	margin-bottom: 5px;
	padding: .3em .4em;
	background: var(--bs-white);
	border: 1px solid var(--bs-dorapita02);
	border-radius: 3px;
	font-size: .85rem;
	color: var(--bs-dorapita02);
}
.job_tag:last-of-type,
a.job_tag:last-of-type {
	margin-right: 0;
}


#fixed_recruit_entry {
	display: none;
}


/* XX-Large devices (larger desktops, 1400px and up) */
@media (max-width: 1400px) {
	
}


/* X-Large devices (large desktops, 1200px and up) */
@media (max-width: 1200px) {
	
	
}

/* Large devices (desktops, 992px and up) */
@media (max-width: 992px) {
	/* 全体 */
	.job_detail {
		padding-bottom: 80px;
	}
}


/* Medium devices (tablets, 768px and up) */
@media (max-width: 768px) {
	/* 求人内容 */
	.job_detail_inner {
		padding: 20px;
	}

}


/* Small devices (landscape phones, 576px and up) */
@media (max-width: 576px) {
	/* タブ */
	.job_tab li a,
	.job_tab li span {
		padding: 5px 0 7px;
	}
	
	/* 固定フッター */
	/*
	#fixed_recruit_entry {
		display: block;
		width: var(--def-width);
		margin: 0 auto;
		padding: 0;
		height: 0px;
		position: fixed;
		z-index: 300;
		bottom: 0;
		left: 0;
		right: 0;
		overflow: none;
		border-radius: 20px 20px 0 0;
		background: var(--bs-dark);
		color: var(--bs-white);
		-moz-transition: all 0.4s ease-in-out;
		-o-transition: all 0.4s ease-in-out;
		transition: all 0.4s ease-in-out;
		-webkit-transition: all 0.4s ease-in-out;
	}
	#fixed_recruit_entry.show {
		height: auto;
		-moz-transition: all 0.4s ease-in-out;
		-o-transition: all 0.4s ease-in-out;
		transition: all 0.4s ease-in-out;
		-webkit-transition: all 0.4s ease-in-out;
		padding: 10px 15px;
	} */
	
	#fixed_recruit_entry {
		display: block;
		width: auto;
		margin: 0 0 -25px;
		padding: 15px;
		position: sticky;
		z-index: 300;
		bottom: 83px;
		border-radius: 20px 20px 0 0;
		background: rgba(33,33,33, 0.8);
		color: var(--bs-white);
		
		transition: all 0.4s ease-in-out;
	}
	div.btn_hide{
		transform: translateY(+60px);
	}
	.fixed_recruit_entry_title {
		margin-bottom: 3px;
		font-weight: 700;
		font-size: 0.9rem;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	#fixed_recruit_entry .company_name {
		margin-bottom: 15px;
		color: #BADBDC;
		font-size: 0.9rem;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	.sp_btn_area {
		display: flex;
		align-items: stretch;
		justify-content: space-between;
	}
	a.f_btn_tel,
	a.f_btn_entry,
	div.f_btn_entry {
		flex-shrink: 1;
		flex-grow: 1;
		display: flex;
		align-items: center;
		justify-content: center;
		margin-right: 10px;
		padding: .7em .5em;
		background: linear-gradient(-25deg,#F7931E 0%,#F7931E 50%,#F68500 50%,#F68500 100%);
		color: var(--bs-white);
		font-size: 1.3rem;
		font-weight: 500;
		line-height: 1;
	}
	a.f_btn_tel i,
	a.f_btn_entry i,
	div.f_btn_entry i {
		margin-right: .5em;
		font-size: 95%;
	}
	a.f_btn_entry,
	div.f_btn_entry,
	a.f_btn_tel,
	.f_btn_keep {
		border-radius: 10px;
	}
	/* お気に入りボタン */
	.f_btn_keep {
		flex-shrink: 0;
		flex-grow: 0;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		margin: 0;
		padding: 5px 6px;
		height: auto;
		background: var(--bs-white);
		color: var(--bs-dark);
		font-size: 0.5rem;
		text-align: center;
		font-weight: bold;
	}
	.f_btn_keep span {
		display: block;
		margin-bottom: 5px;
		color: #A6D0D2;
		font-size: 1rem;
	}
	
	/* キープ中 */
	.f_btn_keep.keep_now,
	.f_btn_keep.keep_now span {
		color: #F68500;
	}
}




@media (max-width: 479px) {
	a.f_btn_tel,
	a.f_btn_entry,
	div.f_btn_entry {
		font-size: 1rem;
	}
	
}











