@charset "utf-8";
/* CSS front Document */

/*****↓ ファーストビューをヘッダーにかける時に利用、利用しない場合は削除かコメントアウト*****/
.header-area {
  opacity: 0;
  animation: slideFadeIn .5s ease-out forwards;
}

@keyframes slideFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.path-frontpage #front_top{

	z-index: 98;
  position: relative;
}
.path-frontpage .hero-area {
  position: relative;
  overflow: hidden;
  height: 604px; /* 固定してるならOK */
  max-height: 100vh;
  margin-top:-105px;
}
.path-frontpage .hero-area .bg-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
  transform: translate(-50%, -50%) scaleX(-1);
  object-fit: cover;
  z-index: 0;
  pointer-events: none; /* クリックを透過させる */
}
#block-builjob-front-views-block-top-slide-block-1 {
  opacity: 0;
  animation: fadeIn 1s ease forwards;
  animation-delay: 0s; /* 4秒後に実行 */
}
#block-builjob-front-front-hero-login-block {
  opacity: 0;
  animation: fadeIn 1s ease forwards;
  animation-delay: 0.4s; /* 4秒後に実行 */
  
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

#block-builjob-front-front-job-search{
  opacity: 0;
  transform: translateY(20px); /* 初期は下に20px */
  animation: slideUpFadeIn 0.7s ease-out forwards;
  animation-delay: 0.4s; /* 2秒後に開始 */
  margin-top:20px;
}

@keyframes slideUpFadeIn {
  0% {
    opacity: 0;
    transform: translateY(20px); /* 下に20pxの位置 */
  }
  100% {
    opacity: 1;
    transform: translateY(0); /* 元の位置に戻る */
  }
}

.path-frontpage .first-view{
	width: 100%;
  max-width: 780px;
  position: relative;
  padding-top:130px;
  padding-left: 40px;
  padding-bottom:160px;
}
/*.path-frontpage .first-view:before{
  position: absolute;
  top:-5px;
  left:-5px;
  max-width: 111px;
  max-height: 110px;
  width:100%;
  z-index: 2;
  content: "";
  display: block;
  height: 100%;
  background-image: url(../img/ribbon.webp);
  background-size: contain;
  background-repeat: no-repeat;
}
*/
.path-frontpage .first-view .firstttl{
  font-size: 32px;
  font-weight: 600;
  color: #fff;
  margin: 10px 0px 20px 0px;
}
.path-frontpage .first-view .firsttext{
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  line-height: 180%;
  padding-right:200px;
}
.path-frontpage .firstcnt {
  font-size: 12px;
  color: #212F3C;
  margin-top:15px;
  display: flex;
  gap:10px;
  padding-left:15px;
  padding-right: 15px;
  margin-bottom:10px;
}
.path-frontpage .firstcnt .cnt-left{
  margin-top:-5px;
  margin-left:75px;
}
/* 吹き出し本体 - 普通の吹き出し */
.path-frontpage .firstcnt .cnt-left{
  position: relative;
  padding: 10px;
  background-color: #E9F1EF;
  border-radius: 10px;         /* 角丸を指定 */
}
/* 三角アイコン - 普通の吹き出し */
.path-frontpage .firstcnt .cnt-left::before{
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  left: -7.5px;
  top: 15px;
  border-right: 7.5px solid #E9F1EF;
  border-top: 7.5px solid transparent;
  border-bottom: 7.5px solid transparent;
}
.path-frontpage .firstcnt .cnt-right{
  margin-left:auto;
  padding-top: 20px;
}
.path-frontpage .firstcnt .cnt-right a.search-details{
  background: url(../img/icon/arrow-right-blue.svg) no-repeat right top 1px;
    padding-right: 21px;
    color: #006FDF;
    font-weight: 600;
    background-size: contain;
}
.path-frontpage .firstcnt span{
  font-size: 19px;
  font-weight: 600;
  color: red;
  padding-right: 5px;
  font-style: italic;
}


