@charset "UTF-8";

/* search_box 検索ボックス */
.search_box {
	padding: 12px 15px;
	border-radius: 5px;
}
.search_select_title {
	display: none;
}
.search_select {
	position: relative;
	display: inline-block;
	width: 100%;
	margin-bottom: 7px;
}
.search_select i {
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	color: #333;
}
.search_select select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	height: 40px;
	padding: 0 12px 0 36px;
	border: 1px solid #333;
	border-radius: 5px;
	background-color: #fff;
	font-size: 15px;
	color: #333;
	cursor: pointer;
}
.search_btn button {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 40px;
	background-color: #033282;
	color: #fff;
	border: none;
	padding: 0 20px;
	border-radius: 5px;
	font-size: 15px;
	text-align: center;
	cursor: pointer;
}

/* jobs 求人セクション */
.jobs_title {
	margin-bottom: 12px;
	font-size: 20px;
	font-weight: 500;
	color: #033282;
}
.jobs_info {
	font-size: 12px;
	display: flex;
	justify-content: flex-end;
	align-items: flex-end;
	gap: 0 20px;
	margin-bottom: 8px;
}
.jobs_info i {
	margin-right: 2px;
}
.jobs_info .count .num {
	display: inline-block;
	padding: 0 3px;
	color: #ff0000;
	font-size: 18px;
	font-weight: 600;
	line-height: 1;
}
.sort_box {
	display: flex;
	align-items: center;
	gap: 10px;
	width: fit-content;
	max-width: 50%;
	margin-bottom: 10px;
	padding: 0 15px;
	background-color: #fff;
	border-radius: 5px;
	border: .5px solid #eee;
	font-size: 13px;
	color: #333;
}
.sort_box select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	cursor: pointer;
}
.jobs_item {
	padding: 0 0 20px;
}
.item_top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 10px;
	margin-bottom: 6px;
}
.item_top .tags {
	flex-basis: auto;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 10px;
	line-height: 1;
	letter-spacing: 0;
}
.item_top .tags .tag {
	display: inline-block;
	padding: 3px 6px 4px;
	border-radius: 5px;
	border: 1px solid #FF0000;
	white-space: nowrap;
	color: #FF0000;
}
.item_top .tags .tag.employment_type {
	border-color: #033282;
	color: #033282;
}
.item_top .tags .tag.merit_tag {
	border-color: #73a0de;
	color: #73a0de;
}
.item_top .bookmark {
	flex-basis: 26px;
}
.item_top .bookmark .favorite-btn {
	width: 26px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 5px;
	border: 1px solid #033282;
	color: #033282;
	padding: 4px 6px 3px;
	font-size: 11px;
	cursor: pointer;
	outline: none;
	background-color: #FFF;
}
.item_top .bookmark i {
	font-weight: 400;
}
.item_top .bookmark.active i {
	font-weight: 900;
}
.item_title {
	margin-bottom: 6px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	color: #033282;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}
.item_date {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-bottom: 10px;
	font-size: 10px;
	letter-spacing: 0;
}
.item_date i {
	margin-right: 2px;
}
.item_info {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 2px 10px;
	margin-bottom: 10px;
	padding: 7px 10px;
	font-size: 10px;
	letter-spacing: 0;
}
.item_info > div {
	width: calc(50% - 5px);
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}
.item_info i {
	margin-right: 2px;
}
.item_btn {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
}
.item_btn a {
	display: inline-block;
	width: calc(50% - 5px);
	border-radius: 5px;
	padding: 10px 12px 10px 18px;
	font-size: 12px;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}
.item_btn a i {
	margin-left: 5px;
}
.item_btn .regist_btn {
	background-color: #FF0000;
	color: #fff;
}
.item_btn .tel_btn {
	background-color: #00cc00;
	color: #fff;
}
.jobs_pager {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 15px;
	margin-bottom: 20px;
	padding: 10px 15px;
	border-radius: 5px;
	color: #ccc;
	font-size: 14px;
}
.jobs_pager a {
	color: #ccc;
}
.jobs_pager a .fa-caret-right {
	color: #033282;
}
.jobs_pager a.active {
	color: #033282;
}

.gift_wrap {
	margin-bottom: 4px;
	padding: 5px 10px;
	border-radius: 5px;
	border: 2px solid #f39800;
	color: #f39800;
	font-size: 12px;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}
.gift_wrap .num {
	display: inline-block;
	padding: 0 2px;
	font-size: 16px;
}
.gift_text {
	margin-bottom: 10px;
	font-size: 10px;
	font-weight: 400;
	line-height: 1.5;
	text-align: justify;
}

.detail_title {
	position: relative;
	margin-bottom: 10px;
	padding: 4px 15px 4px 35px;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 500;
	background-color: #033282;
	color: #FFFFFF;
}
.detail_title i {
	position: absolute;
	top: 50%;
	left: 10px;
	transform: translateY(-50%);
	color: #FFFF09;
}

.page_link {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
}
.page_link a {
	display: inline-block;
	width: calc((100% - 20px) / 3);
	border-radius: 5px;
	padding: 8px 4px;
	font-size: 10px;
	font-weight: 400;
	line-height: 1;
	white-space: nowrap;
	text-align: center;
	background-color: #033282;
	color: #FFFFFF;
}
.page_link a i {
	margin-left: 1px;
}

.detail_content {
	margin-bottom: 20px;
	padding: 12px 15px;
	border-radius: 5px;
	background-color: #FFF;
}

.detail_img {
	width: 70%;
	max-width: 340px;
	margin: 0 auto 12px;
}
.detail_img img {
	aspect-ratio: 3 / 2;
	object-fit: cover;
}

.detail_lead {
	margin-bottom: 15px;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.75;
	text-align: justify;
}
.detail_text {
	margin-bottom: 15px;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.75;
	text-align: justify;
}

.detail_table {
	margin-bottom: 15px;
	border-collapse: collapse;
	border: 1px solid #333;
}
.detail_table tr {
	
}
.detail_table th {
	display: block;
	width: 100%;
	padding: 8px 15px;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.5;
	text-align: justify;
	background-color: #EEE;
}
.detail_table td {
	display: block;
	width: 100%;
	padding: 8px 15px;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.5;
	text-align: justify;
}

.tel_wrap {
	display: flex;
	align-items: center;
	gap: 15px;
}
.tel_wrap .right {
	font-size: 13px;
	font-weight: 500;
	white-space: nowrap;
}
.tel_wrap .left {
}
.tel_wrap .left .num {
	font-size: 30px;
	font-weight: 700;
	line-height: 1.2;
}
.tel_wrap .left .text {
	display: block;
	font-size: 12px;
	font-weight: 400;
}
.form_item {
	margin-bottom: 10px;
}
.form_item label {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 5px;
	font-size: 13px;
	font-weight: 500;
}
.form_item label span {
	display: inline-block;
	padding: 3px 6px;
	border-radius: 3px;
	background-color: #73a0de;
	font-size: 10px;
	line-height: 1;
	text-align: center;
	color: #FFFFFF;
}
.form_item label .req {
	background-color: #EF3939;
}
.form_item input[type="text"],
.form_item input[type="email"],
.form_item input[type="tel"],
.form_item select {
	width: 100%;
	height: 100%;
	min-height: 40px;
	font-size: 14px;
	line-height: 1.4;
	cursor: pointer;
	position: relative;
	background-color: #FFFFFF;
	border: solid 1px #C7CBD1;
	text-align: left;
	padding: 0.375rem 0.75rem;
	font-weight: 400;
	appearance: none;
	border-radius: 0.25rem;
}
.form_item input[type="date"] {
	width: 100%;
	height: 100%;
	min-height: 40px;
	font-size: 14px;
	line-height: 1.4;
	cursor: pointer;
	position: relative;
	background-color: #FFFFFF;
	border: solid 1px #C7CBD1;
	text-align: left;
	padding: 0.375rem 0.75rem;
	font-weight: 400;
	appearance: none;
	border-radius: 0.25rem;
}
.form_item textarea {
	width: 100%;
	height: 100%;
	min-height: 180px;
	font-size: 14px;
	line-height: 1.4;
	cursor: pointer;
	position: relative;
	background-color: #FFFFFF;
	border: solid 1px #C7CBD1;
	text-align: left;
	padding: 0.375rem 0.75rem;
	border-radius: 0.25rem;
	font-weight: 400;
	appearance: none;
}
.form_item input[type="radio"],
.form_item input[type="checkbox"] {
	position: absolute;
	clip: rect(0, 0, 0, 0);
	pointer-events: none;
}
.form_item input[type="radio"] + label,
.form_item input[type="checkbox"] + label {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	min-height: 60px;
	border-radius: 0.25rem;
	font-size: 13px;
	line-height: 1.4;
	cursor: pointer;
	position: relative;
	background-color: #FFFFFF;
	border: solid 1px #C7CBD1;
	text-align: left;
	padding: 0.375rem 0.75rem;
}
.form_item input[type="radio"]:checked + label,
.form_item input[type="checkbox"]:checked + label {
	border: solid 2px #12317D;
	background-color: #EEF4FD;
	font-weight: bold;
}
.form_item .input_wrap {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}
.form_item .input_wrap input,
.form_item .input_wrap label {
	width: calc((100% - 10px) /2);
}

.form_btn button {
	display: inline-block;
	background-color: #f39800;
	color: #FFF;
	width: 100%;
	border-radius: 5px;
	padding: 14px 12px 14px 18px;
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	text-align: center;
	outline: none;
	border: none;
}
.form_btn button i {
	margin-left: 5px;
}
.form_wrap p.sub_text {
	font-size: 11px;
}
.form_wrap p.sub_text a {
	color: #1a73e8;
}
.recaptcha_text {
	margin-top: 10px;
	font-size: 10px;
}
.recaptcha_text a {
	color: #1a73e8;
}








