@charset "utf-8";

/*==============================================================================
	
 【page.css】- ページ別スタイルシート
	
	各ページスタイルを記述しています。
	
	<目次>
	 # 共通
	 # ログイン
	 # 商品選択
	 # カート
	 # マイページ
	 # 求人一覧
	 # 求人詳細
	 # ACF
	 # Form
	 # Footer
	 # SiteColor

==============================================================================*/
/*--------------------------------------
	# 共通
--------------------------------------*/

@media all and (min-width:950px) {
div#container .flex-wrapper {
	display: flex;
	justify-content: space-between;
}
div#container .flex-wrapper .flex-inner {
	width: 49%;
}
}

/* link
--------------------*/
div#container a.detail-link,div#container span.detail-link,a.back_to_top_button {
	position: relative;
	display: inline-block;
	margin: 5px 10px;
	padding: 12px 20px 10px;
	background: #999;
	color: #FFF !important;
	text-align: left;
	line-height: 1.4;
	text-align: center;
	text-decoration: none;
	vertical-align: top;
	border-bottom: 3px solid rgba(0,0,0,0.2);
	border-radius: 3px;
	letter-spacing: 1px;
	transition: 0.3s;
}
div#container span.detail-link {
	opacity: 0.5;
}
div#container a.detail-link.gray {
	background: #8c8c8c !important;
}
div#container a.detail-link.orange {
	background: #ff6900 !important;
}
div#container a.detail-link.red {
	background: #d70c18 !important;
}
div#container a.link-icon {
	position: relative;
	padding-left: 18px;
}
div#container a.link-icon:before {
	content: '';
	position: absolute;
	top: 8px;
	left: 4px;
	width: 0;
	height: 0;
	border-left: 6px solid #000;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
}
div#container a.link-icon.back:before {
	transform: rotate(180deg);
}
div#container .link-pdf {
	position: relative;
	display: block;
	padding-left: 18px;
}
div#container .link-pdf:before {
	content: '\f1c1';
	position: absolute;
	top: 0;
	left: 0;
	color: #666;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
}
@media all and (min-width:950px) {
div#container a.detail-link:hover,a.back_to_top_button:hover {
	border-bottom: 3px solid rgba(0,0,0,0);
	transform: translateY(2px);
	opacity: 0.8;
}
div#container a[data-fancybox] {
	transition: 0.3s;
}
div#container a[data-fancybox]:hover {
	opacity: 0.7;
}
}

/*--------------------------------------
	# ログイン
--------------------------------------*/
#memberpages div.loginbox {
	width: auto;
	margin: 0 20px;
	padding-top: 30px;
}
#memberpages .loginbox p {
	margin-bottom: 1rem;
	padding: 0;
	font-size: 1.6rem;
	line-height: 1.8;
}
#memberpages .loginbox .form-btn input[type="submit"] {
	width: 100%;
	margin: 0 0 5px;
}
@media all and (min-width:950px) {
#memberpages div.loginbox {
	max-width: 540px;
	margin: 0 auto;
}
}

/*--------------------------------------
	# 商品選択
--------------------------------------*/
table.item-table th {
	padding: 6px 12px;
	text-align: center;
}

/*--------------------------------------
	# カート
--------------------------------------*/
div.usccart_navi ol.ucart {
	display: flex;
	height: auto;
	list-style: none;
	overflow: hidden;
}
div.usccart_navi ol.ucart li.ucart {
	flex: 1;
	display: block;
	float: none;
	width: auto;
	padding: 0 0 0 10px;
	background: #dedede;
	color: #999;
	font-size: 1.3rem;
	font-weight: 700;
	text-decoration: none;
	text-align: center;
	line-height: 40px;
}
div.usccart_navi ol.ucart li.ucart:first-child {
	padding: 0;
}
div.usccart_navi ol.ucart li:before {
	display: block;
	width: 5px;
	height: 20px;
	margin: 0 -5px -20px auto;
	float: right;
	content: " ";
	-webkit-transform: skew(20deg);
	background: #dedede;
	border-right: 4px solid #fff;
	-moz-transform: skew(20deg);
	-o-transform: skew(20deg);
	transform: skew(20deg);
}
div.usccart_navi ol.ucart li:after {
	display: block;
	width: 5px;
	height: 20px;
	margin: -20px -5px 0 auto;
	background: #dedede;
	border-right: 4px solid #fff;
	position: relative;
	content: " ";
	-webkit-transform: skew(-20deg);
	-moz-transform: skew(-20deg);
	-o-transform: skew(-20deg);
	transform: skew(-20deg);	
}
div.usccart_navi ol.ucart li:last-child:before,
div.usccart_navi ol.ucart li:last-child:after {
	border: none;
}
div.usccart_navi ol.ucart li[class*="usccart_"],
div.usccart_navi ol.ucart li[class*="usccart_"]:before,
div.usccart_navi ol.ucart li[class*="usccart_"]:after {
	background-color: #323232;
	color: #fff;
}

/* カートの中 */
#cart table#cart_table,#memberinfo table {
	border: none;
	border-top: 1px solid #c8c8c8;
	border-left: 1px solid #c8c8c8;
}
#cart table#cart_table th,#cart table#cart_table td {
	padding: 12px;
	border: none;
	border-bottom: 1px solid #c8c8c8;
	border-right: 1px solid #c8c8c8;
}
#cart table#cart_table th {
	padding: 6px 12px;
	background: #e5e5e5;
	color: #000;
	font-weight: 700;
}
#cart input.delButton {
	margin: 0;
	padding: 8px 20px;
	background: #c2c2c2 !important;
}
@media all and (max-width:949px) {
div.usccart_navi ol.ucart li.ucart {
	font-size: 2.6vw;
	white-space: nowrap;
}
#cart table#cart_table th, #cart table#cart_table td {
  padding: 6px;
}
#cart input.delButton {
	padding: 8px;
}
}