.path-frontpage .first-view form{
	max-width: 340px;
	margin-left:auto;
	margin-right:0px;
	background:var(--white-color);
	padding:15px 20px;
	box-shadow: 0 6px 12px -2px rgb(50 50 93/25%), 0 3px 7px -3px rgb(0 0 0/30%);
}
.login-form-text{
  line-height:180%;
  margin-bottom: 25px;
  font-size: 1.3rem;
}


/******↑ ファーストビューをヘッダーにかける時に利用、利用しない場合は削除かコメントアウト*****/

.path-frontpage .first-view form .form-actions input[type="submit"]{
	width: 100%;
}
.path-frontpage .first-view .slogan1,
.path-frontpage .first-view h1.front_sitetitle,
.path-frontpage .first-view .slogan2{
	color:var(--white-color);
}
.path-frontpage .first-view .slogan1{
	font-size:1.8em;
	font-weight: 600;
}
.path-frontpage .first-view h1.front_sitetitle{
	font-size:3.2em;
	font-weight: 600;
}
.path-frontpage .first-view .slogan2{
	font-size:1.6em;
	font-weight: 600;
}
@media screen and (max-width: 767.9px) {
  #front_top .container{
    max-width: 100%;
  } 

	.path-frontpage .first-view h1.front_sitetitle{
		font-size:2.1rem;
	}

	.path-frontpage .first-view .slogan1{
		font-size:1.6rem;
	}
	.path-frontpage .first-view .slogan2{
		font-size:1.2rem;
	}
	.path-frontpage .first-view form{
		display: flex;
    flex-wrap: wrap;
		max-width: 100%;
    gap:10px;
	}
	.path-frontpage #block-vwork-front-qiurenjiansuouishietsuto #front_top{
		text-align: center;
		position: static;
	}
	.path-frontpage .first-view form {
		margin-left: -15px;
    	margin-right: -15px;
	}
	.path-frontpage .first-view form .form-item-area-id,
	.path-frontpage .first-view form #sbox-edit-occupation-id--wrapper.form-wrapper,
  .path-frontpage .first-view form .form-item.js-form-type-select.form-type-select,
	.path-frontpage .first-view form .form-item-keys{
		flex:1;
	}
	.path-frontpage .first-view form #edit-actions{
		width:100%;
		margin-bottom:0px;
	}
	.path-frontpage #block-vwork-front-qiurenjiansuouishietsuto #front_top .col-md-8{
		position: relative;
		z-index:2
	}
	.path-frontpage #block-vwork-front-qiurenjiansuouishietsuto form .form-item label:not(.option), 
	.path-frontpage #block-vwork-front-qiurenjiansuouishietsuto form .form-item legend .fieldset-legend{
		font-size:1.1rem;
	}
	.path-frontpage #block-vwork-front-qiurenjiansuouishietsuto #front_top .col-md-4{
		position: absolute;
		bottom:0px;
		
	}
	.path-frontpage  #block-vwork-front-qiurenjiansuouishietsuto{
    margin-top:-61px;
    background: url(../img/top/bg_top_sp.webp) no-repeat;
		background-size: 100%;
    min-height: 450px;
    
	}
	.path-frontpage #front_top{
		padding-top:150px;
	}
	.path-frontpage #block-vwork-front-qiurenjiansuouishietsuto #front_top .col-md-4 .form-item{
		margin-top:0px;
		margin-bottom:0px;
	}
  .block-vwork-job-search-widget-block form{
    flex-wrap: wrap;
  }
  .block-vwork-job-search-widget-block form div.form-item.form-item-area-id,
  .block-vwork-job-search-widget-block form div.form-item.form-item-occupation-id{
    max-width:100%;
    flex:auto;
  }
  .block-vwork-job-search-widget-block form div.form-item.form-item-keys,
  .block-vwork-job-search-widget-block form div.form-actions.form-wrapper{
    max-width:100%;
    width: 100%;
    min-width: 100%;
  }
  .block-vwork-job-search-widget-block form div.form-actions.form-wrapper{
    margin-top:0px;
  }
}
/**トップページ　メイン画像なしの検索フォーム**/
.job_search_no_visiual {
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  margin-top: -30px;
  z-index: 9;
  position: relative;
  background: #fff;
  border-radius: 10px;
}
.job_search_no_visiual form{
  display: flex;
  gap: 20px;
  justify-content: center;
}
.job_search_no_visiual .job-search-form-title{
  font-weight: 600;
  color: #000;
  padding: 30px;
  font-size: 18px;
}
.job_search_no_visiual form .form-type-select,
.job_search_no_visiual form .form-type-textfield{
  max-width: 200px;
  flex:1;
}
.job_search_no_visiual form #edit-submit-joblist{
  margin-top: 19px;
  height: 32px;
  line-height: 32px;
  width: 200px;
}

