@charset "UTF-8";

/*
* app用 login.css
*
*/


/*
* レイアウト
*/
#toppage {
	padding: 90px 0 0 0;
}


/*
* メインビジュアル
*/
#mv {
	margin: 0 auto;
	padding: 0;
	background-image: url('/main/img/top/mvBack01.jpg');
	background-size: cover;
}
/* テキスト */
#mv .text {
	position: absolute;
	top: 3vw;
	left: 2vw;
}
#mv .text img {
	object-fit: contain;
	width: 75vw;
}
/* スライド */
#mv .slide {
	width: 100%;
}
#mv .slide li img {
	width: 100%;
}
/* プレオープン */
#mv .preopen {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #FFEE00;
	margin: 5vw 0;
	padding: 0;
	text-shadow: 0 0 5px rgba(0,0,0,0.2);
}
#mv .preopen small {
	display: block;
	margin: 0 0 20px 0;
	padding: 0;
	font-size: 10vw;
	letter-spacing: 0.1em;
	line-height: 1;
}
#mv .preopen strong {
	display: block;
	margin: 0;
	padding: 0;
	font-size: 10vw;
	letter-spacing: 0.1em;
	line-height: 1;
}
/* ボタン */
#mv .button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	margin: 0;
	padding: 4vw 0;
}
#mv .button a {
	display: block;
	margin: 2vw 0;
	padding: 0;
}
#mv .button img {
	display: block;
	object-fit: contain;
	width: 90vw;
	margin: 0;
	padding: 0;
}


/*
* リユースジョブとは？
*/
#about {
	margin: 0 auto;
	padding: 80px 0 0 0;
}
#about h2 {
	margin: 0 0 40px 0;
	text-align: center;
	font-size: 30px;
	font-weight: 600;
	letter-spacing: 0.1em;
}
#about h3 {
	margin: 0 0 40px 0;
	text-align: center;
	font-size: 25px;
	font-weight: 600;
	line-height: 1.8;
	letter-spacing: 0.1em;
}
#about h3 strong {
	display: inline-block;
	line-height: 1.2;
	border-bottom: #38D430 1px dotted;
}
#about p {
	margin: 0 0 40px 0;
	padding: 0 40px;
	font-size: 18px;
}
/* 項目 */
#about section {
	margin: 0 0 -1px 0;
	padding: 40px;
	border-top: #B1B1B1 1px dotted;
	border-bottom: #B1B1B1 1px dotted;
}
#about h4 {
	margin: 0 0 20px 0;
	text-align: center;
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0.1em;
}
#about section p {
	margin: 0;
	padding: 0;
	font-size: 18px;
}


/*
* リユースジョブに登録すると
*/
#expRegist {
	margin: 0 auto;
	padding: 80px 0;
}
#expRegist p {
	margin: 0 0 40px 0;
	padding: 0 40px;
	text-align: center;
	color: #FFFFFF;
	font-size: 25px;
	font-weight: 600;
}
/* ボタン */
#expRegist .button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	margin: 0;
	padding: 0 20px;
}
#expRegist .button img {
	width: 100%;
	margin: 0;
	padding: 0;
}


/*
* リユースジョブ業のお仕事って？
*/
#expReuseJob {
	margin: 0 auto;
	padding: 80px 0;
}
#expReuseJob h2 {
	margin: 0 0 40px 0;
	text-align: center;
	font-size: 30px;
	font-weight: 600;
	letter-spacing: 0.1em;
}
#expReuseJob p {
	margin: 0;
	padding: 0 40px;
	font-size: 18px;
}


/*
* おすすめ求人
*/
#topRecom {
	position: relative;
	width: 100%;
	margin: 0 auto 40px auto;
	padding: 0 0 20px 0;
	background-color: #F1F1F1;
}
#topRecom h3.title {
	margin: 0 0 20px 0;
	padding: 10px 0;
	text-align: center;
	color: #FFFFFF;
	font-size: 18px;
	font-weight: 600;
}
#topRecom p.demo {
	margin: -10px 0 0 0;
	padding: 0 10px;
	text-align: center;
	color: #CC0000;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.2;
	background-color: rgba(255,255,255,0.5);
}
#topRecom .recruitList {
	margin: 0;
	padding: 0;
}
#topRecom .recruitList ul {
	padding: 0;
}
#topRecom .recruitList .cell {
	border: 0;
}
#topRecom .recruitList .pict {
	width: 30vw;
	height: 30vw;
	max-width: 150px;
	max-height: 150px;
}
/* slick */
#topRecom .slick-list {
	z-index: 1;
}
#topRecom .slick-prev {
	position: absolute;
	left: 10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 20px 25px 0;
	border-color: transparent #38D430 transparent transparent;
	z-index: 2;
}
#topRecom .slick-prev::before {
	display: none;
}
#topRecom .slick-next {
	position: absolute;
	right: 10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 0 25px 20px;
	border-color: transparent transparent transparent #38D430;
	z-index: 2;
}
#topRecom .slick-next::before {
	display: none;
}