/* お客様情報／配送・支払方法 */
#customer-info .error_message,#delivery-info .error_message {
	font-size: 1.6rem;
	font-weight: 400;
}
#customer-info th,#customer-info td,#delivery-info th,#delivery-info td,#confirm_table th,#confirm_table td,#memberinfo th,#memberinfo td {
	border-color: #c8c8c8;
} 
#customer-info th,#delivery-info th,#memberinfo th {
	background-color: #e5e5e5;
	color: #323232;
	font-size: 1.4rem;
	font-weight: 700;
	vertical-align: middle;
} 
.customer_form th em {
	color: #F00;
	font-size: .8em;
	font-weight: 500;
}
#customer-info .customer_form input {
	width: 98%;
}
#customer-info .customer_form tr.inp2 input {
	width: 80%;
	margin: 1%;
}
.customer_form input#zipcode {
	width: 40%;
}
.customer_form input#search_zipcode {
	margin: 1%;
	background: #c2c2c2 !important;
}
#customer-info .customer_form input[type="checkbox"], #customer-info .customer_form input[type="radio"] {
	width: 15px;
	margin-right: 5px;
	vertical-align: middle;
}
#newmember .agree_member_area, #customer-info .agree_member_area {
	margin: 40px 20px;
	text-align: center;
}
#newmember .at_cont_text, #customer-info .at_cont_text {
	font-size: 1.2rem;
	line-height: 1.8;
}
#newmember .at_check_area, #customer-info .at_check_area {
	font-size: 1.6rem;
	font-weight: 700;
}
#customer-info td {
	font-size: 80%;
}
#delivery-info td,
#delivery-info .customer_form dt {
	font-size: 1.6rem;
}
@media all and (max-width:949px) {
#customer-info th,#customer-info td,#delivery-info th,#delivery-info td,#memberinfo table.customer_form th,#memberinfo table.customer_form td {
	display: block;
	width: auto;
	border: none;
	border-right: 1px solid #c8c8c8;
}
#customer-info td,#delivery-info td,#memberinfo table.customer_form td {
	border-bottom: 1px solid #c8c8c8;
}
#customer-info .customer_form tr.inp2 input {
	width: 98%;
}
#newmember .agree_member_area, #customer-info .agree_member_area {
	margin: 30px 0;
}
table.customer_form input[type="password"] {
	width: 98% !important;
}
}

/* クレジット決済 */
.ui-dialog-titlebar {
	height: auto !important;
	padding: 5px 36px 10px 16px !important;
}
#welcart .attention {
	padding-left: 1em;
	color: #666;
	font-size: 80%;
	text-indent: -1em;
	line-height: 1.6;
}
#error-page .error_page_mesage p {
	font-size: 1.6rem;
	color: #F00;
	text-align: center;
	line-height: 1.8;
}
#error-page p.return_settlement {
	clear: both;
	margin: 1em 0 0;
}
@media all and (max-width:949px) {
table#welcart th,table#welcart td {
	display: block;
	width: 100%;
}
table#welcart th {
	padding: 5px 10px;
	border-bottom: none;
}
}





/* 内容確認 */
.currency_code {
	color: #666;
	font-size: 1.4rem;
}
#confirm_table .ttl {
	background-color: #999;
}
div#main #confirm_table h3 {
	margin: 0px;
	padding: 0px;
	font-size: 1.6rem;
	color: #FFF;
	border-bottom: none;
}
#confirm_table th {
	background-color: #e5e5e5;
	color: #323232;
	font-size: 1.4rem;
}
#confirm_table td {
	font-size: 1.4rem;
}