/**トップページ featureバナー**/
.view-feature .slick__slide{
    padding-left:0;
    padding-right:0;
}
.view-feature .feature-top-link{
	position: relative;
    width:100%;
    display:block;
}
.view-feature .feature-top-link .feature-top-title{
	text-align: center;
	font-weight: 600;
	margin-top:8px;
}
.feature-top-img img{
	width:100%;
	height: auto;
	object-fit: contain;
}


.view-feature .feature-top-textarea{
	position: absolute;
	top: 140px;
    left: 50%;
    transform: translate(-50%, 0%);
    -webkit-transform: translate(-50%, 0%);
    -ms-transform: translate(-50%, 0%);
	z-index: 2;
	text-align: center;
	width:90%;
}
.view-feature div.feature-top-label{
    color :var(--blue-color);
    margin-bottom: 1.0rem;
}
.view-feature h2.feature-top-ttl{
    color: #fff;
    font-size: 1.6rem;
    font-weight: 500;
}
.view-feature .feature-top-body{
	color:#fff;
	font-size:12px;
	line-height: 130%;
}
.view-feature .slick .feature-top-img img {
    height: auto;
  width:100%;
	object-fit: cover;
}
.view-feature .slick-arrow{
	width:25px;
}
.view-feature .slick-prev:before, 
.view-feature .slick-next:before {
    font-family:"Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
    font-size: 20px;
    line-height: 1;
    opacity: 1;
    color: white;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	width:20px;
	height:37px;
	display: block;
}
@media screen and (max-width: 991.9px) {
  .job_search_no_visiual{
    border-radius: 0px;
  }
  .job_search_no_visiual form{
    flex-wrap: wrap;
    gap:10px;
  }
  .job_search_no_visiual .job-search-form-title{
    width:100%;
    padding:0px;
    font-size:1.6rem;
  }
  .job_search_no_visiual #edit-actions{
    width:100%;
    margin:0px;
  }
  .job_search_no_visiual form #edit-submit-joblist{
    margin:0px !important;
  }
  .job_search_no_visiual form .form-item{
    margin:0px;
  }
}

