@charset "utf-8";

/*
GLOBAL
***************************************************************************/
html {
	font-size: 62.5%;
	overflow-y: scroll;
	overflow-x: hidden;
}

body {
	width: 100%;
	min-width: 1200px;
	height: auto;
	text-align: left;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.4rem;
	font-weight: 500;
	color: #404040;
	line-height: 2;
}

@media screen and (max-width: 1200px){
	body {
		overflow-y: scroll;
		overflow-x: hidden;
	}
}

.base_box {
	position: relative;
	width: 1200px;
	margin: 0 auto;
	z-index: 1;
}

@media screen and (max-width: 1400px){

	.base_box { 
		width:auto;
		margin:0 calc((80 / 1800) * 100vw); 
	}

}

/*
DEFAULT
***************************************************************************/
body,
h1,h2,h3,h4,h5,h6,p,div,
ul,ol,li,dl,dt,dd,
form,fieldset,legend,pre,blockquote,main,
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
	display:block;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
	word-wrap: break-word;
	letter-spacing: 0.1rem;
	font-feature-settings: "pkna";
}

h1,h2,h3,h4,h5,h6 {
	font-weight: 700;
	color: #000;
	line-height: 1.5;
}

.clearfix:after {
	display: block;
	clear: both;
	content: "";
	overflow: hidden;
}

iframe { border:none; }

li {
	list-style-type: none;
}

table {
	width: 100%;
	text-align: left;
	border-collapse: collapse;
}

th {
	text-align: left;
	font-weight: normal;
}

/* ▼LINK▼ */
a {
	color: #00babd;
	text-decoration: none;
	outline: none;
	transition: .5s;
	backface-visibility: hidden;
}

a:before, a:after {
	content: '';
	position: absolute;
	transition: .5s;
	backface-visibility: hidden;
}

a:hover {
	opacity: 0.7;
}

.no_filter a:hover, a.no_filter:hover, .modal_switch.no_filter:hover {
	opacity: 1;
	text-decoration: none;
}

/* ▼IMG▼ */
img, input[type="image"] {
	border: 0;
	font-size: 0;
	line-height: 0;
	vertical-align: middle;
}

button, input[type="submit"] {
	padding: 0;
	border: 0;
	vertical-align: middle;
	font-family: "Noto Sans JP", sans-serif;
	cursor: pointer;
	outline: none;
	transition: .5s;
	backface-visibility: hidden;
}

button:hover, input[type="submit"]:hover { opacity:1; }

.img_frame {
	position: relative;
	overflow: hidden;
}

.img_frame img {
	position: absolute;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.jobs_recommend .box .img {
	width: 100%;
	height: 240px;
}

.hover_img:hover { opacity:0; }

/*
HEADER
***************************************************************************/
header {
	position: fixed;
	top: 0;
	left: 50%;
	width: 100%;
	z-index: 100;
  transform: translateX(-50%);
	background-color: #fff;
	box-shadow: 0px 0px 2px 0 rgb(0 0 0 / 30%);
}

header .logo {
	float: left;
	padding: 31px 0 28px 0;
	margin: 0 35px 0 0;
}

.header_box {
	float: right;
}

.header_inner {
	position: relative;
	width: 1200px;
	top: 0;
	left: 50%;
  transform: translateX(-50%);
}

.hnavi_list {
	display: inline-block;
	padding: 26px 0;
}

.hnavi_list li {
	position: relative;
	display: inline-block;
	padding-right: 34px;
	padding-left: 68px;
	line-height: 60px;
	font-size: 1.5rem;
}

.hnavi_list li + li {
	border-left: 1px solid #dcdcdc;
}

.hnavi_list li a {
	display: block;
	position: relative;
	color: #000000;
	transform: color 0.7s ease;
}

.hnavi_list li a:hover {
	color: #32cdcf;
}

.hnavi_list li a::before {
	content: '';
	display: block;
	position: absolute;
	left: -35px;
	top: 50%;
	transform: translateY(-50%);
	background-size: cover;
}

.hnavi_list li:nth-of-type(1) a::before {
	background-image: url(../images_bf/icon_job.png);
	width: 23px;
	height: 33px;
}

.hnavi_list li:nth-of-type(2) a::before {
	background-image: url(../images_bf/icon_company.png);
	width: 25px;
	height: 32px;
}

.hlink_list {
	position: relative;
	/* width: 310px; */
	float: right;
}

.hlink_list li {
	position: relative;
	display: block;
}

.hlink_list li:nth-of-type(1) {
	color: #fff;
	background: linear-gradient(to top, #00babd 20%, #66e1e3 100%);	
  border: 1px solid #00babd;
	padding: 16px 20px 16px 102px;
	height: 68px;
}
.hlink_list li:nth-of-type(1)::before {
	content: '';
	display: block;
	background-image: url(../images_bf/icon_company_white.png);
	background-size: cover;
	width: 15px;
	height: 20px;
	position: absolute;
	left: 60px;
	top: 50%;
	transform: translateY(-50%);
}

.hlink_list li:nth-of-type(1) p {
	font-size: 1.2rem;
	line-height: 1.2;
}

.hlink_list li:nth-of-type(1) p span {
	position: relative;
	font-size: 1.8rem;
	padding-left: 25px;
}
.hlink_list li:nth-of-type(1) p span::before {
	content: '';
	display: block;
	background-image: url(../images_bf/icon_freedial_white.png);
	background-size: cover;
	width: 20px;
	height: 13px;
	position: absolute;
	left: 1px;
	top: 52%;
	transform: translateY(-50%);
}

.hlink_list li:nth-of-type(2) {
	font-size: 1.4rem;
	background: linear-gradient(180deg, rgba(224,227,0,1) 0%, rgba(241,187,0,1) 90%, rgba(241,187,0,20) 100%);
	padding: 8px 10px 8px 45px;
	white-space: nowrap;
	z-index: 0;
}

.hlink_list li:nth-of-type(2):hover {
	opacity: 1;	
}

.hlink_list li:nth-of-type(2)::before,
.hlink_list li:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	transition: .6s;
	backface-visibility: hidden;
	opacity: 1;
}

.hlink_list li:nth-of-type(2):hover:before {
	opacity: 0; 
}

.hlink_list li:nth-of-type(2)::before {
	background: linear-gradient(to bottom, rgba(224,227,0,1) 0%, rgba(236,198,0,1) 40%, rgba(236,198,0,1) 60%, rgba(224,227,0,1) 100%); 
	z-index:-1; 
}

.hlink_list li:nth-of-type(2)::after {
	background: linear-gradient(to bottom, rgba(252,255,57,1) 0%, rgba(249,220,36,1) 40%, rgba(249,220,36,1) 60%, rgba(252,255,57,1) 100%);
	z-index:-2;
}

.hlink_list li:nth-of-type(2) a {
	position: relative;
	color: #000;
}

.hlink_list li:nth-of-type(2) a::before {
	content: '';
	display: block;
	background-image: url(../images_bf/icon_job_black.png);
	background-size: cover;
	width: 14px;
	height: 20px;
	position: absolute;
	left: -20px;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 1400px){

	header {
		left: 0;
    transform: translateX(0);
		padding: 0 0 0 20px;
	}

	header .logo {
		margin: 0 0 0 10px;
	}

	.header_inner {
		position: relative;
		width: 1200px;
		top: 0;
		left: 0;
		transform: translateX(0);
	}

	.hnavi_list li {
		margin-right: 14px;
		font-size: 1.2rem;
	}
	.hlink_list li:nth-of-type(2) {
		font-size: 1.2rem;
		padding: 10px 10px 10px 45px;
	}

}
@media screen and (max-width: 1200px){
	.hlink_list li:nth-of-type(2) {
		font-size: 1.0rem;
		padding: 12px 10px 12px 45px;
	}
}

/*
NAVI
***************************************************************************/
#gnavi {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	padding: 170px 50px 100px;
	background: rgba(255,255,255,0.95);
	z-index: 1001;
}

.close_gnavi {
	position: fixed;
	top: 20px;
	right: 30px;
	z-index: 1002;
	cursor: pointer;
}

#gnavi .scroll_box {
	height: calc(100vh - 270px);
	overflow-y: auto;
}

#gnavi .sec_inner {
	width: 1200px;
	margin: 0 auto;
}

#gnavi .btn_list {
	position: relative;
	float: left;
	width: 50%;
	padding: 20px 70px 40px 0;
	border-right: solid 1px #eaeaea;
}

#gnavi .btn_list .title {
	margin-bottom: 60px;
	font-size: 7.5rem;
	font-weight: 400;
	line-height: 1.3;
}

#gnavi .btn_list .title span {
	display: block;
	font-size: 2rem;
	font-weight: 700;
	color: #404040;
	letter-spacing: 0.15rem;
}

#gnavi .btn_list .icon {
	position: absolute;
	top: 50px;
	right: 85px;
}

#gnavi .btn_list .icon li {
	float: left;
}

#gnavi .btn_list .btn li {
	float: left;
	width: 250px;
	margin-bottom: 20px;
}

#gnavi .btn_list .btn li:nth-child(2n) { float:right; }

#gnavi .btn_list .btn li a { font-size:1.8rem; }

#gnavi .btn_list .btn li a .arrow {
	right: 20px;
	width: 8px;
	height: calc(18px * 0.8);
	margin-top: calc((-18px * 0.8) / 2);
	background-size: 8px;
}

#gnavi .btn_list .btn li.ex {
	float: none;
	width: 100%;
	margin-bottom: 0;
}

#gnavi .btn_list .btn li.ex a { font-size:1.5rem; }

#gnavi .gnavi_list {
	float: right;
	width: 50%;
	padding: 0 0 20px 70px;
}

#gnavi .gnavi_list li {
	float: left;
	width: 200px;
	margin: 0 75px 45px 0;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.6;
}

#gnavi .gnavi_list li:nth-child(2n) { margin-right:0; }

#gnavi .gnavi_list li:last-child { margin-bottom:0; }

#gnavi .gnavi_list li a {
	color: #8fd127;
}

#gnavi .gnavi_list li img {
	display: block;
	transition: .5s;
	backface-visibility: hidden;
}

#gnavi .gnavi_list li a:hover img { opacity:0.7; }

#gnavi .info {
	margin: 45px 0 55px;
	padding: 60px 0;
	border-top: solid 1px #eaeaea;
	border-bottom: solid 1px #eaeaea;
}

#gnavi .info .txt {
	float: left;
	width: 650px;
	margin: -10px 0 0 45px;
	font-size: 1.3rem;
}

#gnavi .info .txt span {
	display: block;
	margin-top: 5px;
	font-size: 1.5rem;
	font-weight: 700;
}

#gnavi .sinfo .sns_list {
	float: left;
	width: 50%;
}

#gnavi .sinfo .sns_list li {
	display: inline-block;
	margin-right: 10px;
}

#gnavi .sinfo .copy {
	float: right;
	width: 50%;
	text-align: right;
	font-size: 1.1rem;
	font-weight: 300;
	color: #a8a8a8;
	line-height: 24px;
}

@media screen and (max-width: 1400px){

	#gnavi .sec_inner { width:auto; }
	#gnavi .info { margin:45px 60px 55px 0; }
	#gnavi .sinfo { margin-right:60px; }

}

/*
CONTENTS
***************************************************************************/
#contents {
	position: relative;
}

/* ▼PAGE TITLE▼ */
#page_title {
	position: relative;
	height: 562px;
	background-image: url(../common_img/ptitle_bg.jpg);
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	margin-top: 112px;
}

#page_title.jobs_bf { background-image:url(../jobs_bf/images/ptitle_bg.jpg); }
#page_title.forcompany_bf { background-image:url(../forcompany_bf/images/ptitle_bg.jpg); }
#page_title.foruser_bf { background-image:url(../foruser_bf/images/ptitle_bg.jpg); }
#page_title.application_bf { background-image:url(../application/images/ptitle_bg_bf.jpg); margin-top: 0;}