/*--------------------------------------
	# マイページ
--------------------------------------*/
div#main .mypage-info-wrapper {
}
div#main .mypage-info-meta,div#main .mypage-info-news {
	padding: 20px;
	background: #FFF;
	border: 1px solid rgba(0,0,0,0.1);
}
div#main .contract-status p,
div#main .contract-status a {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0 0 1em;
	padding: 5px 30px 5px 15px;
	color: #FFF;
	font-weight: 500;
	text-decoration: none;
	overflow: hidden;
  transition: 0.2s;
}
div#main .contract-status.under p {
	background: #0693e3;
}
div#main .contract-status.no a {
	background: #c2c2c2;
}
div#main .contract-status .period {
	margin-right: auto;
	font-size: 1.4rem;
}
div#main .contract-status .btn {
	display: block;
	font-size: 1.2rem;
	opacity: 0.9;
}
div#main .contract-status a:before {
	content: '';
	position: absolute;
	top: 50%;
	right: 15px;
	display: block;
	width: 8px;
	height: 8px;
	border-top: 1px solid #FFF;
	border-right: 1px solid #FFF;
	transform: rotate(45deg) translate(0, -50%);
  transition: 0.2s;
}
div#main .contract-name {
	position: relative;
	padding: 0 0 0 90px;
	color: #323232;
	font-size: 2.2rem;
	font-weight: 500;
}
div#main .contract-name .number {
	position: absolute;
	top: 9px;
	left: 0;
	width: 6em;
	background: #323232;
	color: #FFF;
	font-size: 1.2rem;
	text-align: center;
	border-radius: 3px;
}
div#main .contract-name .mail {
	position: relative;
	display: block;
	padding-left: 20px; 
	font-size: 1.6rem;
	font-weight: 400;
}
div#main .contract-name .mail:before {
	content: '\f0e0';
	position: absolute;
	top: 0;
	left: 0;
	font-family: "Font Awesome 6 Free";
	font-size: 1.4rem;
	line-height: 30px;
}
#memberpages #memberinfo ul {
	padding: 0;
}
div#main ul.member_submenu {
	display: flex;
	justify-content: center;
}
#memberpages #memberinfo ul.member_submenu li {
	margin: 0 10px;
	font-size: 1.4rem;
	text-align: center;
}
#memberpages #memberinfo ul.member_submenu li a {
	position: relative;
	padding-left: 18px;
	text-decoration: none;
}
#memberpages #memberinfo ul.member_submenu li a:before {
	content: '';
	position: absolute;
	top: 6px;
	left: 6px;
	width: 0;
	height: 0;
	border-left: 6px solid #333;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
}
div#main .mypage-info-news h3.mypage-info-news-title {
	margin-bottom: 1rem;
}
#memberpages #memberinfo .mypage-info-news ul {
	height: 160px;
	overflow-y: scroll;
}
#memberpages #memberinfo .mypage-info-news ul li {
	position: relative;
	padding: 10px;
	border-bottom: 1px solid #EEE;
}
#memberpages #memberinfo .mypage-info-news ul li .data {
	display: block;
	color: #999;
	font-size: 1.2rem;
}
#memberinfo .history-area {
	height: auto;
}
#memberinfo th.historyrow {
	padding: 5px;
	font-size: 1.3rem;
	font-weight: 500;
	text-align: center;
}
#memberinfo td,#memberinfo td.order_number,#memberinfo td.purchase_date,#memberinfo td.purchase_price,#memberinfo td.discount,#memberinfo td.shipping,#memberinfo td.cod,#memberinfo td.tax {
	padding: 12px 5px;
	font-size: 1.4rem;
}
#memberinfo td, #memberinfo td.order_number a.detail-link {
	margin: 0;
	padding: 7px 15px 5px;
}
#memberinfo table.retail th {
	padding: 5px;
	border-top: none;
}
#memberinfo th.cartrownum {
	width: 50px;
}
#memberinfo th {
	text-align: left;
	line-height: 1.8;
	white-space: nowrap;
}
#memberinfo .customer_form input {
	width: 98%;
}
#memberinfo .customer_form input#address1, #memberinfo .customer_form input#address2, #memberinfo .customer_form input#address3,#memberpages input.loginmail,#memberpages input.loginpass {
	width: 98%;
}
.customer_form input#name1,
.customer_form input#name2,
.customer_form input#name3,
.customer_form input#name4{
	width: 82%;
	margin-left: 3px;
}
dl.important-info {
  padding: 15px;
	border: 3px solid #f00;
  background: #ffeaea;
	line-height: 1.4;
}
dl.important-info dt {
	margin-bottom: 0.5em;
	color: #f00;
  font-size: 17px;
  font-weight: bold;
}
dl.important-info dd {
	margin: 0 0 0 1em;
	font-size: 15px;
}
@media all and (max-width:949px) {
div#main .mypage-info-meta {
	margin: 0 0 20px;
}
#memberinfo .history-area {
	overflow-x: scroll;
}
#memberinfo .history-area table {
	width: 550px;
}
#memberinfo table.customer_form th {
	padding: 5px 10px;
}
}
@media all and (min-width:950px) {
div#main .mypage-info-wrapper {
	display: flex;
	justify-content: space-between;
}
div#main .mypage-info-meta {
	width: 40%;
}
div#main .mypage-info-news {
	width: 58%;
}
body.dv div#main .contract-status a:hover {
	opacity: 0.8;
}
body.dv div#main .contract-status a:hover:before {
	right: 10px;
}
body.dv #memberpages #memberinfo ul.member_submenu li a:hover {
	text-decoration: underline;
}
#memberpages #memberinfo .mypage-info-news ul li {
	padding: 10px 10px 10px 90px;
}
#memberpages #memberinfo .mypage-info-news ul li .data {
	position: absolute;
	top: 10px;
	left: 10px;
	width: 6em;
	margin: 0 20px 0 0;
}
#memberinfo .customer_form input#address1, #memberinfo .customer_form input#address2, #memberinfo .customer_form input#address3 {
	width: 80%;
}
.customer_form input#address1,
.customer_form input#address2,
.customer_form input#address3,
.customer_form input#tel,
.customer_form input#fax {
	width: 80%;
}
}

/*--------------------------------------
	# 領収書発行
--------------------------------------*/
div.receipt-wrapper {
	padding: 20px;
	background: #FFF;
	text-align: center;
	border: 1px solid rgba(0,0,0,0.1);
}
div.receipt-wrapper .receipt-title {
	margin: 10px 0 30px -10px;
	font-size: 2.6rem;
	font-weight: 500;
	letter-spacing: 10px;
}
div.receipt-wrapper .receipt-top {
	display: flex;
  justify-content: space-around;
	align-items: center;
	margin: 0 0 20px;
}
div.receipt-wrapper .receipt-name {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	width: 45%;
	font-size: 2.0rem;
	text-align: left;
	line-height: 1.4;
	border-bottom: 1px solid #000;
}
div.receipt-wrapper .receipt-name .fs-small {
	margin-left: 1em;
	white-space: nowrap;
}
div.receipt-wrapper .receipt-data {
	width: 50%;
	font-size: 1.3rem;
	text-align: right;
}
div.receipt-wrapper .receipt-item-price {
	padding: 20px 10px;
	background: rgba(0,0,0,0.1);
	line-height: 1.4;
}
div.receipt-wrapper .receipt-item-price-inner {
	display: inline-block;
	font-size: 1.8rem;
	font-weight: 500;
	text-align: left;
}
div.receipt-wrapper .receipt-item-price .receipt-item-name {
	display: block;
	font-size: 1.4rem;
	font-weight: 400;
}
div.receipt-wrapper .receipt-item-price-inner em {
	font-size: 3.0rem;
}
div.receipt-wrapper .receipt-item-price-sub {
	margin: 5px 0 20px;
}
div.receipt-wrapper .receipt-item-bottom {
	display: flex;
  justify-content: space-around;
	align-items: center;
}
div.receipt-wrapper .receipt-item-price-breakdown {
	width: 15em;
	text-align: left;
}
div.receipt-wrapper .receipt-item-price-breakdown table {
	margin: 0 0 1rem;
	font-size: 1.4rem;
	border-left: none;
}
div.receipt-wrapper .receipt-item-price-breakdown table caption {
	margin: 0;
	color: #000;
	font-size: 1.4rem;
}
div.receipt-wrapper .receipt-item-price-breakdown table th,div.receipt-wrapper .receipt-item-price-breakdown table td {
	padding: 5px 15px;
	border-right: none;
}
div.receipt-wrapper .receipt-item-price-breakdown table th {
	background: none;
}
div.receipt-wrapper .receipt-publisher {
	flex: 1;
	margin-left: 5%;
	font-size: 1.4rem;
	text-align: right;
	line-height: 1.4;
}