.block-vwork-job-search-widget-block {
  background: #F0F8FF;
  width:1150px;
  margin-left:auto;
  margin-right:auto;
  padding:25px;
  border-radius: 5px;
  box-shadow: rgba(14, 63, 126, 0.06) 0px 0px 0px 1px, rgba(42, 51, 70, 0.03) 0px 1px 1px -0.5px, rgba(42, 51, 70, 0.04) 0px 2px 2px -1px, rgba(42, 51, 70, 0.04) 0px 3px 3px -1.5px, rgba(42, 51, 70, 0.03) 0px 5px 5px -2.5px, rgba(42, 51, 70, 0.03) 0px 10px 10px -5px, rgba(42, 51, 70, 0.03) 0px 24px 24px -8px;
  
}
.block-vwork-job-search-widget-block form{
  max-width:985px;
  margin-left:auto;
  margin-right:auto;
  display:  flex;
  background:#fff;
  border-radius: 5px;
  padding:0px 16px;
  gap:15px;
  box-sizing: border-box;
  box-shadow: rgba(40, 116, 166, 0.2) 0px 1px 2px 0px, rgba(40, 116, 166, 0.15) 0px 2px 6px 3px;
}
.block-vwork-job-search-widget-block form .form-item-area-id{
  padding-left:25px;
  background: url(../img/icon/pin.svg) no-repeat 0px 13px;
  background-size:16px;
  margin-bottom:4px;
}
.block-vwork-job-search-widget-block form .form-item-occupation-id{
  padding-left:25px;
  background: url(../img/icon/bag.svg) no-repeat 0px 13px;
  background-size:16px;
  margin-bottom:10px;
}
.block-vwork-job-search-widget-block form .form-item-keys{
  padding-left:25px;
  background: url(../img/icon/keyword.svg) no-repeat 0px 13px;
  background-size:16px;
  margin-bottom:10px;
}

.block-vwork-job-search-widget-block form label{
  display: none !important;
}
.block-vwork-job-search-widget-block form div.form-item{
  flex:1;
}
.block-vwork-job-search-widget-block form div.form-type-select select,
.block-vwork-job-search-widget-block form div.form-type-textfield input{
  border:none;
  padding:10px;
}
.block-vwork-job-search-widget-block form div.form-type-textfield.form-item-keys{
  margin-right:15px;
}
.block-vwork-job-search-widget-block form .form-actions input[type="submit"]{
  width:135px;
  height:40px;
  line-height: 40px;
  border-radius: 10px;
}
.block-vwork-job-search-widget-block .job-count-area span.job-count{
  font-weight: 600;
  font-size:1.6rem;
  color:#3498db;
}
.block-vwork-job-search-widget-block .job-count-area:after{
  content:"件の求人";
  display: inline-block;
}
.block-vwork-job-search-widget-block .js-form-item-prefectures-id.form-item-prefectures-id,
.block-vwork-job-search-widget-block .js-form-item-city-id.form-item-city-id{
  display: none;
}
.block-simple-blockhiroarealogin{
  
  margin-left: auto;
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.8),
    rgba(240, 248, 255, 0.9)
  );
  backdrop-filter: blur(5px); /* 背景ぼかし（オプション） */
  -webkit-backdrop-filter: blur(5px); /* Safari対応 */
  padding: 20px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
  border-radius: 5px;
  max-width: 355px;
  margin-top:100px;
  height: fit-content;
}
.block-simple-blockhiroarealogin .text-left h2{
  margin-top:0px;
  line-height: 150%;
  font-size:1.8rem;
}
.btn.btn-register-google {
    width: 100%;
    height: 40px;
    background: #fff url(../img/sns/google_logo.svg) no-repeat left 20px top 10px;
    background-size: 20px;
    box-sizing: border-box;
    display: block;
    position: relative;
    color: #121212;
    text-align: center;
    font-weight: bold;
    border-radius: 20px;
    padding: 0px;
    line-height: 40px;
    border: 1px solid #dedede;
    margin-bottom: 10px;
}
.btn.btn-register-line {
    width: 100%;
    height: 40px;
    background: #fff url(../img/sns/line_logo.svg) no-repeat left 20px top 10px;
    background-size: 20px;
    box-sizing: border-box;
    display: block;
    position: relative;
    color: #121212;
    text-align: center;
    font-weight: bold;
    border-radius: 20px;
    padding: 0px;
    line-height: 40px;
    border: 1px solid #dedede;
    margin-bottom: 10px;
}
.btn.btn-register {
    width: 100%;
    height: 40px;
    background-color: var(--blue2-color);
    box-sizing: border-box;
    display: block;
    position: relative;
    color: #fff;
    text-align: center;
    font-weight: bold;
    border-radius: 20px;
    padding: 0px;
    line-height: 40px;
}
.btn.btn-register:hover{
  background-color: var(--blue2-hover-color);
}
ul.client{
  display: flex;
  gap:15px;
}
ul.client li{
  width:180px;
  box-shadow: rgba(14, 63, 126, 0.04) 0px 0px 0px 1px, rgba(42, 51, 69, 0.04) 0px 1px 1px -0.5px, rgba(42, 51, 70, 0.04) 0px 3px 3px -1.5px, rgba(42, 51, 70, 0.04) 0px 6px 6px -3px, rgba(14, 63, 126, 0.04) 0px 12px 12px -6px, rgba(14, 63, 126, 0.04) 0px 24px 24px -12px;
}
ul.client li img{
  width:100%;
  height:auto;
  object-fit: cover;
  border:1px solid #fff;
}
ul.client li a{
  display: block;
  line-height: 0;
}
ul.client li a:hover img{
  border:1px solid var(--blue2-color);
}
/**** 資格から探す ****/
.qualify-side ul{
  display: flex;
  flex-wrap: wrap;
  gap:10px;
}
.qualify-side ul li a{
  display: inline-block;
  height:30px;
  line-height: 30px;
  padding:0px 15px;
  border-radius: 5px;
  border:1px solid var(--link-color);
}
.qualify-side ul li a:hover{
  color:#fff;
  background:var(--link-color);
}
.path-frontpage .hero-area .region.region-hero {
  padding-top:105px;
}
@media screen and (max-width: 1139.9px) {
  .block-vwork-job-search-widget-block{
    position: relative;
    width:100%;
    left:0px;
    right: 0px;
    border-radius: 0px;
    padding:15px;
  }
  #block-vwork-front-vol2-views-block-top-slide-block-1 .pc_slide .container .slide_items{
    margin-left:0px;
  }
  .block-vwork-job-search-widget-block form{
    max-width: 100%;
    width:100%;
  }
  
}
@media screen and (max-width: 1199.9px) {

  .region.region-hero{
    max-width: 100%;
    width:100%;
  }
  .path-frontpage .first-view .firsttext{
    padding-right:20px;
  }
}
@media (max-width: 767.9px) {
  ul.client{
    flex-wrap: wrap;
  }
  ul.client li{
    width:30%
  }
  .block-vwork-job-search-widget-block form .form-actions input[type="submit"]{
    width:100%;
  }
}