#page_title .sec_title {
	position: absolute;
	font-size: 4.8rem;
	color: #fff;
	width: 1200px;
	margin: 0 auto;
	left: 50%;
	bottom: 50%;
	transform: translate(-50%, 50%);
}
@media screen and (max-width: 1400px){
	#page_title .sec_title {
		left: 0;
		transform: translate(0, 50%);
    padding: 0 0 0 20px;
	}
}

#page_title .sec_title img {
	display: block;
}

#page_title .sec_title span {
	padding-bottom: 10px;
	border-bottom: solid 3px #8fd127;
}

/* ▼PAGE NAVI▼ */
.pnavi_list {
	padding: 20px 0;
	background: #fff;
}

.pnavi_list li {
	display: inline;
	margin-right: 8px;
	font-size: 1.1rem;
	font-weight: 300;
	color: #b5b5b5;
	line-height: 1.8;
}

.pnavi_list li a {
	margin-right: 12px;
	padding-bottom: 2px;
	color: #959595;
	border-bottom: solid 1px #959595;
}

/* ▼PAGINATION▼ */
.page_list {
	padding-top: 30px;
	text-align: center;
}

.page_list li {
	display: inline-block;
	line-height: 32px;
}

.page_list li a, .page_list li span {
	display: block;
	position: relative;
	width: 24px;
	height: 32px;
	margin: 0 12px;
	font-weight: 400;
	color: #404040;
}

.page_list li span {
	font-size: 1.5rem;
	font-weight: 700;
	color: #8fd127;
	border-bottom: solid 2px #8fd127;
}

.page_list li.prev, .page_list li.next { vertical-align:1px; }
.page_list li.prev a, .page_list li.next a { width:auto; }

/* ▼ANCHOR LIST▼ */
.anc_list {
	text-align: center;
	font-size: 1.5rem;
	box-shadow: 0px 0px 20px rgba(118,118,118,0.25);
}

.anc_list.fixed {
	position: absolute;
	top: -65px;
	right: 0;
	padding: 40px 60px 50px;
	background: #8fd127;
	border-radius: 20px 0 0 20px;
	z-index: 100;
}

.anc_list .title {
	padding: 25px 0 35px;
	background: #8fd127;
	cursor: pointer;
}

.anc_list .title span {
	padding-left: 30px;
	background: url(../common_img/icon_plus.png) left 5px no-repeat;
}

.anc_list .title.opened span {
	background: url(../common_img/icon_minus.png) left 5px no-repeat;
}

.anc_list .inner {
	display: none;
	padding: 70px 0 80px;
	background: #8fd127;
	border-top: solid 1px #acea4b;
}

.anc_list li {
	display: inline-block;
	margin: 0 20px;
	font-weight: 400;
}

.anc_list.fixed li { margin:0; }

.anc_list li a {
	display: block;
	position: relative;
	padding: 0 20px;
	color: #fff;
	line-height: 40px;
}

.anc_list li a:after {
	bottom: 0;
	left: 50%;
	width: 4px;
	height: 4px;
	margin-left: -2px;
	background: #fff;
}

/*
TOP
***************************************************************************/
/* ▼TOPIMG▼ */
#topimg {
	position: relative;
	height: calc(100vh - 112px);
	background: url(../images_bf/topimg_title_bf.jpg) -160px top no-repeat;
	background-size: cover;
	margin-top: 112px;
}

#topimg .sec_title {
	position: absolute;
	width: 1200px;
	margin: 0 auto;
	left: 50%;
	bottom: 50%;
	transform: translate(-50%, 50%);
}

#topimg .sec_title h1 {
	color: #fff;
	font-size: 48px;
	font-weight: bold;
	letter-spacing: 2px;
}

#topimg .sec_title h1 span {
	font-size: 24px;
}

#topimg .sec_title p {
	color: #fff;
	font-size: 15px;
	letter-spacing: 1.6px;
	padding-top: 30px;
}

#topimg .link_list {
	position: absolute;
	top: 50%;
	left: calc((100vw / 2) - 9px);
	width: 600px;
	transform: translateY(-50%);
}

#topimg .link_list .box {
	padding: 28px 50px 42px 50px;
	background: rgb(0 0 0 / 60%);
}

#topimg .link_list .box > p {
	font-size: 28px;
	color: #fff;
	padding-bottom: 32px;
}

#topimg .link_list .box > p span {
	font-size: 14px;
	font-weight: normal;
	padding-left: 10px;
}

#topimg .link_list .box form ul li + li {
	padding-top: 12px;
}

#topimg .link_list .box form ul li select {
	font-size: 1.6rem;
	line-height: 58px;
	background: #fff url(../images_bf/icon_arrow_select.png) right 12px center no-repeat;
	color: #b1b1b1;
}

#topimg .link_list .box form button {
	margin-top: 12px;
}

#topimg .link_list .box .btn01 { font-size:1.8rem; letter-spacing: 1.2px;     font-weight: 500;}

@media screen and (max-width: 1400px){
	#topimg .sec_title {
		left: 0;
		transform: translate(0, 50%);
    padding: 0 0 0 20px;
	}
	#topimg .link_list {
		left: auto;
    right: 20px;
	}
}

@media screen and (max-height: 950px){
	#topimg { 
		height: calc(100vh - 112px);
	}
}
@media screen and (min-width: 1600px){
	#topimg {
		background: url(../images_bf/topimg_title_bf.jpg) 22% top no-repeat;
		background-size: cover;
	}
}

/* ▼PICK UP▼ */
.top_pickup {
	position: relative;
	margin-top: 70px;
	padding-bottom: 80px;
}

.top_pickup .title01 + .btn01 {
	width: 300px;
	font-weight: 500;
	position: absolute;
	top: 0;
	right: 0;
}

.top_pickup .plist {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
	padding-top: 40px;
	gap: 45px;
}

.top_pickup .plist li {
	list-style-type: none;
  border: 1px solid #dadada;
  width: 370px;
	padding: 0 20px 20px 20px;
}

.top_pickup .plist li .plist_category {
	display: inline-block;
	background-color: #e0e300;
	border-bottom-right-radius: 8px;
	border-bottom-left-radius: 8px;
	width: 100px;
	font-weight: bold;
	text-align: center;
	padding: 6px 0;
}
.top_pickup .plist li .plist_category.lg {
	background-color: #e0e300;
}

.top_pickup .plist li .plist_category.st {
	background-color: #97e94f;
}

.top_pickup .plist li .plist_title {
	font-size: 1.6rem;
	line-height: 1.8;
	letter-spacing: 2px;
	font-weight: bold;
	border-bottom: 2px solid #e5e5e5;
	padding: 10px 0;
}

.top_pickup .plist li .plist_desc {
	position: relative;
	padding-top: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid #e5e5e5;
	display: flex;
	align-items: center;
}

.top_pickup .plist li .plist_desc p {
	display: inline-block;
}

.top_pickup .plist li .plist_desc p:nth-of-type(1) {
	position: relative;
	font-weight: bold;
	width: 98px;
	padding-left: 28px;
	flex: 0 0 98px;
}

.top_pickup .plist li .plist_desc p:nth-of-type(2) {
	font-weight: 500;
}

.top_pickup .plist li .plist_desc p.location::before {
	content: '';
	position: absolute;
	display: block;
	transition: .5s;
	backface-visibility: hidden;
	top: 50%;
	left: 4px;
	width: 16px;
	height: 23px;
	background: url(../images_bf/icon_pin.png) no-repeat;
	background-size: 16px;
	transform: translateY(-50%);
}

.top_pickup .plist li .plist_desc p.salary::before {
	content: '';
	position: absolute;
	display: block;
	transition: .5s;
	backface-visibility: hidden;
	top: 50%;
	left: 0;
	width: 21px;
	height: 21px;
	background: url(../images_bf/icon_dol.png) no-repeat;
	background-size: 21px;
	transform: translateY(-50%);
}

.top_pickup .plist li .plist_desc p.time::before {
	content: '';
	position: absolute;
	display: block;
	transition: .5s;
	backface-visibility: hidden;
	top: 50%;
	left: 1px;
	width: 19px;
	height: 19px;
	background: url(../images_bf/icon_clock.png) no-repeat;
	background-size: 19px;
	transform: translateY(-50%);
}

.top_pickup .plist li .btn01 {
	margin-top: 22px;
}

/* ▼FLOW▼ */
.top_flow {
	position: relative;
	padding-top: 70px;
	padding-bottom: 80px;
	background-color: #f2f2f2;
}

.top_flow .flow_list {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	gap: 10px;
	padding-top: 34px;
}

.top_flow .flow_list li {
	position: relative;
	width: 290px;
	background-color: #fff;
	border-radius: 6px;
	padding: 10px 10px 18px 10px;
	box-shadow: 0px 0px 6px 0px rgb(0 0 0 / 20%);
}
.top_flow .flow_list li:first-child {
	padding-bottom: 8px;
}

.top_flow .flow_list li::before {
	content: '';
	display: block;
	background-image: url(../images_bf/icon_tri.png);
	background-size: cover;
	width: 34px;
	height: 40px;
	position: absolute;
	top: 50%;
	right: -24px;
	transform: translateY(-50%);
	z-index: 10;
}
.top_flow .flow_list li::after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	background-color: #fff;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	z-index: 11;
}
.top_flow .flow_list li:last-child::before,
.top_flow .flow_list li:last-child::after {
	display: none;
}

.top_flow .flow_list li .list_step {
	position: relative;
	text-align: center;
	font-size: 3.0rem;
	font-weight: 800;
	color: #00babd;
}

.top_flow .flow_list li .list_step span {
	font-size: 3.6rem;
	padding-left: 10px;
}

.top_flow .flow_list li .list_step::before {
	content: '';
	display: block;
	width: 50px;
	height: 8px;
	background-color: #e0e300;
	position: absolute;
	left: 50%;
	bottom: -6px;
	transform: translateX(-50%);
}

.top_flow .flow_list li .list_title {
	color: #343434;
	font-size: 2.2rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
	padding-top: 40px;
}
.top_flow .flow_list li:first-child .list_title {
	font-size: 2.0rem;
	padding-top: 32px;
}

.top_flow .flow_list li .list_desc {
	position: relative;
	display: inline-block;
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
	font-style: normal;
	color: #343434;
	left: 50%;
  transform: translateX(-50%);
}

.top_flow .flow_list li .list_desc::before,
.top_flow .flow_list li .list_desc::after {
	content: '';
	display: block;
	width: 15px;
	height: 23px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background-size: cover;
}

.top_flow .flow_list li .list_desc::before {
	background-image: url(../images_bf/line_left.png);
	left: -20px;
}
.top_flow .flow_list li .list_desc::after {
	background-image: url(../images_bf/line_right.png);
	right: -18px;
}
.top_flow .flow_list li:first-child .list_desc::before,
.top_flow .flow_list li:first-child .list_desc::after {
	top: 62%;
}

.top_flow .flow_list li .list_desc .bgText {
	font-size: 3.6rem;
}