@media all and (max-width:480px) {
div.receipt-wrapper .receipt-top {
	display: block;
}
div.receipt-wrapper .receipt-name {
	width: 100%;
	margin: 0 0 1em;
}
div.receipt-wrapper .receipt-data {
	width: 100%;
}
div.receipt-wrapper .receipt-item-bottom {
	display: block;
}
div.receipt-wrapper .receipt-item-price-breakdown {
	width: 100%;
}
}

/*--------------------------------------
	# 求人一覧
--------------------------------------*/
#main div.search-block {
	margin: 0 0 40px;
	padding: 0 20px 20px;
	background: #FFF;
	border: 1px solid rgba(0,0,0,0.1);
	border-top: 3px solid #000;
}
#main div.search-block h3.search-block-title {
	margin: 0 -20px;
	padding: 20px;
	border-bottom: none;
}
#main div.search-block .search-block-inner {
	border-top: 1px dotted #c8c8c8;
}
#main div.search-block .search-block-inner dl.form-block:first-child {
	margin-top: 0;
	border-top: none;
}
#main div.search-block label {
	display: inline-block;
	margin-right: 2rem;
}
#main div.search-block div.search-detail-block {
	position: relative;
	padding: 0 0 60px;
}
#main div.search-block .search-detail-block-btn {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 10px;
	color: #000;
	font-size: 1.4rem;
	font-weight: 500;
	text-align: center;
	letter-spacing: 2px;
	cursor: pointer;
}
#main div.search-block .search-detail-block-btn:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background: #000;
	opacity: 0.15;
}
#main div.search-block .search-detail-block-btn:after {
	content: '';
	position: absolute;
	top: 42%;
	right: 20px;
	display: block;
	width: 10px;
	height: 10px;
	border-bottom: 1px solid #000;
	border-right: 1px solid #000;
	transform: rotate(45deg) translate(0, -50%);
	transition: 0.1s;
}
#main div.search-block .search-detail-block-btn.open:after {
	transform: rotate(225deg);
}
#main div.search-block .search-detail-body {
	height: 0;
	overflow: hidden;
  transition: 0.4s;
}
#main div.search-block .search-detail-body.open {
	height: auto;
}
#main .recruit-list-title {
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}
#main .recruit-list-title h3 {
	flex: 1;
	margin: 0;
	border-bottom: none;
}
#main .recruit-list-title .order {
	margin: 0 0 0 1em;
	font-size: 1.4rem;
}
#main .recruit-list-title .order select {
	width: auto;
	margin: 0;
	font-size: 1.4rem;
}
#main .recruit-list {
	border-bottom: 1px solid #c8c8c8; 
}
#main .recruit-list:first-child {
	border-top: 1px solid #c8c8c8; 
}
#main .recruit-list .recruit-list-img {
	position: relative;
	height: 0;
	overflow: hidden;
}
#main .recruit-list .recruit-list-img a {
	display: block;
}
#main .recruit-list .recruit-list-img img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	transform: translate(-50%, -50%);
	transition: 0.2s;
}
#main .recruit-list .recruit-list-text {
	font-size: 1.4rem;
	line-height: 1.6;
}
#main .recruit-list .recruit-list-text dl.area {
	margin: 0 0 10px;
	color: #666;
	font-size: 1.2rem;
}
#main .recruit-list .recruit-list-text dl.area dt {
	display: inline-block;
	padding: 0 5px;
	background: #999;
	color: #FFF;
	font-weight: 500;
	border-radius: 3px;
}
#main .recruit-list .recruit-list-text dl.area dt:before {
	content: '\f3c5';
	display: inline-block;
	margin: 0 5px 1px 0;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
}
#main .recruit-list .recruit-list-text dl.area dd {
	margin-left: 1em;
}
#main .recruit-list .recruit-list-text .name {
	margin: 0;
	color: #666;
	text-align: right;
}
#main .recruit-list .recruit-list-btn {
	display: flex;
}
#main .recruit-list .recruit-list-btn a {
	display: block;
	padding: 12px 5px 10px;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info li {
	margin-right: 1rem !important;
}
#main #memberpages #memberinfo .recruit-list .recruit-list-text ul.recruit-list-info li {
	color: #666;
	font-size: 1.2rem;
	line-height: 1.8;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info li.status {
	padding: 2px 8px !important;
	background: #c8c8c8;
	color: #FFF !important;
	line-height: 1.2;
	border-radius: 3px;
	opacity: 0.7;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info li.status.open {
	background: #8ed1fc;
	opacity: 1;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info li:not(.status):before {
	content: '';
	display: inline-block;
	width: 1em;
	margin: 0 5px 1px 0;
	color: #999;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	text-align: center;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info li.name:before {
	content: '\f1ad';
}
#main .recruit-list .recruit-list-text ul.recruit-list-info li.data:before {
	content: '\f304';
}

/* ページャー */
#main nav.page-nav {
	padding: 20px 0 0;
}
#main nav.page-nav ul {
	display: flex;
	justify-content: center;
}
#main nav.page-nav li a,#main nav.page-nav li span {
	display: block;
	width: 40px;
	height: 40px;
	background: #f3f7f8;
	color: #666;
	background: #FFF;
	border: 1px solid #c8c8c8;
	border-left: none;
	font-size: 1.4rem;
	text-align: center;
	line-height: 40px;
	text-decoration: none;
	transition: 0.2s;
}
#main nav.page-nav li:first-child a,#main nav.page-nav li:first-child span {
	border-left: 1px solid #c8c8c8;
}
body.dv #main nav.page-nav li a:hover,#main nav.page-nav li .current {
	color: #FFF;
	background: #323232;
}