.qualify-side .view-footer{
  display: none;
}
@media (max-width: 991.9px) {
  .region.region-hero{
    flex-wrap: wrap;
  }
  .path-frontpage .first-view{
    padding-top:20px;
    padding-bottom:20px;
  }
  #block-builjob-front-front-hero-login-block{
    margin-top:0px;
    min-width: 100%;
    margin-right:auto;
  }
  .qualify-side .view-footer{
    display: block;
  }
  /* 高さ制限とアニメーション */
  .qualify-side .qualify-wrapper {
    max-height: 100px; /* 初期表示高さ */
    overflow: hidden;
    transition: max-height 0.3s ease;
    position: relative;
  }

  /* 下にグラデーション */
  .qualify-side .qualify-fade {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 160px; /* 少し高さを増やして自然に */
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #fff);
    pointer-events: none;
    z-index: 1; /* グラデーションを下にする */
  }

  /* フッターラッパー */
  .qualify-side .view-footer {
    position: relative;
    text-align: center;
    margin-top: -60px; /* グラデーションの高さに合わせる */
    padding-top: 60px;
  }

  /* ボタンはグラデーションの上に表示 */
  .qualify-side .qualify-toggle-btn {
    display: inline-block;
    padding: 8px 20px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    position: relative;
    z-index: 2; /* グラデーションより前面に */
  }

  /* 開いた状態（JSで .open クラス付与） */
  .qualify-side .qualify-wrapper.open {
    max-height: none;
  }

  /* 開いたらfadeは消す */
  .qualify-side .qualify-wrapper.open ~ .view-footer .qualify-fade {
    display: none;
  }
}
@keyframes revealFromRight {
  0% {
    -webkit-mask-position: 100% 0%;
            mask-position: 100% 0%;
  }
  100% {
    -webkit-mask-position: 0% 0%;
            mask-position: 0% 0%;
  }
}
.en-keyword{
  font-weight: 600;
  color:#fff;
  background:#D9241E;
  height:26px;
  line-height: 25px;
  padding:0px 10px;
  text-transform: uppercase;
  transform: skewX(-15deg);
}
.firstkey .en-keyword,
.firstkey .firstttl,
.firstkey .firsttext {
  display: inline-block;


/*  animation: revealFromRight 0.5s ease forwards;*/
  opacity: 1;
}