.top_flow .flow_list li .list_desc .text-marker {
  background: linear-gradient(to bottom, transparent 75%, #f6f788 75%);
}

.top_flow .flow_list li img {
	position: relative;
	left: 50%;
	transform: translateX(-50%);
}
.top_flow .flow_list li:nth-of-type(1) img {
	left: 52%;
	padding-top: 33px;
}
.top_flow .flow_list li:nth-of-type(2) img {
	padding-top: 44px;
	padding-bottom: 26.2px;
}
.top_flow .flow_list li:nth-of-type(3) img {
	padding-top: 46px;
	padding-bottom: 28.2px;
}
.top_flow .flow_list li:nth-of-type(4) img {
	padding-top: 53px;
	padding-bottom: 27.2px;
}

/* ▼CTA CONTACT▼ */
.cta_contact {
	position: relative;
	background-image: url(../images_bf/contact_bg_on.jpg);
	background-size: cover;
}

.cta_contact a {
	display: block;
	color: #fff;
	padding-top: 74px;
	padding-bottom: 64px;
	background-image: url(../images_bf/contact_bg_off.jpg);
	background-size: cover;
	transition: all 0.5s ease;
}

.cta_contact a:hover {
	background-image: url(../images_bf/contact_bg_on.jpg);
	opacity: 1;
}

.cta_contact a .contact_desc {
	font-size: 1.5rem;
	font-weight: 500;
	text-align: center;
	letter-spacing: 2px;
}

.cta_contact a .contact_title {
	position: relative;
	display: inline-block;
	font-size: 3.6rem;
	font-weight: bold;
	letter-spacing: 4px;
	padding-top: 24px;
	padding-bottom: 16px;
	left: 50%;
	transform: translateX(-50%);
}
.cta_contact a .contact_title span {
	content: '';
	display: inline-block;
	width: 40px;
	height: 7px;
	position: absolute;
	top: 50%;
	right: -74px;
	background-image: url(../images_bf/icon_freedial_arrow.png);
	background-size: cover;
}

.cta_contact a .contact_tel {
	position: relative;
	font-size: 3.0rem;
	font-weight: 500;
	text-align: center;
}

.cta_contact a .contact_tel span {
	content: '';
	display: inline-block;
	width: 50px;
	height: 33px;
	position: relative;
	top: 6px;
	right: 0;
	background-image: url(../images_bf/contact_img01.png);
	background-size: cover;
	margin-right: 13px;
}


/*
JOB BF
***************************************************************************/
/* ▼SEARCH▼ */
.jobs_search {
	position: relative;
	padding-top: 80px;
	padding-bottom: 60px;
	background-color: #f2f2f2;
}

.jobs_search .search_main {
	position: relative;
	padding: 40px 50px 54px 50px;
	background: #fff;
	border-radius: 6px;
	box-shadow: 0px 0px 20px rgba(118,118,118,0.25);
}

.jobs_search .search_main > p {
	font-size: 2.8rem;
	font-weight: bold;
	color: #141414;
	padding-bottom: 26px;
}

.jobs_search .search_main > p span {
	font-size: 1.4rem;
	font-weight: normal;
	padding-left: 10px;
}

.jobs_search .search_main .list {
	display: grid;
  grid-template-columns: 260px 260px 260px 260px;
	column-gap: 20px;
	margin-bottom: 50px;
}

.jobs_search .search_main .list li {
	width: 260px;
	margin-right: 15px;
}

.jobs_search .search_main  .list li:last-child { margin-right:0; }

.jobs_search .search_main .list li select {
	font-size: 1.6rem;
	line-height: 58px;
	background: #fff url(../images_bf/icon_arrow_select.png) right 12px center no-repeat;
	color: #b1b1b1;
}

.jobs_search .search_main .list_submit {
	display: block;
	width: 540px;
	margin: 0 auto;
}

.jobs_search .search_main .list_submit .btn01 {
	font-size: 1.8rem;
	letter-spacing: 2px;
	font-weight: 500;
	box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 25%);
}

.jobs_search .search_result {
	position: relative;
	padding: 50px 50px 0 50px;
}

.jobs_search .search_result > p {
	font-size: 2.4rem;
	font-weight: bold;
	color: #141414;
	padding-bottom: 10px;
}

.jobs_search .search_result .list {
	display: grid;
  grid-template-columns: 330px 220px 130px 280px;
	column-gap: 50px;
	padding-bottom: 40px;
}

.jobs_search .search_result .list li {
	position: relative;
	font-size: 1.4rem;
	font-weight: bold;
	color: #343434;
	padding-left: 20px;
	line-height: 54px;
	border-bottom: 1px dotted #d0d0d0;
}
.jobs_search .search_result .list li::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 51%;
	transform: translateY(-50%);
	width: 6px;
	height: 6px;
	background-color: #72b9ba;
	border-radius: 50%;
}

.jobs_search .search_result .list li span {
	font-weight: 500;
	padding-left: 26px;
}

.jobs_search  .search_result .btn01 {
	font-size: 1.5rem;
	font-weight: 500;
	width: 430px;
	display: block;
	margin: 0 auto;
}


/* ▼JOB LIST▼ */
.jobs_list {
	position: relative;
	margin-top: 80px;
	padding-bottom: 80px;
}

.jobs_list .plist {
	display: grid;
  grid-template-columns: 370px 370px 370px;
	column-gap: 45px;
	row-gap: 60px;
	padding-bottom: 70px;
}

.jobs_list .plist li {
	list-style-type: none;
  border: 1px solid #dadada;
  width: 370px;
	padding: 0 20px 20px 20px;
}

.jobs_list .plist li .plist_category {
	display: inline-block;
	background-color: #e0e300;
	border-bottom-right-radius: 8px;
	border-bottom-left-radius: 8px;
	width: 100px;
	font-weight: bold;
	text-align: center;
	padding: 6px 0;
}

.jobs_list .plist li .plist_category.lg {
	background-color: #e0e300;
}

.jobs_list .plist li .plist_category.st {
	background-color: #97e94f;
}

.jobs_list .plist li .plist_title {
	font-size: 1.6rem;
	line-height: 1.8;
	letter-spacing: 2px;
	font-weight: bold;
	border-bottom: 2px solid #e5e5e5;
	padding: 10px 0;
}

.jobs_list .plist li .plist_desc {
	position: relative;
	padding-top: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid #e5e5e5;
	display: flex;
	align-items: center;
}

.jobs_list .plist li .plist_desc p {
	display: inline-block;
}

.jobs_list .plist li .plist_desc p:nth-of-type(1) {
	position: relative;
	font-weight: bold;
	width: 98px;
	padding-left: 28px;
	flex: 0 0 98px;
}

.jobs_list .plist li .plist_desc p:nth-of-type(2) {
	font-weight: 500;
}

.jobs_list .plist li .plist_desc p.location::before {
	content: '';
	position: absolute;
	display: block;
	transition: .5s;
	backface-visibility: hidden;
	top: 50%;
	left: 4px;
	width: 16px;
	height: 23px;
	background: url(../images_bf/icon_pin.png) no-repeat;
	background-size: 16px;
	transform: translateY(-50%);
}

.jobs_list .plist li .plist_desc p.salary::before {
	content: '';
	position: absolute;
	display: block;
	transition: .5s;
	backface-visibility: hidden;
	top: 50%;
	left: 0;
	width: 21px;
	height: 21px;
	background: url(../images_bf/icon_dol.png) no-repeat;
	background-size: 21px;
	transform: translateY(-50%);
}

.jobs_list .plist li .plist_desc p.time::before {
	content: '';
	position: absolute;
	display: block;
	transition: .5s;
	backface-visibility: hidden;
	top: 50%;
	left: 1px;
	width: 19px;
	height: 19px;
	background: url(../images_bf/icon_clock.png) no-repeat;
	background-size: 19px;
	transform: translateY(-50%);
}

.jobs_list .plist li .btn01 {
	width: 330px;
	margin-top: 22px;
}
.jobs_list .plist li .btn01.gray {
	width: 328px;
}

.jobs_list .plist li .btn01 + .btn01 {
	margin-top: 0;
}

.jobs_list .add_btn {
	display: block;
	width: 540px;
	margin: 0 auto;
}

.jobs_list .add_btn .btn01 {
	font-size: 1.8rem;
	font-weight: 500;
	box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 25%);
}

/* ▼DETAIL▼ */
.jobs_detail {
	position: relative;
}

.jobs_detail .detail_title {
	padding-top: 75px;
	padding-bottom: 50px;
}

.jobs_detail .detail_title .sub {
	font-weight: 500;
}

.jobs_detail .detail_title h2 {
	font-size: 2.0rem;
	font-weight: bold;
	color: #141414;
	padding-top: 28px;
	padding-bottom: 30px;
}

.jobs_detail .detail_title .num {
	display: inline-block;
	color: #fff;
	font-weight: 500;
	line-height: 50px;
	background-color: #b2b2b2;
	border-radius: 4px;
	padding: 0 24px;
}

.jobs_detail .detail_title .num + .num {
	margin-left: 10px;
}

.jobs_detail .detail_title .tag {
    display: inline-block;
    flex-direction: row;
    justify-content: flex-start;
    gap: 10px;
    padding-top: 20px;
    padding-bottom: 50px;
}

.jobs_detail .detail_title .tag li {
    font-weight: 500;
    color: #fff;
    line-height: 30px;
    background-color: #47d5d7;
    border-radius: 15px;
    padding: 0 24px 2px 24px;
    display: inline-block;
    margin-bottom: 10px;
}

.jobs_detail .detail_title .data {
	border-top: 2px solid #d6d6d6;
}

.jobs_detail .detail_title .data dl {
	padding: 25px 30px;
	border-bottom: dotted 1px #c5c5c5;
}

.jobs_detail .detail_title .data dt {
	position: relative;
	float: left;
	width: 15%;
	padding: 0 30px 0 0;
	text-align: left;
	font-weight: bold;
	color: #333;
}

.jobs_detail .detail_title .data dd {
	float: right;
	width: 85%;
	padding-right: 10px;
	color: #343434;
	font-weight: 500;
}

.jobs_detail .detail_point {
	position: relative;
	padding-bottom: 200px;
}

.jobs_detail .detail_point .point_wrap {
	border-radius: 6px;
	padding: 30px 40px 45px 40px;
	/*box-shadow: 0 0 7px 1px rgb(0 0 0 / 15%);*/
}

.jobs_detail .detail_point .point_wrap p {
	position: relative;
	font-size: 3.0rem;
	font-weight: bold;
	color: #00babd;
}

.jobs_detail .detail_point .point_wrap p::before {
	content: '';
	display: block;
	width: 26px;
	height: 8px;
	position: absolute;
	top: 50%;
	left: -40px;
	transform: translateY(-50%);
	background-color: #e0e300;
}

.jobs_detail .detail_point .point_wrap ul li {
	position: relative;
	padding-left: 25px;
}

.jobs_detail .detail_point .point_wrap ul ul {
	padding-top: 20px;
}

.jobs_detail .detail_point .point_wrap ul li::before {
	content: '';
	display: block;
	width: 6px;
	height: 6px;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	background-color: #72b9ba;
	border-radius: 50%;
}

.jobs_detail .detail_point img {
	position: absolute;
	top: 60px;
	right: 60px;
	width: 530px;
}

.jobs_detail .detail_list {
	margin-top: 20px;
	margin-bottom: 80px;
	border-top: 2px solid #d6d6d6;
}

.jobs_detail .detail_list dl {
	padding: 25px 30px;
	border-bottom: dotted 1px #c5c5c5;
}

.jobs_detail .detail_list dt {
	position: relative;
	float: left;
	width: 15%;
	padding: 0 30px 0 0;
	text-align: left;
	font-weight: bold;
	color: #333;
}

.jobs_detail .detail_list dd {
	float: right;
	width: 85%;
	padding-right: 10px;
	color: #343434;
	font-weight: 500;
}

.jobs_detail .detail_list .btn01 {
	display: block;
	font-size: 1.8rem;
	font-weight: 500;
	width: 540px;
	margin: 80px auto 0;
	box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 25%);
}

/*
FORCOMPANY BF
***************************************************************************/
.forcompany_sec {
	position: relative;
	background-image: url(../forcompany_bf/images/forcompany_bf_bg.jpg);
	background-size: cover;
	padding-top: 108px;
	padding-bottom: 90px;
}

.forcompany_sec .base_box p:nth-of-type(1) {
	font-size: 3.6rem;
	font-weight: bold;
	color: #fff;
}

.forcompany_sec .base_box p:nth-of-type(2) {
	font-size: 1.5rem;
	font-weight: 500;
	color: #fff;
	padding-top: 42px;
  padding-bottom: 44px;
}