@media all and (max-width:949px) {
#main .recruit-list {
	padding: 15px 0 10px;
}
#main .recruit-list .recruit-list-img {
	float: right;
	clear: right;
	width: 40%;
	padding-top: 30%;
	margin: 0 0 1.5rem 1.5rem;
}
#main .recruit-list .recruit-list-text dl.area dt {
	margin: 0 0 5px;
	padding: 1px 5px 0;
}
#main .recruit-list .recruit-list-text .name {
	margin: 0 0 1rem;
}
#main .recruit-list .recruit-list-text ul.recruit-list-info {
	margin: 1em 0 !important;
}
#main .recruit-list .recruit-list-btn {
	clear: both;
	justify-content: center;
}
#main .recruit-list .recruit-list-btn a {
	flex: 1;
	margin: 5px;
}
}
@media all and (min-width:950px) {
#main div.search-block .search-block-inner,#main div.search-block .search-detail-body {
	display: flex;
	flex-wrap: wrap;
}
#main div.search-block .search-block-inner dl.form-block {
	width: 50%;
}
#main div.search-block .search-block-inner dl.form-block.full {
	flex: none;
	width: 100%;
}
#main div.search-block .search-block-inner dl.form-block {
	align-items: center;
}
#main div.search-block .search-block-inner dl.form-block dt {
	font-size: 1.4rem;
}
#main div.search-block .search-block-inner select {
	width: 98%;
}
#main div.search-block.omit {
	display: flex;
	align-items: center;
	padding: 0 20px;
}
#main div.search-block.omit .search-block-title {
	margin: 0;
	padding: 20px 40px 20px 20px;
	white-space: nowrap;
}
#main div.search-block.omit > form {
	flex: 1;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0;
}
#main div.search-block.omit .search-block-inner {
	margin-right: 20px;
	border-top: none;
	border-left: 1px dotted #c8c8c8;
}
#main div.search-block.omit .search-block-inner dl.form-block {
	border-bottom: none;
}
#main div.search-block.omit .search-block-inner dl.form-block dt {
	width: auto;
}
#main .recruit-list .recruit-list-img a:hover img {
	opacity: 0.8;
}
#main .recruit-list {
	display: flex;
	padding: 20px 5px;
}
#main .recruit-list .recruit-list-img {
	width: 200px;
	padding-top: 140px;
}
#main .recruit-list .recruit-list-text {
	flex: 1;
	padding: 0 20px;
}
#main .recruit-list .recruit-list-text dl.area {
	display: flex;
	align-items: flex-start;
}
#main .recruit-list .recruit-list-text dl.area dd {
	flex: 1;
}
#main .recruit-list .recruit-list-btn {
	flex-direction: column;
	justify-content: center;
	width: 140px;
	padding-left: 20px;
	border-left: 1px dotted #c8c8c8;
}
#main .recruit-list .recruit-list-btn a {
	width: 100%;
	margin: 5px 0;
	font-size: 1.4rem;
}
}