/* アニメーションの順番（1秒ずつ） */
.firstkey img {
}
.firstkey .firstttl {

  text-shadow: 1px 1px 5px #235f85;
}
.firstkey .firsttext {
  text-shadow: 1px 1px 5px #235f85;
}


/* アニメーション用の擬似要素 */
.path-frontpage .first-view::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.2);
}

/* アニメーション定義：下から上へ高さを伸ばす */
@keyframes borderGrowUp {
  from {
    height: 0;
  }
  to {
    height: 100%;
  }
}



@media (max-width: 767.9px) {
  .path-frontpage .first-view .firsttext{
    padding-right:0px;
    font-size:13px;
    line-height: 130%;
  }
  .path-frontpage .first-view{
    padding-left:20px;
    padding-bottom:10px;
    padding-top:15px;
    padding-right:20px;
  }
  .path-frontpage .region.region-hero{
    gap:10px;
  }
  .path-frontpage .first-view .firstttl{
    font-size:24px;
  }
  #block-builjob-front-front-hero-login-block{
    margin-top:0px;
    margin-bottom:20px;
  }
  .path-frontpage .hero-area{
    
    height: 730px;
  }
  .path-frontpage .hero-area .bg-video{
    height: 730px;
  }
  
}

/*** エリアから探す ****/
ul.area-search {
  display: flex;
  gap:15px;
  flex-wrap: wrap;
}
ul.area-search li{
  padding:10px;
  box-shadow: rgba(14, 63, 126, 0.06) 0px 0px 0px 1px, rgba(42, 51, 70, 0.03) 0px 1px 1px -0.5px, rgba(42, 51, 70, 0.04) 0px 2px 2px -1px, rgba(42, 51, 70, 0.04) 0px 3px 3px -1.5px, rgba(42, 51, 70, 0.03) 0px 5px 5px -2.5px, rgba(42, 51, 70, 0.03) 0px 10px 10px -5px, rgba(42, 51, 70, 0.03) 0px 24px 24px -8px;
  border-radius: 5px;
  text-align: center;
  font-weight: 700;
}
ul.area-search img{
  width:100%;
  height: auto;
  object-fit: cover;
  margin-bottom:10px;
}
ul.area-search li:hover,
ul.area-search a:hover{
  color:#fff;
  background:#90CBFF;
}
ul.area-search li{
    width:calc( 14% - 15px);
}
@media (max-width: 991.9px) {
  ul.area-search{
    flex-wrap: wrap;
  }
  ul.area-search li{
    width:calc( 25% - 15px);
  }
}
@media (max-width: 767.9px) {
  ul.area-search li{
    width:calc( 33% - 15px);
  }
  .path-frontpage .firstcnt {
    font-size: 12px;
  }
  .path-frontpage .firstcnt span{
    font-size: 15px;
  }
  .cnt-left{
    width:35%;
  }

}
#block-front-top-cnt{
	position: relative;
}
#block-front-top-cnt:after{
	content:"";
	display: block;
	background: url("../img/owl1.webp") no-repeat;
	width:80px;
	height:120px;
	background-size: contain;
	top: -20px;
	position: absolute;
}