.forcompany_sec .base_box .btn01 {
	font-size: 1.8rem;
	width: 500px;
}
@media screen and (max-width: 1250px){
	.forcompany_sec .base_box .btn01 {
		width: 450px;
	}
}

.forcompany_sec .base_box img {
	position: absolute;
	top: 0;
	right: -100px;
	width: 700px;
}
@media screen and (max-width: 1200px){
	.forcompany_sec .base_box img {
		top: 70px;
		width: 600px;
	}
}

.c_strengths_sec {
	position: relative;
	padding-top: 135px;
	padding-bottom: 90px;
}

.c_strengths_sec .title01 {
	padding-bottom: 36px;
}

.c_strengths_sec .list {
	display: grid;
  grid-template-columns: 580px 580px;
	column-gap: 40px;
	row-gap: 76px;
}

.c_strengths_sec .list li {
	position: relative;
	width: 580px;
	border-radius: 6px;
}

.c_strengths_sec .list li::before {
	content: '';
	width: 580px;
	height: fit-content;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	border-radius: 6px;
	box-shadow: 0px 0px 9px 1px rgb(0 0 0 / 20%);
}
.c_strengths_sec .list li:nth-of-type(1):before,
.c_strengths_sec .list li:nth-of-type(2):before {
	height: 624px;
}
.c_strengths_sec .list li:nth-of-type(3):before,
.c_strengths_sec .list li:nth-of-type(4):before {
	height: 560px;
}

.c_strengths_sec .list li .num {
	position: absolute;
	top: -72px;
	right: 8px;
}

.c_strengths_sec .list li .num {
	font-size: 12.0rem;
	font-weight: 800;
	color: #00babd;
	line-height: 1.1;
}

.c_strengths_sec .list li .num span {
	position: relative;
	display: block;
	font-size: 1.6rem;
	font-family: 'Lato', sans-serif;
	padding-left: 40px;
}

.c_strengths_sec .list li .num span::before {
	content: '';
	display: block;
	position: absolute;
	left: 2px;
	top: 50%;
	width: 26px;
	height: 8px;
	background-color: #e0e300;
	transform: translateY(-50%);
}

.c_strengths_sec .list li img {
	width: 100%;
}

.c_strengths_sec .list li .list_text {
	padding: 44px 50px;
}

.c_strengths_sec .list li .list_text h3 { 
	font-size: 3.2rem;
	font-weight: bold;
	padding-bottom: 28px;
}

.c_strengths_sec .list li .list_text p {
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.12rem;
}

@media screen and (max-width: 1200px){
	.c_strengths_sec .list {
		column-gap: 0;
	}
	.c_strengths_sec .list li {
		width: 500px;
	}
	.c_strengths_sec .list li::before {
		content: '';
		width: 500px;
	}
}

/*
FOR USER
***************************************************************************/
.foruser_jobs {
	display: block;
	color: #fff;
	padding-top: 20px;
	padding-bottom: 100px;
	/* background-image: url(../foruser_bf/images/foruser_bg01.jpg); */
	/* background-size: cover; */
	transition: all 0.5s ease;
}
.foruser_jobs h2 {
	font-size: 3.4rem;
	font-weight: 600;
	text-align: center;
	letter-spacing: 4px;
	/* color: #fff; */
}

.foruser_jobs p {
	font-size: 1.5rem;
	font-weight: 500;
	text-align: center;
	color: #343434;
	padding-top: 50px;
}

.foruser_jobs .btn01 {
	display: block;
	font-size: 2rem;
	font-weight: 500;
	margin: 60px auto 0;
	width: 740px;
	box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 25%);
	height: 90px;
	line-height: 90px;
}

.foruser_flow {
	position: relative;
	padding-top: 70px;
	padding-bottom: 80px;
	background-color: #f2f2f2;
}

.foruser_flow .flow_list {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	gap: 10px;
	padding-top: 34px;
}

.foruser_flow .flow_list li {
	position: relative;
	width: 290px;
	background-color: #fff;
	border-radius: 6px;
	padding: 10px 10px 18px 10px;
	box-shadow: 0px 0px 6px 0px rgb(0 0 0 / 20%);
}
.foruser_flow .flow_list li:first-child {
	padding-bottom: 8px;
}

.foruser_flow .flow_list li::before {
	content: '';
	display: block;
	background-image: url(../images_bf/icon_tri.png);
	background-size: cover;
	width: 34px;
	height: 40px;
	position: absolute;
	top: 50%;
	right: -24px;
	transform: translateY(-50%);
	z-index: 10;
}
.foruser_flow .flow_list li::after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	background-color: #fff;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	z-index: 11;
}
.foruser_flow .flow_list li:last-child::before,
.foruser_flow .flow_list li:last-child::after {
	display: none;
}

.foruser_flow .flow_list li .list_step {
	position: relative;
	text-align: center;
	font-size: 3.0rem;
	font-weight: 800;
	color: #00babd;
}

.foruser_flow .flow_list li .list_step span {
	font-size: 3.6rem;
	padding-left: 10px;
}

.foruser_flow .flow_list li .list_step::before {
	content: '';
	display: block;
	width: 50px;
	height: 8px;
	background-color: #e0e300;
	position: absolute;
	left: 50%;
	bottom: -6px;
	transform: translateX(-50%);
}

.foruser_flow .flow_list li .list_title {
	color: #343434;
	font-size: 2.2rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
	padding-top: 40px;
}
.foruser_flow .flow_list li:first-child .list_title {
	font-size: 2.0rem;
	padding-top: 32px;
}

.foruser_flow .flow_list li .list_desc {
	position: relative;
	display: inline-block;
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
	font-style: normal;
	color: #343434;
	left: 50%;
  transform: translateX(-50%);
}

.foruser_flow .flow_list li .list_desc::before,
.foruser_flow .flow_list li .list_desc::after {
	content: '';
	display: block;
	width: 15px;
	height: 23px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background-size: cover;
}

.foruser_flow .flow_list li .list_desc::before {
	background-image: url(../images_bf/line_left.png);
	left: -20px;
}
.foruser_flow .flow_list li .list_desc::after {
	background-image: url(../images_bf/line_right.png);
	right: -18px;
}
.foruser_flow .flow_list li:first-child .list_desc::before,
.foruser_flow .flow_list li:first-child .list_desc::after {
	top: 62%;
}

.foruser_flow .flow_list li .list_desc .bgText {
	font-size: 3.6rem;
}

.foruser_flow .flow_list li .list_desc .text-marker {
  background: linear-gradient(to bottom, transparent 75%, #f6f788 75%);
}

.foruser_flow .flow_list li img {
	position: relative;
	left: 50%;
	transform: translateX(-50%);
}
.foruser_flow .flow_list li:nth-of-type(1) img {
	left: 52%;
	padding-top: 33px;
}
.foruser_flow .flow_list li:nth-of-type(2) img {
	padding-top: 44px;
	padding-bottom: 26.2px;
}
.foruser_flow .flow_list li:nth-of-type(3) img {
	padding-top: 46px;
	padding-bottom: 28.2px;
}
.foruser_flow .flow_list li:nth-of-type(4) img {
	padding-top: 53px;
	padding-bottom: 27.2px;
}

.foruser_flow .btn01 {
	/* display: block;
	font-size: 1.8rem;
	font-weight: 500;
	margin: 80px auto 0;
	width: 540px;
	box-shadow: 0px 0px 5px 0px rgb(0 0 0 / 25%); */
}

.u_strengths_sec {
	position: relative;
	padding-top: 90px;
	padding-bottom: 90px;
}

.u_strengths_sec .title01 {
	padding-bottom: 36px;
}

.u_strengths_sec .list {
	display: grid;
  grid-template-columns: 580px 580px;
	column-gap: 40px;
	row-gap: 76px;
}

.u_strengths_sec .list li {
	position: relative;
	width: 580px;
	border-radius: 6px;
}

.u_strengths_sec .list li::before {
	content: '';
	width: 580px;
	height: fit-content;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	border-radius: 6px;
	box-shadow: 0px 0px 9px 1px rgb(0 0 0 / 20%);
}
.u_strengths_sec .list li:nth-of-type(1):before,
.u_strengths_sec .list li:nth-of-type(2):before {
	height: 650px;
}
.u_strengths_sec .list li:nth-of-type(3):before,
.u_strengths_sec .list li:nth-of-type(4):before {
	height: 600px;
}

.u_strengths_sec .list li .num {
	position: absolute;
	top: -72px;
	right: 8px;
}

.u_strengths_sec .list li .num {
	font-size: 12.0rem;
	font-weight: 800;
	color: #00babd;
	line-height: 1.1;
}

.u_strengths_sec .list li .num span {
	position: relative;
	display: block;
	font-size: 1.6rem;
	font-family: 'Lato', sans-serif;
	padding-left: 42px;
}

.u_strengths_sec .list li .num span::before {
	content: '';
	display: block;
	position: absolute;
	left: 6px;
	top: 50%;
	width: 26px;
	height: 8px;
	background-color: #e0e300;
	transform: translateY(-50%);
}

.u_strengths_sec .list li img {
	width: 100%;
}

.u_strengths_sec .list li .list_text {
	padding: 44px 50px 56px 50px;
}

.u_strengths_sec .list li .list_text h3 { 
	font-size: 3.2rem;
	font-weight: bold;
	padding-bottom: 28px;
}

.u_strengths_sec .list li .list_text p {
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.14rem;
}


/*
APPLICATION BF
***************************************************************************/
.application_sec {
	position: relative;
	padding: 0 0 110px;
}

.application_sec:before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: calc((1100 / 1800) * 100vw);
	height: 100%;
	z-index: 0;
}

.application_sec .sec_inner {
	position: relative;
	width: 1200px;
	margin: 0 auto;
	padding-top: 60px;
	text-align: left;
	line-height: 2.15;
	background: #fff;
	border-radius: 20px;
	z-index: 1;
}

.application_sec .sec_inner .top_text {
	padding-left: 30px;
}

.application_sec .sec_inner .top_text .must {
	position: relative;
	padding-left: 20px;
}
.application_sec .sec_inner .top_text .must::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: #72b9ba;
	position: absolute;
	left: 4px;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 1400px){

	.application_sec .sec_inner { width:auto; margin:0 calc((80 / 1800) * 100vw); }

}

/* ▼STEP▼ */
.application_sec .step_bg {
	background: #f3f3f3;
}
.application_sec .step {
	position: relative;
	width: 1200px;
	margin: 0 auto 30px;
	padding: 60px 100px 100px;
	z-index: 1;
}

@media screen and (max-width: 1400px){

	.application_sec .step { width:auto; margin:0 calc((80 / 1800) * 100vw) 30px; padding:25px 50px 35px; }

}

.application_sec .step ul {
	display: flex;
	flex-direction: row;
	justify-content: center;
	border-bottom: solid 2px #d6d6d6;
}

.application_sec .step li {
	position: relative;
	width: 180px;
	margin-right: 130px;
	padding-bottom: 20px;
	padding-bottom: 20px;
	text-align: center;
	font-size: 1.4rem;
	font-weight: bold;
	color: #818181;
	line-height: 1.6;
}
.application_sec .step li.active {
	font-size: 1.8rem;
	color: #333333;
}

.application_sec .step li:last-child { margin-right:0; }

.application_sec .step li span {
	display: block;
	font-size: 1.8rem;
	font-weight: 700;
	color: #00babd;
}
.application_sec .step li span span {
	display: inline-block;
	font-size: 3.0rem;
	font-weight: 700;
	color: #00babd;
	padding-left: 3px;
}

.application_sec .step li:before {
	content: '';
	position: absolute;
	bottom: -9px;
	left: 50%;
	width: 16px;
	height: 16px;
	margin-left: -5px;
	background: #e0e300;
	border-radius: 50%;
	z-index: 1;
}