/*--------------------------------------
	# 求人詳細
--------------------------------------*/
#main .detail-info {
	position: relative;
	margin: 0 0 30px;
}
#main .detail-info ul {
	display: flex;
	flex-wrap: wrap;
	color: #666;
	font-size: 1.3rem;
}
#main .detail-info li {
	margin-right: 2rem;
}
#main .detail-info li.name {
	font-size: 1.4rem;
	font-weight: 700;
}
#main .detail-info li.name {
	font-size: 1.5rem;
	font-weight: 700;
}
#main .detail-info li.name,#main .detail-info li.add,#main .detail-info li.obsession {
	flex: none;
	width: 100%;
}
#main .detail-info li:before {
	display: inline-block;
	margin: 0 5px 1px 0;
	color: #999;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
}
#main .detail-info li.name:before {
	content: '\f1ad';
}
#main .detail-info li.add:before {
	content: '\f3c5';
}
#main .detail-info li.mng:before {
	content: '\f007';
}
#main .detail-info li.tel:before {
	content: '\f095';
}
#main .detail-info li.mail:before {
	content: '\f0e0';
}
#main .detail-info li.url:before {
	content: '\f0ac';
}
#main .detail-info li.instagram:before {
	content: '\f16d';
	color: #666;
	font-family: "Font Awesome 6 Brands";
	font-weight: 400;
}
#main .detail-info li.obsession li {
	margin: 10px 10px 0 0;
	padding: 3px 8px;
	background: #FFF;
	font-size: 1.2rem;
	line-height: 1.2;
	border: 1px solid #c8c8c8;
	border-radius: 3px;
}
#main .detail-info .favorite-btn {
	position: relative;
	text-align: center;
	background: #FFF;
	border: 1px solid #c8c8c8;
	border-bottom: 3px solid #c8c8c8;
	border-radius: 3px;
	transition: 0.2s;
	overflow: hidden;
}
#main .detail-info .favorite-btn:before {
	content: '\f004';
	font-family: "Font Awesome 6 Free";
	font-size: 2.0rem;
	font-weight: 900;
}
#main .detail-info .favorite-btn.add:before {
	color: #999;
}
#main .detail-info .favorite-btn.lift:before {
	color: #df5656;
}
#main .detail-info .favorite-btn input {
	position: relative;
	padding: 10px;
	background: none;
	color: #666;
	font-size: 1.1rem;
	cursor: pointer;
	transition: 0.2s;
}
#main .detail-wrapper ul.detail-pdf {
	display: flex;
  justify-content: space-between;
	margin: 10px 0;
}
#main .detail-wrapper ul.detail-pdf li {
	flex: 1;
	margin: 0 5px;
}
#main .detail-wrapper ul.detail-pdf li a {
	display: block;
	margin: 0;
	padding: 10px 5px 8px;
}
#main .detail-wrapper ul.detail-pdf li a:before {
	content: '\f1c1';
	display: inline-block;
	margin: 0 5px 0 0;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
}
#main table.detail-table th {
	background: #FFF;
	color: #00a669;
}
@media all and (max-width:949px) {
#main .detail-info ul {
	margin-bottom: 10px;
	line-height: 1.6;
}
#main .detail-info li.obsession li {
	margin: 5px 5px 0 0;
}
#main .detail-info .favorite-btn:before {
	display: inline-block;
	font-size: 1.8rem;
	vertical-align: middle;
}
#main .detail-info .favorite-btn input {
	font-size: 1.4rem;
}
#main .detail-wrapper .detail-img {
	margin: 0 0 20px;
}
#main .detail-wrapper .detail-img img {
	display: block;
	width: 80%;
	margin: 0 auto;
}
#main table.detail-table th {
	padding-top: 10px;
	padding-bottom: 0;
	border-bottom: none;
}
}
@media all and (min-width:950px) {
#main .detail-info {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#main .detail-info ul {
	flex: 1;
}
#main .detail-info .favorite-btn {
	width: 130px;
}
#main .detail-info .favorite-btn:before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	text-align: center;
}
#main .detail-info .favorite-btn input {
	display: block;
	width: 100%;
	padding: 35px 10px 5px;
}
#main .detail-info .favorite-btn:hover {
	border-bottom: 1px solid #c8c8c8;
	transform: translateY(2px);
}
#main .detail-info .favorite-btn.add:hover:before {
	color: #df5656;
}
#main .detail-info .favorite-btn.lift:hover:before {
	color: #999;
}
#main .detail-wrapper {
	display: flex;
	justify-content: space-between;
}
#main .detail-wrapper .detail-img {
	width: 33%;
}
#main .detail-wrapper .detail-text {
	width: 65%;
}
#main table.detail-table th {
	padding-right: 0;
	width: 20%;
	border-right: none;
}
}

/*--------------------------------------
	# ACF
--------------------------------------*/
.acf-fields > .acf-field {
	clear: both;
	border-top: none;
	border-bottom: 1px dotted #c8c8c8;
	overflow: hidden;
}
.acf-fields > .acf-field:first-child {
	margin-top: 1rem;
	border-top: 1px dotted #c8c8c8;
}
.acf-field .acf-label {
	position: relative;
	font-weight: 500;
	line-height: 1.4;
}
.acf-field .acf-label label {
	margin: 0;
	font-weight: 500;
}
.acf-field p.description {
	margin: 5px 0 0;
	color: #666;
	font-size: 1.4rem;
	font-weight: 400;
}
.acf-field .acf-input {
	margin: 0 0 0 5px;
}
.acf-field .acf-input p {
	margin: 0;
}
.acf-form-submit {
	clear: both;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 30px 0 0;
	padding: 0;
	border: none;
}
.select2-container.-acf .select2-selection {
	border-color: #CCC;
}
ul.acf-radio-list li, ul.acf-checkbox-list li {
	margin: 0 20px 5px 0;
	font-size: 1.6rem;
	line-height: 1.8;
}
.acf-input-prepend, .acf-input-append {
	min-height: 38px;
	padding: 6px 8px;
	color: #666;
	border-color: #CCC;
}
.acf-fields.-border {
	display: flex;
  justify-content: space-between;
	border: none;
	background: none;
}
.acf-fields.-border > .acf-field {
	display: block;
	margin: 0;
	padding: 0;
	border-bottom: none;
}
.acf-field[data-width] + .acf-field[data-width] {
	border-left: none;
}
.acf-field input[type=text], .acf-field input[type=password], .acf-field input[type=date], .acf-field input[type=datetime], .acf-field input[type=datetime-local], .acf-field input[type=email], .acf-field input[type=month], .acf-field input[type=number], .acf-field input[type=search], .acf-field input[type=tel], .acf-field input[type=time], .acf-field input[type=url], .acf-field input[type=week], .acf-field textarea, .acf-field select {
	font-size: 16px;
}
.acf-field textarea {
	min-width: 100%;
	max-width: 100%;
}
.acf-file-uploader .file-info a {
	color: blue;
	text-decoration: underline;
}
@media all and (max-width:949px) {
.acf-fields > .acf-field {
	padding: 15px 0;
}
}
@media all and (min-width:950px) {
.acf-fields > .acf-field {
	display: flex;
}
.acf-field .acf-label {
	width: 12em;
	margin: 0;
	padding: 5px 0;
}
.acf-field .acf-input {
	flex: 1;
	margin-left: 2em;
}
.acf-fields.-border .acf-label {
	width: auto;
}
.acf-fields.-border .acf-input {
	margin-left: 0;
}
.acf-file-uploader .file-info a:hover {
	text-decoration: none;
}
}