/*
* 求人検索
*/
#topSearch {
	width: 100%;
	margin: 0 auto;
	padding: 0 0 40px 0;
}
/* ワード検索 */
#topSearch .directWord {
	margin: 0 0 20px 0;
	padding: 20px;
}
#topSearch .directWord form {
	display: flex;
	align-items: stretch;
	margin: 0;
	padding: 0;
}
#topSearch .directWord input {
	flex: 1;
	margin: 0;
	padding: 8px;
	font-size: 16px;
	line-height: 1.6;
	background-color: #FFFFFF;
	border: none;
	border: #B1B1B1 2px solid;
	border-right: 0;
	border-radius: 6px 0 0 6px;
}
#topSearch .directWord button {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0 20px;
	border: 0;
	background-color: #0E9B94;
	border-radius: 0 6px 6px 0;
}
/* 検索ボタン */
#topSearch ul.button {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	margin: 0;
	padding: 0 10px;
}
#topSearch ul.button li {
	width: 33.33%;
	margin: 0;
	padding: 0 10px;
}
#topSearch ul.button li img {
	width: 100%;
}
@media screen and (min-width:960px) {
	#topSearch ul.button li {
		padding: 0 40px;
	}
}


/* ワード検索 */
#topSearch .searchWord {
	margin: 0;
	padding: 20px;
	text-align: center;
}
#topSearch .searchWord input {
	padding-left: 20px;
	padding-right: 20px;
	border: 0;
	border-radius: 9999px;
}
/* 検索項目 */
#topSearch .list {
	margin: 0;
	padding: 5px 0 0 0;
}
#topSearch .list li {
	display: flex;
	align-items: center;
	justify-content: space-around;
	margin: 0;
	padding: 5px 20px;
}
#topSearch .list h5 {
	width: 80px;
	margin: 0;
	padding: 0;
	font-size: 16px;
	font-weight: 600;
}
#topSearch .form {
	flex: 1;
}
/* フォーム要素 */
#topSearch input,
#topSearch select {
	width: 100%;
	margin: 0;
}
/* 市区町村 */
#topSearch .cityWrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	max-height: 10rem;
	margin: 10px 0 0 0;
	padding: 10px;
	background-color: #FFFFFF;
	border: #B1B1B1 1px solid;
	border-radius: 5px;
	overflow-y: scroll;
}
#topSearch .cityWrap.hide {
	display: none;
}
#topSearch .cityWrap input {
  position: absolute;
  left: -9999px;
}
#topSearch .cityWrap label {
  position: relative;
	display: inline-block;
	min-width: 6em;
  margin: 0;
  padding: 0 0 0 20px;
	font-size: 14px;
	font-weight: 300;
  cursor: pointer;
  user-select: none;
  transition: background-color .1s, box-shadow .1s;
}
#topSearch .cityWrap label::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
	-webkit-transform: translateY(-50%);
  width: 14px;
	height: 14px;
  background-color: #FFFFFF;
	border: #B1B1B1 1px solid;
  border-radius: 5px;
  transition: background-color .1s;
}
#topSearch .cityWrap label::after {
	content: '';
  display: block;
	position: absolute;
  top: calc(50% - 2px);
	left: 5px;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  height: 12px;
  border-right: 3px solid #000000;
  border-bottom: 3px solid #000000;
  opacity: 0;
}
#topSearch .cityWrap input:checked + label::after {
  opacity: 1;
}
/* ボタン */
#topSearch .baseButton {
	margin: 0;
	padding: 0 10px 10px 10px;
}
/* 現在地ボタン */
#topSearch .buttonCurrent {
	margin: 0 0 10px 0;
	padding: 0 10px;
}
#topSearch .buttonCurrent a {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 10px;
	padding: 10px 0;
	color: #FFFFFF;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.1em;
	background-color: #0E9B94;
	border: #0E9B94 3px solid;
	border-radius: 10px;
}
#topSearch .buttonCurrent i {
	display: inline-block;
	margin: 0 5px 0 0;
	font-size: 24px
}