.application_sec .step li.active:before {
	bottom: -13px;
	width: 24px;
	height: 24px;
	margin-left: -10px;
}

/* ▼USER FORM▼ */
.user_form {
	margin-bottom: 40px;
	text-align: left;
	line-height: 2;
	border-top: 2px solid #d6d6d6;
}

.user_form.conf { margin-bottom:80px; }
.user_form.resume { margin-bottom:0!important; }

.user_form dl {
	padding: 30px 60px;
	border-bottom: dotted 1px #c5c5c5;
}

.user_form.conf dl { padding:25px 60px; }
.user_form dl.ex, .user_form.ex dl { padding:25px 60px; }
.user_form.resume dl:last-child { border-bottom:none; }

.user_form dt {
	position: relative;
	float: left;
	width: 22%;
	padding: 0 30px 0 0;
	text-align: left;
	font-weight: 700;
	color: #333;
	line-height: 60px;
}

.user_form.resume dt { width:25%; }
.user_form.conf dt { line-height:2; }
.user_form dt.ex { margin-top:-5px; }

.user_form dt.must { padding:0 30px 0 0; }

.user_form dt.must:before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: #72b9ba;
	position: absolute;
	left: -18px;
	top: 50%;
	transform: translateY(-50%);
}

.user_form dt.must .size12 { margin-right:-10px; }

.user_form dt .mark {
	display: inline-block;
	position: relative;
	padding-left: 20px;
}

.user_form dt .mark:before {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #ee426f;
	border-radius: 50%;
}

.user_form dd {
	float: right;
	width: 78%;
	padding-right: 10px;
	color: #343434;
	font-weight: 500;
}

.user_form.resume dd { width:75%; }

.user_form .box {
	margin-bottom: 15px;
}

.user_form .box:last-child { margin-bottom:0; }

.user_form .box .txt {
	float: left;
	width: 36px;
	line-height: 60px;
}

.user_form .box .input {
	float: left;
	width: calc(95% - 80px);
}

/* ▼OPTION▼ */
.user_option {
	position: relative;
	background-color: #f3f3f3;
	text-align: center;
	margin-bottom: 80px;
}

.user_option .option_btn {
	position: relative;
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 80px;
  color : #343434;
	cursor: pointer;
}

.user_option .option_btn::before,
.user_option .option_btn::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 20px;
	width: 30px;
	height: 1px;
	transform: translateY(-50%);
	background-color: #00babd;
}
.user_option .option_btn::after {
	transform: translateY(-50%) rotate(90deg);
}


/*
CONTACT
***************************************************************************/
.contact_sec {
	position: relative;
	padding: 90px 0 95px;
}

.contact_sec:before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: calc((1015 / 1800) * 100vw);
	height: 345px;
	background: #8fd127;
	z-index: 0;
}

.contact_sec:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: calc((650 / 1800) * 100vw);
	height: 1900px;
	background: url(../common_img/bg01.png) repeat;
	z-index: 0;
}

.contact_sec:after { max-height:100%; }

.contact_sec.comp:after { height:360px; }

.contact_sec .sec_inner {
	position: relative;
	width: 1200px;
	margin: 0 auto;
	padding: 70px 100px 120px;
	background: #fff;
	border-radius: 20px;
	box-shadow: 0px 0px 20px rgba(118,118,118,0.25);
	z-index: 1;
}

@media screen and (max-width: 1400px){

	.contact_sec .sec_inner { width:auto; margin:0 calc((80 / 1800) * 100vw); }

}

.contact_sec.comp .sec_inner { padding:70px 100px; }

.contact_sec .sec_title {
	margin-bottom: 30px;
	text-align: center;
	font-size: 3rem;
}

.contact_sec .sec_txt {
	margin-bottom: 60px;
	text-align: center;
	line-height: 2.15;
}

.contact_sec .sec_txt a {
	padding-bottom: 4px;
	border-bottom: solid 1px #70b108;
}

/* ▼FORM COMMON▼ */
.pp_box {
	margin-bottom: 110px;
	padding: 60px 60px 45px;
	border-radius: 6px;
	box-shadow: 0 0 6px 1px rgb(0 0 0 / 15%);
}

.pp_box .title {
	margin-bottom: 30px;
	text-align: center;
	font-size: 1.8rem;
}

.pp_box p > a {
	border-bottom: 1px solid #00babd;
}

.pp_box .stitle {
	margin-bottom: 15px;
	font-size: 1.8rem;
}

.pp_box .scroll_box {
	height: 270px;
	margin: 0 25px 30px 70px;
	padding: 25px 0;
	overflow-y: auto;
}

.pp_box .agree {
	margin: 0 auto;
	padding: 22px 0;
	margin-top: 40px;
	text-align: center;
	background-color: #f3f3f3;
}

.pp_box .agree .chk_icon {
	display: inline-block;
}

.btn_form {
	width: 540px;
	margin: 0 auto;
}

.btn_form .conf {
	display:none;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 1.4px;
	box-shadow: rgb(0 0 0 / 25%) 0px 0px 5px 0px;
}

.btn_form .disable {
	color: #afafaf;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 1.4px;
	pointer-events: none;
}

.btn_form.col li {
	float: left;
	width: 380px;
	margin: 0;
}

.btn_form.col li:last-child { float:right; }

.btn_form.col li .btn01 {
	font-weight:500; 
}

#mfp_hidden, #mfp_overlay_background, #mfp_loading_screen, #mfp_loading, #mfp_overlay { display:none; }

.mfp_err {
	display: none;
	margin-top: 20px;
	padding: 0 15px;
	text-align: left;
	font-size: 1.4rem;
	color: #fff;
	line-height: 40px;
	background: #8fd127;
	clear: both;
}

.error_txt {
	margin: -30px 0 70px;
	text-align: center;
	font-size: 1.4rem;
	color: #ff9600;
	line-height: 1.8;
}

.err_txt {
	margin: 10px 15px 0;
	font-size: 1.4rem;
	color: #ff9600;
	line-height: 1.8;
}

.noagree_txt {
	margin-top: 35px;
	text-align: left;
	font-size: 1.4rem;
	color: #ff9600;
}

.end_txt {
	margin-bottom: 35px;
	padding: 20px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 400;
	color: #fff;
	background: #ff9600;
}


/*
BREADCRUMBS
***************************************************************************/
.breadcrumbs{
	padding-top: 8px;
	padding-bottom: 10px;
	background-color: #f7f7f7;
}

.breadcrumbs ul li {
	position: relative;
	display: inline;
	margin-right: 16px;
	font-size: 1.2rem;
	font-weight: 300;
	color: #6d6d6d;
	line-height: 1.8;
}

.breadcrumbs ul li a {
	color: #8c8c8c;
	border-bottom: 1px solid #cbc9c9;
	margin-right: 12px;
	padding-bottom: 2px;
}
.breadcrumbs ul li:after{
	content: ">";
	display: inline-block;
	position: absolute;
	top: 50%;
	right: -10px;
	transform: translateY(-50%);
}
.breadcrumbs ul li:last-child::after{
	display: none;
}


/*
FOOTER
***************************************************************************/
footer {
	position: relative;
	padding: 100px 0 70px 0;
	background: linear-gradient(to right, #1a1d1d 55%,#141616 55%);
}

footer .footer_wrap {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

footer .footer_wrap .link_list {
	width: 540px;
}

footer .footer_wrap .link_list .list ul {
	display: flex;
	flex-direction: row;
	justify-content: flex-start;
	gap: 60px;
}

footer .footer_wrap .link_list .list ul li a {
	font-size: 1.3rem;
	font-weight: normal;
	color: #fff;
}

footer .footer_wrap .link_list .list .btn01 {
	font-weight: 500;
	width: 360px;
	margin-top: 30px;
	margin-bottom: 60px;
	background: #fff;
}

footer .footer_wrap .link_list .banner {
	position: relative;
}

footer .footer_wrap .link_list .banner .banner_inner {
	position: absolute;
	right: 0;
	top: 50%;
	padding-left: 8px;
	transform: translateY(-50%);
}

footer .footer_wrap .link_list .banner .banner_inner img,
footer .footer_wrap .link_list .banner .banner_inner a,
footer .footer_wrap .link_list .banner .banner_inner a img {
	width: 74px;
}

footer .footer_wrap .link_list .banner .banner_inner img + img,
footer .footer_wrap .link_list .banner .banner_inner img + a {
	padding-left: 12px;
}

footer .footer_wrap .link_list .info {
	border-top: 1px solid #6a6a6a;
	margin-top: 25px;
	padding-top: 20px;
}

footer .footer_wrap .link_list .info small {
	font-size: 1.0rem;
	color: #555959;
	padding-right: 114px;
}

footer .footer_wrap .link_list .info a {
	font-size: 1.1rem;
	color: #a5a5a5;
}

footer .footer_wrap .link_list .info a + a {
	padding-left: 14px;
}

footer .footer_wrap .btn_list {
	width: 360px;
}

footer .footer_wrap .btn_list li + li {
	border-top: 1px solid #393d3d;
	padding-top: 30px;
	margin-top: 36px;
}

footer .footer_wrap .btn_list li p {
	font-size: 14px;
	font-weight: 500;
	color: #fff;
	padding-bottom: 20px;
}

footer .footer_wrap .btn_list li .btn01 {
	font-size: 1.5rem;
	font-weight: 500;
	color: #fff;
	transition: color 0.8s ease;
}

footer .footer_wrap .btn_list li .btn01 .arrow {
	right: 10px;
}

footer .footer_wrap .btn_list li .btn01:hover {
	color: #000;
}

footer .btn_ptop {
	position: absolute;
	top: 0;
	right: 0;
}

footer .btn_ptop a {
	display: block;
	font-size: 1.2rem;
	font-family: 'Lato', sans-serif;
	color: #fff;
  padding: 58px 30px 18px 30px;
  background-color: #000000;
}

footer .btn_ptop a:before {
	content: '';
	display: block;
	position: absolute;
	background-image: url(../images_bf/icon_arrow_top.png);
	background-size: cover;
	width: 5px;
	height: 24px;
	top: 24px;
	left: 50%;
	transform: translateX(-50%);
}

footer .btn_ptop a:hover:before {
	top: 18px;
}

/*
OVERLAY WINDOW
***************************************************************************/
.modal_switch, .modal_switch span {
	cursor: pointer;
	transition: .5s;
	backface-visibility: hidden;
}

#overlay_window {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.8);
	z-index: 10000;
	overflow: auto;
}

.overlay_outbox {
	position: absolute;
	width: 100%;
	height: 100vh;
}

.overlay_inner {
	position: absolute;
	top: 120px;
	left: 50%;
	width: 900px;
	height: auto;
	margin-left: -450px;
}

.overlay_content {
	display: none;
	position: relative;
	margin: 0 auto;
	padding: 60px 25px 60px 65px;
	background: #fff;
	border-radius: 20px;
	box-shadow: 0px 0px 20px rgba(118,118,118,0.25);
}

.overlay_content .scroll_box {
	max-height: calc(100vh - 360px);
	padding-right: 30px;
	overflow-y: auto;
}

#overlay_window .modal_close {
	position: absolute;
	top: -55px;
	right: 0;
	cursor: pointer;
	transition: .5s;
	backface-visibility: hidden;
	z-index: 10001;
}

#overlay_window .modal_close:hover { opacity:0.7; }

/*
ORIGINAL SCROLL
***************************************************************************/
.scroll_box::-webkit-scrollbar {
	width: 6px;
}

#overlay_window .scroll_box::-webkit-scrollbar { width:3px; }

.scroll_box::-webkit-scrollbar-track {
	background: #d9d9d9;
}