/*--------------------------------------
	# Form
--------------------------------------*/
div#main dl.form-block {
	clear: both;
	padding: 15px 0;
	border-bottom: 1px dotted #c8c8c8;
	overflow: hidden;
}
div#main dl.form-block:first-child {
	margin-top: 1rem;
	border-top: 1px dotted #c8c8c8;
}
div#main dl.form-block dt {
	position: relative;
	padding: 0 0 10px;
	color: #2b2f39;
	font-weight: 500;
	line-height: 1.4;
}
div#main dl.form-block dt span.required {
	position: absolute;
	top: 0;
	right: 0;
	padding: 0 8px 2px;
	color: #FFF;
	font-size: 1.1rem;
	background: #000;
	border-radius: 2px;
	line-height: 18px;
}
div#main dl.form-block dd {
	margin: 0 0 0 5px;
}
div#main dl.form-block dd p {
	margin: 0;
}
div#main .form-btn,div#main .send,.send.settlement_form_send,.send.agree_form_send {
	clear: both;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 30px 0 0;
	padding: 0;
	border: none;
}
.send.agree_form_send input[type="button"] {
	display: inline-block;
	margin: 0 1% 1%;
	padding: 8px 20px;
	background: #333;
	color: #FFF;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1.5rem;
	font-weight: 500;
	border-bottom: 3px solid rgba(0, 0, 0, 0.2);
	border-radius: 3px;
	vertical-align: top;
	cursor: pointer;
	transition: 0.2s;
}
body.dv .send.agree_form_send input[type="button"]:hover {
	border-bottom: 3px solid rgba(0,0,0,0);
	transform: translateY(2px);
	opacity: 0.8;
}
/*div#main div.form_in {
	clear: both;
	overflow: hidden;
}
div#main div.form_in p.error {
	color: #F00;
	font-size: 1.4rem;
}
div#main div.form-block {
	margin-bottom: 40px;
}
div#main div.form-block > dl {
	clear: both;
	padding: 15px 0;
	border-bottom: 1px solid #d8e2e5;
	overflow: hidden;
}
div#main div.form-block > dl:first-child {
	border-top: 1px solid #d8e2e5;
}
div#main div.form-block > dl > dt {
	position: relative;
	padding: 0 0 10px;
	color: #2b2f39;
	font-weight: 500;
	line-height: 1.4;
}
div#main div.form-block > dl > dt span.required {
	position: absolute;
	top: 0;
	right: 0;
	padding: 0 8px 2px;
	color: #FFF;
	font-size: 1.1rem;
	background: #00afcc;
	border-radius: 2px;
	line-height: 18px;
}
div#main div.form-block > dl > dd {
	margin: 0 0 0 5px;
}
div#main div.form-block dl dd p {
	margin: 0;
}
div#main div.form-block > dl > dd dl {
	padding: 5px 0;
}
div#main div.form-block > dl > dd dl:first-child {
	padding: 0 0 5px;
}
div#main div.form-block > dl > dd dl dt {
	color: #2b2f39;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.4;
}
div#main div.form_in input[type="text"],div#main div.form_in input[type="email"],div#main div.form_in input[type="tel"],div#main div.form_in select,div#main div.form_in textarea,div#main input[type="password"] {
	display: inline-block;
	width: 98%;
	min-height: 38px;
	margin: 1%;
	padding: 5px 10px;
	background: #FFF;
	font-size: 16px;
	font-family: 'Noto Sans JP', sans-serif;
	border: 1px solid #CCC;
	border-radius: 3px;
	outline: none;
	vertical-align: middle;
}
div#main div.form_in select.short {
	width: 25%;
}
div#main div.form_in input.short {
	width: 30%;
}
div#main div.form_in input.medium {
	width: 50%;
}
div#main div.form_in label {
	display: inline-block;
	min-height: 38px;
	margin-right: 20px;
	padding: 6px 0 0 20px;
	text-indent: -20px;
	vertical-align: top;
}
div#main div.form_in textarea {
	min-width: 98%;
	padding: 10px;
	font-size: 16px;
	font-family: 'Noto Sans JP', sans-serif;
}
div#main div.form_in .button-block {
	padding: 30px 0 0;
}
div#main .form-btn {
	clear: both;
	margin: 40px 0 0;
	text-align: center;
	letter-spacing: -.40em;
}
div#main .form-btn input[type="submit"] {
	position: relative;
	display: inline-block;
	width: 43%;
	height: auto;
	margin: 0 10px;
	padding: 8px 10px;
	background: #00afcc;
	color: #FFF;
	vertical-align: top;
	letter-spacing: 2px;
	border: 1px solid #00afcc;
	border-radius: 0;
	cursor: pointer;
	transition: 0.2s;
}*/

@media all and (min-width:950px) {
div#main dl.form-block {
	display: flex;
	padding: 10px 20px;
}
div#main dl.form-block dt {
	width: 10em;
	padding: 5px 0;
}
div#main dl.form-block dt span.required {
	top: 5px;
}
div#main dl.form-block dd {
	flex: 1;
	margin-left: 2em;
}
/*div#main div.form_in {
	max-width: 900px;
	margin: 0 auto 60px;
}
div#main div.form-block {
	margin-bottom: 40px;
}
div#main div.form-block > dl {
	display: flex;
	padding: 20px;
}
div#main div.form-block > dl > dt {
	width: 10em;
	padding: 5px 0;
}
div#main div.form-block > dl > dt span.required {
	top: 5px;
}
div#main div.form-block > dl > dd {
	flex: 1;
	margin-left: 2em;
}
div#main div.form-block > dl > dd dl {
	display: flex;
	align-items: center;
}
div#main div.form-block > dl > dd dl dt {
	width: 8em;
	white-space: nowrap;
}
div#main div.form-block > dl > dd dl dd {
	flex: 1;
}
div#main div.form-block > dl > dd dl.flex-start {
  align-items: flex-start;
}
div#main div.form-block > dl > dd dl.flex-start dt {
	padding-top: 12px;
}
div#main div.form_in input[type="text"],div#main div.form_in input[type="email"],div#main div.form_in input[type="tel"],div#main div.form_in select,div#main div.form_in textarea,div#main input[type="password"] {
	font-size: 1.6rem;
}
div#main div.form_in input.short {
	width: 20%;
}
div#main div.form_in input.middle {
	width: 60%;
}
div#main div.form_in select.short {
	width: 20%;
}
div#main div.form_in textarea {
	font-size: 1.6rem;
}
div#main .form-btn input[type="submit"] {
	width: 20%;
	font-size: 1.8rem;
}
div#main .form-btn input[type="submit"]:hover {
	background: #FFF;
	color: #00afcc;
}*/
}