/*
* 求人検索
*/
/*
#searchJob {
	margin: 0;
	padding: 80px 0;
}
#searchJob h2 {
	margin: 0 0 40px 0;
	text-align: center;
	font-size: 30px;
	font-weight: 600;
	letter-spacing: 0.1em;
}
#searchJob .contentWrap {
	margin: 0;
	padding: 0;
}
#searchJob dl {
	margin: 0 0 40px 0;
	padding: 0;
}
#searchJob dt {
	margin: 0 0 20px 0;
	padding: 0 10px 15px 10px;
	font-size: 25px;
	font-weight: 600;
	line-height: 1;
	border-bottom: #707070 1px solid;
}
#searchJob dd {
	margin: 0;
	padding: 0 20px;
}
#searchJob dd h6 {
	width: 100%;
	margin: 0 0 10px 0;
	font-size: 18px;
	font-weight: 600;
}
/* 市区町村 */
/*
#searchJob .cityWrap {
	margin: 20px 0 0 0;
}
#searchJob .cityWrap ul {
	max-height: 300px;
	margin: 0;
	padding: 25px 15px 10px 15px;
	border: #B1B1B1 2px solid;
	border-radius: 5px;
	overflow-y: scroll;
}
/* フォーム部品 */
/*
#searchJob select.formPref {
	width: 100%;
}


/*
* 無料会員登録モーダル
*/
#mdlUserReg {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	display: none;
	width: 90vw;
	max-width: 960px;
	max-height: calc(100vh - 180px);
	margin: 0;
	padding: 0;
	background-color: #FFFFFF;
	border-radius: 20px;
	box-shadow: 0 0 5px 1px rgba(0,0,0,0.2);
	overflow-y: hidden;
	z-index: 99000;
}
#mdlUserReg .content {
	width: 100%;
	max-height: calc(100vh - 180px);
	margin: 0;
	padding: 0 0 100px 0;
	overflow-y: scroll;
}
/* 閉じるボタン */
#mdlUserReg .mdlUserClose {
	position: absolute;
	top: 10px;
	right: 20px;
	color: #666666;
	font-size: 18px;
}
/* ロゴ */
#mdlUserReg .logo {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 30px 0 30px 0;
	padding: 0;
}
#mdlUserReg .logo img {
	width: 20vw;
	max-width: 200px;
	margin: 0;
	padding: 0;
}
/* ページャー */
#mdlUserReg .mdlPager {
	position: fixed;
	bottom: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	margin: 0;
	padding: 20px 10px;
	background-color: #F1F1F1;
}
#mdlUserReg .mdlPager i {
	margin: 0 5px;
}
#mdlUserReg .mdlPager span {
	opacity: 0.5;
}
#mdlUserReg .mdlPager span.active {
	opacity: 1;
}
#mdlUserReg .mdlPager span.hide {
	opacity: 0;
}
/* 設問スライダー */
#mdlUserReg #slideReg {
	margin: 0;
	padding: 0;
}
#mdlUserReg article {
	display: flex;
	flex-direction: column;
	margin: 0;
	padding: 0 20px;
}
#mdlUserReg h2 {
	margin: 0 0 30px 0;
	padding: 0;
	text-align: center;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.8;
}
#mdlUserReg .answer {
	width: 100%;
	margin: 0;
	padding: 0;
}
#mdlUserReg .answer ul.normal {
	margin: 0 0 20px 0;
	padding: 0 40px;
}
#mdlUserReg p.text {
	margin: 0 0 20px 0;
	padding: 0;
	text-align: center;
	font-size: 14px;
	font-weight: 600;
}
/* お名前 */
#mdlUserReg .name input {
	width: 100%;
}
/* 生年月日 */
#mdlUserReg .birth li {
	align-items: flex-end;
}
#mdlUserReg .birth input[name='userTemp[birth1]'] {
	width: 6em;
}
#mdlUserReg .birth input[name='userTemp[birth2]'] {
	width: 4em;
}
#mdlUserReg .birth input[name='userTemp[birth3]'] {
	width: 4em;
}
#mdlUserReg .birth li span {
	display: inline-block;
	margin: 0 5px;
	vertical-align: bottom;
}
/* お住まい */
#mdlUserReg .pref li div {
	width: 100%;
}
#mdlUserReg .pref select {
	width: 100%;
}
/* 連絡先 */
#mdlUserReg .phone li div {
	width: 100%;
}
#mdlUserReg .phone input {
	width: 100%;
}
/* メールアドレス */
#mdlUserReg .email li div {
	width: 100%;
}
#mdlUserReg .email input {
	width: 100%;
}
/* スキル */
#mdlUserReg .skill li div {
	width: 100%;
}
/* 登録ボタン 非表示 */
#mdlUserReg .userSubmit {
	opacity: 0.5;
	pointer-events: none;
}









/*
*
* PC用
*
*/









@media screen and (min-width:960px){


	/*
	* レイアウト
	*/
	#toppage {

	}


	/*
	* メインビジュアル
	*/
	#mv {
		position: static;
		width: 100%;
		height: auto;
		overflow: visible;
		background-image: url();
	}
	/* スライド */
	#mv .slide {
		width: 100%;
	}
	#mv .slide li img {
		width: 100%;
	}
	/* 写真 */
	#mv .pict {
		position: static;
		width: 100%;
		height: 500px;
	}
	#mv .pict img {
		object-fit: cover;
		width: 100%;
		height: 100%;
	}
	/* プレオープン */
	#mv .preopen {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		margin: 40px 0 0 0;
		padding: 0;
		color: #38D430;
		text-shadow: none;
	}
	#mv .preopen small {
		display: block;
		margin: 0 0 20px 0;
		padding: 0;
		font-size: 80px;
		letter-spacing: 0.1em;
		line-height: 1;
	}
	#mv .preopen strong {
		display: block;
		margin: 0;
		padding: 0;
		font-size: 80px;
		letter-spacing: 0.1em;
		line-height: 1;
	}
	/* ボタン */
	#mv .button {
		position: static;
		display: flex;
		flex-direction: row;
		align-items: center;
		justify-content: center;
		width: 100%;
		margin: 0;
		padding: 40px 0;
	}
	#mv .button a {
		margin: 1vw 10px;
	}
	#mv .button img {
		object-fit: contain;
		width: auto;
	}


}