.pp_box .scroll_box::-webkit-scrollbar-track { width:1px; background:#ddd; }

.scroll_box::-webkit-scrollbar-thumb {
	background: #575757;
}

.pp_box .scroll_box::-webkit-scrollbar-thumb { background:#8fd127; }

.gecko .scroll_box {
	scrollbar-width: 6px;
	scrollbar-color: #575757 #d9d9d9;
}

.gecko #overlay_window .scroll_box { scrollbar-width:3px; }

.gecko .pp_box .scroll_box {
	scrollbar-width: 3px;
	scrollbar-color: #8fd127 #ddd;
}

/*
PARTS
***************************************************************************/
/* ▼TITLE▼ */
.title01 {
	position: relative;
	display: inline-block;
}
.title01 h2 {
	font-size: 3.4rem;
	font-weight: 600;
	color: #141414;
}
.title01 p {
	font-family: 'Lato', sans-serif;
	font-size: 1.4rem;
	color: #00babd;
	font-weight: 400;
	padding-left: 2px;
}

/* ▼TEXT▼ */
.txt_parts {
	text-align: center;
}

.txt_parts span {
	display: inline-block;
	position: relative;
	padding: 0 25px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 24px;
}

.txt_parts.black span { color:#141414; }
.txt_parts.pink span { color:#ee426f; }
.txt_parts.white span { color:#fff; }
.txt_parts.green span { color:#8fd127; }

.txt_parts span:before, .txt_parts span:after {
	content: '';
	position: absolute;
	top: 0;
	width: 16px;
	height: 24px;
}

.txt_parts span:before { left:0; }
.txt_parts span:after { right:0; }

.txt_parts.black span:before { background:url(../common_img/txt_parts_left_black.png) no-repeat; }
.txt_parts.black span:after { background:url(../common_img/txt_parts_right_black.png) no-repeat; }

.txt_parts.pink span:before { background:url(../common_img/txt_parts_left_pink.png) no-repeat; }
.txt_parts.pink span:after { background:url(../common_img/txt_parts_right_pink.png) no-repeat; }

.txt_parts.white span:before { background:url(../common_img/txt_parts_left_white.png) no-repeat; }
.txt_parts.white span:after { background:url(../common_img/txt_parts_right_white.png) no-repeat; }

.txt_parts.green span:before { background:url(../common_img/txt_parts_left_green.png) no-repeat; }
.txt_parts.green span:after { background:url(../common_img/txt_parts_right_green.png) no-repeat; }

.txt01 {
	position: relative;
	margin-bottom: 5px;
	padding-left: 12px;
	font-size: 1.4rem;
	font-weight: 700;
}

.txt01:before {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	width: 4px;
	height: 4px;
	margin-top: -2px;
	background: #8fd127;
	border-radius: 50%;
}

/* ▼BOX▼ */
.box01 {
	padding: 15px 20px;
	background: #f6f6f6;
	border-radius: 10px;
}

.box02 {
	padding: 45px 50px;
	background: #f6f6f6;
}

.box03 {
	padding: 40px;
	text-align: center;
	background: #f6f6f6;
	border-radius: 20px;
}

.box04 {
	padding: 25px 30px;
	background: #f6f6f6;
}

.box05 {
	padding: 20px;
	background: #fff;
	border: solid 1px #eaeaea;
}

/* ▼BUTTON▼ */
.btn01 {
	display: inline-block;
	position: relative;
	width: 100%;
	height: 70px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
	color: #000;
	line-height: 70px;
	font-family: "Noto Sans JP", sans-serif;
	background: transparent;
	overflow: hidden;
	cursor: pointer;
	z-index: 0;
}

.btn01.edge { border-radius:8px!important; }

.btn01:before, .btn01:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	transition: .6s;
	backface-visibility: hidden;
	opacity: 1;
}

.btn01:before { z-index:-1; }
.btn01:after { z-index:-2; }

.btn01.pink:before { background:linear-gradient(to right, #d62a57, #ef4370); }
.btn01.green:before { background:linear-gradient(to right, #71b900, #8fd127); }

.btn.black { border: 1px solid #4f5252; }
.btn01.black:before { background: linear-gradient(180deg, rgba(38,41,41,1) 0%, rgba(30,32,32,1) 20%, rgba(20,22,22,1) 100%); border: 1px solid #4f5252; }
.btn01.black:after { background: linear-gradient(to bottom, rgba(252,255,57,1) 0%, rgba(249,220,36,1) 40%, rgba(249,220,36,1) 60%, rgba(252,255,57,1) 100%); }

.btn01.white { color:#8fd127; background:#fff; border:solid 2px #fff; }
.btn01.white:hover { color:#fff; background:#8fd127; border:solid 2px #fff; }

.btn01.gray { background: linear-gradient(180deg, rgba(244,244,244,1) 0%, rgba(229,229,229,1) 100%); border: solid 1px #d1d1d1;}
.btn01.d_gray { color:#FFFFFF; background:#42413d; }

.btn01.yellow { color:#000; }
.btn01.yellow:before {background: linear-gradient(to bottom, rgba(224,227,0,1) 0%, rgba(236,198,0,1) 40%, rgba(236,198,0,1) 60%, rgba(224,227,0,1) 100%); }
.btn01.yellow:after { background: linear-gradient(to bottom, rgba(252,255,57,1) 0%, rgba(249,220,36,1) 40%, rgba(249,220,36,1) 60%, rgba(252,255,57,1) 100%); }

/* .btn01.yellow:hover { opacity: 0.8; } */

.btn01.blue { color:#FFFFFF; }
.btn01.blue::before { background: linear-gradient(0deg, rgba(0,186,189,1) 0%, rgba(102,225,227,1) 100%); }
.btn01.blue::after { background: linear-gradient(0deg, rgba(23,211,214,1) 0%, rgba(136,240,242,1) 100%); }

.btn01.pink:after { background:linear-gradient(to right, #f74473, #ff678f); }
.btn01.green:after { background:linear-gradient(to right, #8acd21, #aae946); }


.btn01:hover { opacity:1; }
a.btn01.gray:hover { opacity:0.7; }
a.btn01.d_gray:hover { opacity:0.9; }
.btn01:hover:before { opacity:0; }

.btn01.mx_small {
	height: 50px;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 50px;
}

.btn01.small {
	height: 60px;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 60px;
}

.btn01.large {
	height: 80px;
	font-size: 1.8rem;
	line-height: 80px;
}

.btn01.large.ex {
	box-sizing: border-box;
	padding-top: 8px;
	line-height: 1.45;
}

.btn01.mx_large {
	height: 90px;
	font-size: 2rem;
	line-height: 90px;
	border-radius: 45px;
}

.btn01 .arrow {
	display: block;
	position: absolute;
	top: 60%;
	right: 16px;
	width: 24px;
	height: 5px;
	margin-top: -9px;
	background: url(../images_bf/icon_arrow.png) no-repeat;
	background-size: 24px;
}

.btn01 .arrow.rev {
	right: 0;
	left: 25px!important;
}

.btn01.white .arrow {
	background: url(../common_img/arrow01_green.png) no-repeat;
	background-size: 24px;
}

.btn01.white:hover .arrow {
	background: url(../common_img/arrow01_white.png) no-repeat;
	background-size: 24px;
}

.btn01.gray .arrow {
	background: url(../images_bf/icon_arrow.png) no-repeat;
	background-size: 24px;
}

.btn01.gray .arrow.rev {
	background: url(../images_bf/icon_arrow.png) no-repeat;
	background-size: 24px;
	transform: scale(-1, 1);
}

.btn01.blue .arrow {
	background: url(../images_bf/icon_arrow_white.png) no-repeat;
	background-size: 24px;
}

.btn01.disp_switch .switch {
	padding-right: 28px;
	background: url(../common_img/arrow01_down.png) right center no-repeat;
}

.btn01.disp_switch.opened .switch {
	background: url(../common_img/arrow01_up.png) right center no-repeat;
}

.btn02 {
	display: inline-block;
	position: relative;
	width: 100%;
	height: 60px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 60px;
	font-family: "Noto Sans JP", sans-serif;
	border-radius: 30px;
	cursor: pointer;
}

.btn02 .arrow {
	display: block;
	position: absolute;
	top: 50%;
	right: 25px;
	width: 10px;
	height: 18px;
	margin-top: -9px;
}

.btn02.white { color:#fff; background:transparent; border:solid 2px #fff; }
.btn02.green { color:#8fd127; background:transparent; border:solid 2px #8fd127; }

.btn02.white .arrow {
	background: url(../common_img/arrow01_white.png) no-repeat;
	background-size: 10px;
}

.btn02.green .arrow {
	background: url(../common_img/arrow01_green.png) no-repeat;
	background-size: 10px;
}

.btn02.white:hover { color:#8fd127; background:#fff; border:solid 2px #fff; }
.btn02.green:hover { color:#fff; background:#8fd127; border:solid 2px #8fd127; }

.btn02:hover { opacity:1; }

.btn02.white:hover .arrow {
	background: url(../common_img/arrow01_green.png) no-repeat;
	background-size: 10px;
}

.btn02.green:hover .arrow {
	background: url(../common_img/arrow01_white.png) no-repeat;
	background-size: 10px;
}

.btn02.large {
	height: 70px;
	font-size: 1.8rem;
	line-height: 70px;
	border-radius: 35px;
}

/* ▼LINK▼ */
.link01 {
	position: relative;
	padding-right: 12px;
}

.link01:before {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	width: 4px;
	height: 4px;
	border-radius: 50%;
}

.link01.pink:before { background:#ee426f; }

.link01:hover:before { right:-5px; }

a.file {
	padding-right: 30px;
	background: url(../common_img/icon_file.png) right center no-repeat;
}

/* ▼LIST▼ */
.li_mb0 > li { margin-bottom:0px!important; }
.li_mb5 > li { margin-bottom:5px!important; }
.li_mb10 > li { margin-bottom:10px!important; }
.li_mb20 > li { margin-bottom:20px!important; }
.li_mb30 > li { margin-bottom:30px!important; }
.li_mb40 > li { margin-bottom:40px!important; }
.li_mb50 > li { margin-bottom:50px!important; }

.list01 > li {
	position: relative;
	margin-bottom: 10px;
	padding-left: 15px;
}

.list01 > li:last-child { margin-bottom:0; }

.list01 > li:before {
	content: '';
	position: absolute;
	top: 12px;
	left: 0;
	width: 4px;
	height: 4px;
	background: #8fd127;
	border-radius: 50%;
}

.list02 > li {
	position: relative;
	margin-bottom: 20px;
	padding-left: 45px;
}

.list02 > li:last-child { margin-bottom:0; }

.list02 > li:before {
	position: absolute;
	top: 0;
	left: 0;
}

.list02 > li:nth-child(1):before { content:'（1）'; }
.list02 > li:nth-child(2):before { content:'（2）'; }
.list02 > li:nth-child(3):before { content:'（3）'; }
.list02 > li:nth-child(4):before { content:'（4）'; }
.list02 > li:nth-child(5):before { content:'（5）'; }
.list02 > li:nth-child(6):before { content:'（6）'; }
.list02 > li:nth-child(7):before { content:'（7）'; }
.list02 > li:nth-child(8):before { content:'（8）'; }
.list02 > li:nth-child(9):before { content:'（9）'; }

.list03 > li {
	position: relative;
	margin-bottom: 15px;
	padding-left: 25px;
}

.list03 > li:last-child { margin-bottom:0; }

.list03 > li:before {
	position: absolute;
	top: 0;
	left: 0;
}

.list03.green > li:before { color:#71b900; }

.list03 > li:nth-child(1):before { content:'1.'; }
.list03 > li:nth-child(2):before { content:'2.'; }
.list03 > li:nth-child(3):before { content:'3.'; }
.list03 > li:nth-child(4):before { content:'4.'; }
.list03 > li:nth-child(5):before { content:'5.'; }
.list03 > li:nth-child(6):before { content:'6.'; }
.list03 > li:nth-child(7):before { content:'7.'; }
.list03 > li:nth-child(8):before { content:'8.'; }
.list03 > li:nth-child(9):before { content:'9.'; }

.list04 > li {
	position: relative;
	margin-bottom: 10px;
	padding-left: 30px;
}

.list04 > li:last-child { margin-bottom:0; }

.list04 > li:before {
	position: absolute;
	top: 0;
	left: 0;
}

.list04 > li:nth-child(1):before { content:'ア)'; }
.list04 > li:nth-child(2):before { content:'イ)'; }
.list04 > li:nth-child(3):before { content:'ウ)'; }
.list04 > li:nth-child(4):before { content:'エ)'; }
.list04 > li:nth-child(5):before { content:'オ)'; }
.list04 > li:nth-child(6):before { content:'カ)'; }
.list04 > li:nth-child(7):before { content:'キ)'; }
.list04 > li:nth-child(8):before { content:'ク)'; }
.list04 > li:nth-child(9):before { content:'ケ)'; }

.list05 > li {
	position: relative;
	margin-bottom: 5px;
	padding-left: 25px;
}

.list05 > li:last-child { margin-bottom:0; }

.list05 > li:before {
	position: absolute;
	top: 0;
	left: 0;
}

.list05 > li:nth-child(1):before { content:'a)'; }
.list05 > li:nth-child(2):before { content:'b)'; }
.list05 > li:nth-child(3):before { content:'c)'; }
.list05 > li:nth-child(4):before { content:'d)'; }
.list05 > li:nth-child(5):before { content:'e)'; }
.list05 > li:nth-child(6):before { content:'f)'; }
.list05 > li:nth-child(7):before { content:'g)'; }
.list05 > li:nth-child(8):before { content:'h)'; }
.list05 > li:nth-child(9):before { content:'i)'; }

.list06 > li {
	position: relative;
	margin-bottom: 5px;
	padding-left: 32px;
}

.list06 > li:last-child { margin-bottom:0; }

.list06 > li:before {
	position: absolute;
	top: 0;
	left: 0;
	font-weight: 500;
}

.list06 > li:nth-child(1):before { content:'4-1.'; }
.list06 > li:nth-child(2):before { content:'4-2.'; }
.list06 > li:nth-child(3):before { content:'4-3.'; }
.list06 > li:nth-child(4):before { content:'4-4.'; }
.list06 > li:nth-child(5):before { content:'4-5.'; }
.list06 > li:nth-child(6):before { content:'4-6.'; }
.list06 > li:nth-child(7):before { content:'4-7.'; }
.list06 > li:nth-child(8):before { content:'4-8.'; }
.list06 > li:nth-child(9):before { content:'4-9.'; }

/* ▼DL▼ */
.dlist01 dl {
	line-height: 1.8;
}

.dlist01 dt {
	float: left;
	width: 24%;
	padding: 35px 0;
	text-align: center;
	font-weight: 700;
	border-bottom: solid 2px #8fd127;
}

.dlist01 dd {
	float: right;
	width: 76%;
	padding: 35px 20px;
	border-bottom: solid 1px #eaeaea;
}

.dlist01 dl:last-child dt, .dlist01 dl:last-child dd { border-bottom:none; }

.dlist02 dt {
	float: left;
	width: 60px;
	padding-bottom: 2px;
	text-align: center;
	font-weight: 500;
	color: #fff;
	line-height: 28px;
	border-radius: 15px;
}

.dlist02 dt.pink { background:#ee426f; }
.dlist02 dt.green { background:#8fd127; }

.dlist02 dd {
	float: left;
	width: calc(100% - 60px);
	padding: 0 0 0 15px;
}

/* ▼TABLE▼ */
.table01 table tr {
	border-bottom: solid 2px #e9e9e9;
	padding: 7px 0;
}

.table01 table thead tr th {
	vertical-align: middle;
	font-size: 1.7rem;
	font-weight: 700;
	color: #000;
	line-height: 1.8;
	padding: 15px 25px 15px 30px;
}

.table01 table tbody tr th {
	width: 220px;
	vertical-align: middle;
	font-size: 1.7rem;
	font-weight: 700;
	color: #000;
	line-height: 1.8;
	padding: 30px 25px 30px 30px;
}

.table01 table tbody tr td {
	padding: 30px 25px 30px 30px;
	vertical-align: middle;
	text-align: left;
	line-height: 1.8;
}

.table01 table tbody tr td.col-2 {
	width: 240px;
}

.table01 table tbody tr td.col-num {
	position: relative;
	left: 30px;
}

.table01 table tbody tr td.col-num span {
	position: absolute;
	left: -8px;
}

/*
COMMON PARTS
***************************************************************************/
/* ▼display▼ */
.block { display:block!important; }
.inline { display:inline!important; }
.iblock { display:inline-block!important; }

.posit_r { position:relative!important; }
.posit_a { position:absolute!important; }
.posit_f { position:fixed!important; }

.align_c { text-align:center!important; }
.align_r { text-align:right!important; }
.align_l { text-align:left!important; }

.disp_l { float:left!important; }
.disp_r { float:right!important; }

.va_top { vertical-align:top!important; }
.va_mid { vertical-align:middle!important; }
.va_btm { vertical-align:bottom!important; }

/* ▼width▼ */
.w4per { width:4%; }
.w5per { width:5%; }
.w7per { width:7%; }
.w8per { width:8%; }
.w10per { width:10%; }
.w12per { width:12%; }
.w14per { width:14%; }
.w15per { width:15%; }
.w16per { width:16%; }
.w18per { width:18%; }
.w20per { width:20%; }
.w22per { width:22%; }
.w24per { width:24%; }
.w25per { width:25%; }
.w30per { width:30%; }
.w32per { width:32%; }
.w35per { width:35%; }
.w36per { width:36%; }
.w40per { width:40%; }
.w50per { width:50%; }
.w55per { width:55%; }
.w56per { width:56%; }
.w60per { width:60%; }
.w70per { width:70%; }
.w75per { width:75%; }
.w80per { width:80%; }
.w100per { width:100%!important; }

.w40 { width:40px!important; }
.w60 { width:60px!important; }
.w75 { width:75px!important; }
.w80 { width:80px!important; }
.w90 { width:90px!important; }
.w100 { width:100px!important; }
.w120 { width:120px!important; }
.w130 { width:130px!important; }
.w140 { width:140px!important; }
.w150 { width:150px!important; }
.w170 { width:170px!important; }
.w180 { width:180px!important; }
.w200 { width:200px!important; }
.w210 { width:210px!important; }
.w220 { width:220px!important; }
.w230 { width:230px!important; }
.w250 { width:250px!important; }
.w260 { width:260px!important; }
.w280 { width:280px!important; }
.w290 { width:290px!important; }
.w300 { width:300px!important; }
.w310 { width:310px!important; }
.w320 { width:320px!important; }
.w335 { width:335px!important; }
.w350 { width:350px!important; }
.w355 { width:355px!important; }
.w360 { width:360px!important; }
.w380 { width:380px!important; }
.w400 { width:400px!important; }
.w440 { width:440px!important; }
.w450 { width:450px!important; }
.w460 { width:460px!important; }
.w470 { width:470px!important; }
.w500 { width:500px!important; }
.w570 { width:570px!important; }
.w600 { width:600px!important; }
.w800 { width:800px!important; }
.w1000 { width:1000px!important; }

.h90 { height:90px!important; }
.h100 { height:100px!important; }
.h150 { height:150px!important; }
.h200 { height:200px!important; }
.h300 { height:300px!important; }
.h360 { height:360px!important; }

.area_h200 { height:200px; }

.zoom05 { zoom:0.5; }

/* ▼area▼ */
.mb150 { margin-bottom:150px!important; }
.mb140 { margin-bottom:140px!important; }
.mb120 { margin-bottom:120px!important; }
.mb110 { margin-bottom:110px!important; }
.mb100 { margin-bottom:100px!important; }
.mb95 { margin-bottom:95px!important; }
.mb90 { margin-bottom:90px!important; }
.mb85 { margin-bottom:85px!important; }
.mb80 { margin-bottom:80px!important; }
.mb75 { margin-bottom:75px!important; }
.mb70 { margin-bottom:70px!important; }
.mb65 { margin-bottom:65px!important; }
.mb60 { margin-bottom:60px!important; }
.mb55 { margin-bottom:55px!important; }
.mb50 { margin-bottom:50px!important; }
.mb45 { margin-bottom:45px!important; }
.mb40 { margin-bottom:40px!important; }
.mb35 { margin-bottom:35px!important; }
.mb30 { margin-bottom:30px!important; }
.mb25 { margin-bottom:25px!important; }
.mb20 { margin-bottom:20px!important; }
.mb15 { margin-bottom:15px!important; }
.mb12 { margin-bottom:12px!important; }
.mb10 { margin-bottom:10px!important; }
.mb8 { margin-bottom:8px!important; }
.mb5 { margin-bottom:5px!important; }
.mb0 { margin-bottom:0!important; }

.mlr150 { margin-left:150px!important; margin-right:150px!important; }
.mlr115 { margin-left:115px!important; margin-right:115px!important; }
.mlr100 { margin-left:100px!important; margin-right:100px!important; }
.mlr80 { margin-left:80px!important; margin-right:80px!important; }
.mlr75 { margin-left:75px!important; margin-right:75px!important; }
.mlr70 { margin-left:70px!important; margin-right:70px!important; }
.mlr60 { margin-left:60px!important; margin-right:60px!important; }
.mlr55 { margin-left:55px!important; margin-right:55px!important; }
.mlr50 { margin-left:50px!important; margin-right:50px!important; }
.mlr45 { margin-left:40px!important; margin-right:45px!important; }
.mlr40 { margin-left:40px!important; margin-right:40px!important; }
.mlr35 { margin-left:35px!important; margin-right:35px!important; }
.mlr30 { margin-left:30px!important; margin-right:30px!important; }
.mlr25 { margin-left:25px!important; margin-right:25px!important; }
.mlr20 { margin-left:20px!important; margin-right:20px!important; }
.mlr15 { margin-left:15px!important; margin-right:15px!important; }
.mlr10 { margin-left:10px!important; margin-right:10px!important; }
.mlr5 { margin-left:5px!important; margin-right:5px!important; }
.mlr-1 { margin-left:-1px!important; margin-right:-1px!important; }
.mlr-5 { margin-left:-5px!important; margin-right:-5px!important; }
.mlr-10 { margin-left:-10px!important; margin-right:-10px!important; }
.mlr-20 { margin-left:-20px!important; margin-right:-20px!important; }
.mlr_auto { margin-left:auto!important; margin-right:auto!important; }

.mr60 { margin-right:60px!important; }
.mr50 { margin-right:50px!important; }
.mr40 { margin-right:40px!important; }
.mr30 { margin-right:30px!important; }
.mr25 { margin-right:25px!important; }
.mr20 { margin-right:20px!important; }
.mr15 { margin-right:15px!important; }
.mr10 { margin-right:10px!important; }
.mr5 { margin-right:5px!important; }
.mr0 { margin-right:0px!important; }
.mr-5 { margin-right:-5px!important; }

.ml260 { margin-left:260px!important; }
.ml180 { margin-left:180px!important; }
.ml80 { margin-left:80px!important; }
.ml50 { margin-left:50px!important; }
.ml40 { margin-left:40px!important; }
.ml32 { margin-left:32px!important; }
.ml30 { margin-left:30px!important; }
.ml20 { margin-left:20px!important; }
.ml15 { margin-left:15px!important; }
.ml10 { margin-left:10px!important; }
.ml0 { margin-left:0px!important; }
.ml-5 { margin-left:-5px!important; }
.ml-10 { margin-left:-10px!important; }
.ml-15 { margin-left:-15px!important; }
.ml-20 { margin-left:-20px!important; }

.ml_em5 { margin-left:5em!important; }

.mt140 { margin-top:140px!important; }
.mt130 { margin-top:130px!important; }
.mt120 { margin-top:120px!important; }
.mt90 { margin-top:90px!important; }
.mt80 { margin-top:80px!important; }
.mt70 { margin-top:70px!important; }
.mt60 { margin-top:60px!important; }
.mt55 { margin-top:55px!important; }
.mt50 { margin-top:50px!important; }
.mt45 { margin-top:45px!important; }
.mt40 { margin-top:40px!important; }
.mt30 { margin-top:30px!important; }
.mt20 { margin-top:20px!important; }
.mt15 { margin-top:15px!important; }
.mt10 { margin-top:10px!important; }
.mt5 { margin-top:5px!important; }
.mt3 { margin-top:3px!important; }
.mt0 { margin-top:0!important; }
.mt-5 { margin-top:-5px!important; }
.mt-10 { margin-top:-10px!important; }
.mt-20 { margin-top:-20px!important; }
.mt-30 { margin-top:-30px!important; }
.mt-40 { margin-top:-40px!important; }
.mt-50 { margin-top:-50px!important; }
.mt-80 { margin-top:-80px!important; }
.mt-125 { margin-top:-125px!important; }

.pb100 { padding-bottom:100px!important; }
.pb80 { padding-bottom:80px!important; }
.pb50 { padding-bottom:50px!important; }
.pb30 { padding-bottom:30px!important; }
.pb20 { padding-bottom:20px!important; }
.pb15 { padding-bottom:15px!important; }
.pb10 { padding-bottom:10px!important; }
.pb5 { padding-bottom:5px!important; }
.pb0 { padding-bottom:0!important; }

.p20 { padding:20px!important; }
.p15 { padding:15px!important; }
.p10 { padding:10px!important; }

.pt60 { padding-top:60px!important; }
.pt50 { padding-top:50px!important; }
.pt20 { padding-top:20px!important; }
.pt18 { padding-top:18px!important; }
.pt15 { padding-top:15px!important; }
.pt12 { padding-top:12px!important; }

.ptb30 { padding-top:30px!important; padding-bottom:30px!important; }
.ptb20 { padding-top:20px!important; padding-bottom:20px!important; }
.ptb15 { padding-top:15px!important; padding-bottom:15px!important; }
.ptb5 { padding-top:5px!important; padding-bottom:5px!important; }
.ptb0 { padding-top:0!important; padding-bottom:0!important; }

.pl23 { padding-left:23px!important; }
.pl10 { padding-left:10px!important; }

.pr10 { padding-right:10px!important; }

.plr40 { padding-left:40px!important; padding-right:40px!important; }
.plr25 { padding-left:25px!important; padding-right:25px!important; }

/* ▼font▼ */
.weight_300 { font-weight:300!important; }
.weight_400 { font-weight:400!important; }
.weight_500 { font-weight:500!important; }
.weight_700 { font-weight:700!important; }

.size10 { font-size:1rem!important; }
.size11 { font-size:1.1rem!important; }
.size12 { font-size:1.2rem!important; }
.size13 { font-size:1.3rem!important; }
.size14 { font-size:1.4rem!important; }
.size16 { font-size:1.6rem!important; }
.size17 { font-size:1.7rem!important; }
.size18 { font-size:1.8rem!important; }
.size19 { font-size:1.9rem!important; }
.size20 { font-size:2.0rem!important; }
.size22 { font-size:2.2rem!important; }
.size24 { font-size:2.4rem!important; }
.size26 { font-size:2.6rem!important; }
.size28 { font-size:2.8rem!important; }
.size30 { font-size:3.0rem!important; }
.size32 { font-size:3.2rem!important; }
.size34 { font-size:3.4rem!important; }
.size36 { font-size:3.6rem!important; }
.size54 { font-size:5.4rem!important; }
.size64 { font-size:6.4rem!important; }

.lh25 { line-height:2.5!important; }
.lh22 { line-height:2.2!important; }
.lh2 { line-height:2!important; }
.lh18 { line-height:1.8!important; }
.lh16 { line-height:1.6!important; }
.lh15 { line-height:1.5!important; }
.lh12 { line-height:1.2!important; }

.c_pink { color:#ee426f!important; }
.c_green { color:#8fd127!important; }
.c_gray { color:#b5b5b5!important; }
.c_dgray { color:#7c7c7c!important; }
.c_black { color:#141414!important; }
.c_white { color:#ffffff!important; }

/* ▼link▼ */
.u_line { padding-bottom:4px; border-bottom:solid 1px #70b108; }
.u_line.white { color:#fff; border-bottom:solid 1px #fff; }
.u_line.green { padding-bottom:2px; color:#8fd127; border-bottom:solid 1px #8fd127; }
.u_line.black { color:#404040; border-bottom:solid 1px #404040; }

/* ▼frame▼ */
.img_frame01 { border:solid 1px #fff; }

/* ▼line▼ */

/* ▼indent▼ */
.indent1 { margin-left:1em; text-indent:-1em; }
.indent2 { margin-left:2em; text-indent:-2em; }
.indent3 { margin-left:3em; text-indent:-3em; }
.indent4 { margin-left:4em; text-indent:-4em; }
.indent5 { margin-left:5em; text-indent:-5em; }
.indent6 { margin-left:6em; text-indent:-6em; }


/* ▼background▼ */
.bg_none { background:none!important; }

/* ▼border▼ */
.border_none { border:none!important; }

/* ▼form▼ */
input[type="text"], input[type="date"], input[type="tel"], input[type="email"], input[type="file"], input[type="password"], select {
	-webkit-appearance: none;
	-moz-appearance: none;
	-ms-appearance: none;
	box-sizing: border-box;
	position: relative;
	width: 100%;
	height: 60px;
	padding: 0 15px;
	vertical-align: middle;
	font-size: 1.4rem;
	font-weight: 500;
	color: #404040;
	line-height: 60px;
	background: #fff;
	border: solid 1px #d6d6d6;
	font-family: "Noto Sans JP", sans-serif;
}

textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	-ms-appearance: none;
	box-sizing: border-box;
	position: relative;
	width: 100%!important;
	padding: 15px;
	font-size: 1.4rem;
	font-weight: 500;
	color: #404040;
	background: #fff;
	border: solid 1px #ccc;
	font-family: "Noto Sans JP", sans-serif;
	border-radius: 4px;
}

input[type="text"]:focus, input[type="date"]:focus, input[type="tel"]:focus, input[type="email"]:focus, input[type="file"]:focus, input[type="password"]:focus, input[type="date"]:focus, select:focus, textarea:focus {
	border: solid 1px #ccc;
	outline: none;
}

input::-webkit-input-placeholder {
	font-size: 1.4rem!important;
	color: #b2b2b2;
	font-weight: 500;
	letter-spacing: 1.6px;
}

input:-ms-input-placeholder {
	font-size: 1.4rem!important;
	color: #b2b2b2;
	font-weight: 500;
	letter-spacing: 1.6px;
}

input::-moz-placeholder {
	font-size: 1.4rem!important;
	color: #b2b2b2;
	font-weight: 500;
	letter-spacing: 1.6px;
}

textarea::-webkit-input-placeholder {
	font-size: 1.4rem!important;
	color: #b2b2b2;
	font-weight: 500;
	letter-spacing: 1.6px;
}

textarea:-ms-input-placeholder {
	font-size: 1.4rem!important;
	color: #b2b2b2;
	font-weight: 500;
	letter-spacing: 1.6px;
}

textarea::-moz-placeholder {
	font-size: 1.4rem!important;
	color: #b2b2b2;
	font-weight: 500;
	letter-spacing: 1.6px;
}

select {
	line-height: 58px;
	background: #fff url(../common_img/arrow_select.png) right 12px center no-repeat;
}

.pwd_look {
	display: block;
	position: absolute;
	top: 50%;
	right: 30px;
	width: 20px;
	height: 20px;
	margin-top: -11px;
	text-align: center;
	line-height: 20px;
	cursor: pointer;
}

input[type="radio"], input[type="checkbox"] {
	position: absolute;
	top: 0;
	left: 0;
	width: 30px;
	height: 30px;
	opacity: 0;
	filter: alpha(opacity=0);
	cursor: pointer;
}

.radio_list li, .chk_list li {
	position: relative;
	margin-bottom: 20px;
	padding-left: 40px;
	line-height: 30px;
	background-position: left center;
	background-repeat: no-repeat;
}

.radio_list li { background-image:url(../common_img/radio_box_off.png); }
.radio_list li.active { background-image:url(../images_bf/radio_box_on.png); }

.chk_list li { background-image:url(../images_bf/chk_box_off.png); }
.chk_list li.active { background-image:url(../images_bf/chk_box_on.png); }

.radio_list.col, .chk_list.col { display:inline-block; vertical-align:middle; }

.radio_list.col li, .chk_list.col li {
	display: inline-block;
	margin: 10px 115px 10px 0;
}

.radio_list.col li:last-child, .chk_list.col li:last-child { margin-right:0; }

.radio_list.col.line_1 li, .chk_list.col.line_1 li { margin:0 35px 0 0; }

.chk_list.chk li { display:inline-block; }

.radio_icon, .chk_icon {
	display: inline-block;
	position: relative;
	padding-left: 64px;
	line-height: 36px;
}

.radio_icon { background:url(../common_img/radio_box_off.png) left center no-repeat; }
.chk_icon { background:url(../images_bf/chk_box_off.png) left center no-repeat; }

.radio_icon.active { background:url(../images_bf/radio_box_on.png) left center no-repeat; }
.chk_icon.active { background:url(../images_bf/chk_box_on.png) left center no-repeat; }

.radiobtn_list li, .chkbtn_list li {
	position: relative;
	float: left;
	height: 60px;
	margin: 0 10px 10px 0;
	text-align: center;
	line-height: 58px;
	background: #fff;
	border: solid 1px #ccc;
	border-radius: 4px;
}

.radiobtn_list, .chkbtn_list { margin-bottom:-10px; }

.radiobtn_list.col_2 li, .chkbtn_list.col_2 li { width:350px; }
.radiobtn_list.col_2 li:nth-child(2n), .chkbtn_list.col_2 li:nth-child(2n) { margin-right:0; }

.radiobtn_list.col_3 li, .chkbtn_list.col_3 li { width:calc((100% - 20px) / 3); }
.radiobtn_list.col_3 li:nth-child(3n), .chkbtn_list.col_3 li:nth-child(3n) { margin-right:0; }

.radiobtn_list.app, .chkbtn_list.app { width:570px; }
.radiobtn_list.app li, .chkbtn_list.app li { width:275px; margin:10px 0; }
.radiobtn_list.app li:nth-child(2n), .chkbtn_list.app li:nth-child(2n) { float:right; }

.radiobtn_list li label, .chkbtn_list li label { display:block; width:100%; cursor:pointer; }

.radiobtn_list li.active, .chkbtn_list li.active {
	color: #fff;
	background: #8fd127;
	border: solid 1px #8fd127;
}

.input_file {
	box-sizing: border-box;
	position: relative;
	width: 100%;
	height: 60px;
	line-height: 60px;
}

.input_file.ex {
	height: 50px;
	line-height: 50px;
}

.input_file .input_txt {
	float: left;
	width: 505px;
	height: 60px;
	padding: 0 15px;
	color: #b5b5b5;
	line-height: 58px;
	border: solid 1px #ccc;
	border-radius: 4px;
}

.input_file.ex .input_txt {
	width: 350px;
	height: 50px;
	line-height: 48px;
}

.input_file .input_btn {
	float: right;
	width: 240px;
	margin-top: -2px;
}

.input_file.ex .input_btn {
	width: 170px;
}

.input_file input[type="file"] {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 60px;
	cursor: pointer;
	opacity: 0;
	z-index: 1;
}

.input_file.ex input[type="file"] {
	height: 50px;
}

.input_file:hover .btn01:before { opacity:0; }