/*--------------------------------------
	# Footer
--------------------------------------*/

@media print, screen and (min-width:950px) {
footer#footer {
	position: relative;
	clear: both;
	border-top: 3px solid rgba(0,0,0,0.05);
}
footer#footer .footer-wrapper {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding: 30px 60px;
}
footer#footer nav#sitemap-nav ul {
	display: flex;
}
footer#footer nav#sitemap-nav ul li {
	padding: 0 15px;
	border-right: 1px solid rgba(0,0,0,0.2);
}
footer#footer nav#sitemap-nav ul li:first-child {
	border-left: 1px solid rgba(0,0,0,0.2);
}
footer#footer nav#sitemap-nav ul li a {
	display: block;
	color: #666;
	font-size: 1.3rem;
	text-decoration: none;
}
footer#footer nav#sitemap-nav ul li a:hover {
	text-decoration: underline;
}
footer#footer p.copyright {
	margin: 0 0 0 30px;
	color: rgba(0,0,0,0.6);
	font-size: 1.2rem;
	text-align: center;
	letter-spacing: 1px;
}
div#pagetop {
	position: fixed;
	right: 0;
	bottom: 105px;
	z-index: 10;
	opacity: 0;
	transition: 0.3s;
}
div#pagetop.show {
	opacity: 1;
}
div#pagetop a {
	display: block;
	width:50px;
	height: 0;
	padding-top: 60px;
	background: #1c1e23;
	overflow: hidden;
}
div#pagetop a:before {
	content: '';
	position: fixed;
	right: 19px;
	bottom: 125px;
	display: block;
	width: 10px;
	height: 10px;
	border-top: 1px solid #FFF;
	border-left: 1px solid #FFF;
	transform: rotate(45deg);
	transition: 0.1s;
}
body.dv div#pagetop a:hover,
body.dv div#pagetop a:hover:before {
	opacity: 0.8;
}
}
@media all and (max-width:949px) {
footer#footer {
	position: relative;
	clear: both;
}
footer#footer #footer-wrapper {
	padding: 30px 20px 0;
	overflow: hidden;
}
footer#footer nav#sitemap-nav {
	display: none;
}
footer#footer p.copyright {
	margin: 0;
	padding: 10px 0;
	color: rgba(0,0,0,0.6);
	font-size: 1.1rem;
	text-align: center;
	line-height: 1.2;
	letter-spacing: 1px;
}
div#pagetop {
	position: fixed;
	right: 0;
	bottom: 70px;
	opacity: 0;
	transition: 0.3s;
	z-index: 998;
}
div#pagetop.show {
	opacity: 1;
}
div#pagetop a {
	display: block;
	width: 40px;
	height: 0;
	padding-top: 50px;
	background: #1c1e23;
	overflow: hidden;
	transition: 0.1s;
}
div#pagetop a:before {
	content: '';
	position: fixed;
	right: 12px;
	bottom: 85px;
	display: block;
	width: 10px;
	height: 10px;
	border-top: 2px solid #FFF;
	border-left: 2px solid #FFF;
	transform: rotate(45deg);
	transition: 0.1s;
}
}

/*--------------------------------------
  # SiteColor
--------------------------------------*/

/* 企業用 */
#enterprise header#header div.header-wrapper,#enterprise header#header div#global-nav-icon div.nav-icon,#enterprise #header #global-nav {
	background: #2b2b2b;
}
#enterprise a:not(.call-link),body#enterprise.m .call-link {
  color: #444;
}
#enterprise form input[type="radio"]:checked:after,#enterprise form input[type="submit"],#enterprise form input[type="button"],.send.settlement_form_send input[type="button"],#enterprise div#container a.detail-link,#enterprise a.back_to_top_button,#enterprise div#main dl.form-block dt span.required {
  background: #444;
}
#enterprise form input[type="checkbox"]:checked:after{
	border-color: #444;
}
#enterprise div#container a.link-icon:before {
	border-left-color: #444;
}

/* 学生用 */
#student header#header div.header-wrapper,#student header#header div#global-nav-icon div.nav-icon,#student #header #global-nav,#student #main div.search-block .search-detail-block-btn:before {
	background: #00a669;
}
#student a:not(.call-link),body#student.m .call-link,#student #main div.search-block h3.search-block-title,#student #main div.search-block .search-detail-block-btn {
  color: #00a669;
}
#student form input[type="radio"]:checked:after,#student form input[type="submit"],#student form input[type="button"],#student div#container a.detail-link,#student a.back_to_top_button,#student div#main dl.form-block dt span.required {
  background: #00a669;
}
#student form input[type="checkbox"]:checked:after,#student #main div.search-block .search-detail-block-btn:after {
	border-color: #00a669;
}
#student #main div.search-block {
	border-top-color: #00a669;
}
#student div#container a.link-icon:before {
	border-left-color: #00a669;
}