@charset "utf-8";
/*==================================================================================================
【search_widget.css】
フリーワード検索＆ジョブロケボタン用CSS
search_widget.cssはoriginal-css、もしくはasset-cssに配置してください
 2024/03/12:ver1.00
 2024/08/02:ver1.10 ジョブロケボタン文言変更・tabindex修正・フリーワード検索隠しテキスト更新
 2025/00/00:ver1.11 日本地図の外に出しても使える（単独使用）できるように修正
====================================================================================================*/
/*
#################################################################################################
##  ■アイコンフォント
## "recop-iconfonts" has been generated by the fontello & flaticon.
##
##  【fontello】http://fontello.com/
##  License is under the materials SIL Open Font License 1.1
##
## 【Font Awesome】http://fortawesome.github.com/Font-Awesome/
## 【Typicons】http://typicons.com/
## 【MFG Labs】http://www.mfglabs.com/
## 【Entypo】http://www.entypo.com
## 【Modern Pictograms】http://thedesignoffice.org/project/modern-pictograms/
## 【Iconic】http://somerandomdude.com/work/iconic/
## 【Web Symbols】http://www.justbenicestudio.com/
## 【Elusive】http://aristeides.com
## 【Freepik】http://www.freepik.com
##
##
##  【flaticon】https://www.flaticon.com/
##  Icons made by under the materials from www.flaticon.com Licensed by [CC 3.0 BY]
##
## 【Scott de Jonge】https://www.flaticon.com/authors/scott-de-jonge
## 【Trinh Ho】https://www.flaticon.com/authors/trinh-ho
## 【SimpleIcon】https://www.flaticon.com/authors/simpleicon
## 【google】https://www.flaticon.com/authors/google
##
#################################################################################################
*/

@font-face {
  font-family: recop-iconfonts;
  src:
    url("option/font/recop-iconfont.eot?") format("eot"),
    url("option/font/recop-iconfont.woff") format("woff"),
    url("option/font/recop-iconfont.ttf") format("truetype");
  font-display: swap;
}
/*-------------------------------------------*/
/*◆位置・サイズ調整用
/*-------------------------------------------*/
/*ロケスマアイコン*/
.gpsObj .locasma a:after {
  content: "";
  left: calc(50% - 6.45em);
  /* right: 0.5em; */
}
/*flexで横並べ*/
.fwdObj form {
  height: 70px;
  line-height: 70px;
}
/*入力*/
.fwdObj form #freeword {
  width: calc(100% - 60px);
}
/*検索ボタン（アイコンフォント使用）*/
.fwdObj form #freewordsearch {
  font-size: 32px;
  /* margin-left:5px; */
}
/*地図内の位置調整用（PCのみ）*/
#zoneSearch_pack #search_widget {
  max-width: 420px;
  left: 80px;
}
/*-------------------------------------------*/
/*◆ロケスマ
/*-------------------------------------------*/
.gpsObj {
  width: 100%;
  max-width: 980px;
  margin: 10px auto;
  margin-bottom: 1em;
  position: relative;
  transition: 0.3s;
}
.gpsObj .locasma a {
  color: #fff !important;
  font-size: 18px;
  font-weight: 600;
  text-decoration: none !important;
  text-align: center;
  padding: 9px 12px 9px 20px;
  display: block;
  background: #00a494;
  border: 3px solid #00a494;
  border-radius: 10px;
  position: relative;
  transition: 0.3s;
}
.gpsObj .locasma a:before {
  content: "\e881";
  display: block;
  position: absolute;
  right: 0.9em;
  top: 50%;
  transform: translateY(-50%);
  margin: auto;
  font-family: "recop-iconfont";
  font-size: 20px;
  color: #fff;
}
.gpsObj .locasma a:after {
  content: "";
  display: block;
  position: absolute;
  /* right: 0.5em; */
  top: 50%;
  transform: translateY(-50%);
  margin: auto;
  width: 21px;
  height: 30px;
  background: url("../images/ico_locasma.svg") no-repeat top center / contain;
}
.gpsObj .locasma a:hover,
.gpsObj .locasma a:active {
  opacity: 0.6;
}
@media only screen and (min-width: 768px) {
  .gpsObj .locasma a {
    box-sizing: border-box;
    min-height: 70px;
    display: grid;
    place-items: center;
    padding: 12px 34px 12px 50px;
  }
  .gpsObj .locasma a:after {
    left: calc(50% - 6.15em);
  }
}
@media only screen and (min-width: 780px) {
  .gpsObj .locasma a {
    font-size: 20px;
  }
}
@media only screen and (max-width: 375px) {
  .gpsObj .locasma a {
    font-size: 18px;
  }
  .gpsObj .locasma a:after {
    left: calc(50% - 6.45em);
  }
}
/*-------------------------------------------*/
/*◆フリーワード検索
/*-------------------------------------------*/
.fwdObj {
  max-width: 980px;
  margin: 10px auto;
  width: 100%;
}
/*flexで横並べ*/
.fwdObj form {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  width: 100%;
  height: 60px;
  line-height: 60px;
  margin-bottom: 1.4em;
  background: #fff;
  border-radius: 10px;
}
/**/
.fwdObj form input {
  width: 100%;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
}
/*入力*/
.fwdObj form #freeword {
  font-size: 18px;
  font-weight: bold;
  height: 60px;
  padding: 17px 23px 17px 16px;
  border: none;
  background: transparent;
  color: #919191;
  border: 3px solid #00a494;
  border-right: none;
  border-radius: 10px 0 0 10px;
}
/*検索ボタン（アイコンフォント使用）*/
.fwdObj form #freewordsearch {
  width: 60px;
  height: 60px;
  background: #00a494 url("../images/ico_jobfind.svg") no-repeat center center / 33px;
  border-radius: 0 10px 10px 0;
  color: #fff;
  cursor: pointer;
  transition: 0.3s;
}
.fwdObj form #freewordsearch:hover,
.fwdObj form #freewordsearch:active {
  opacity: 0.6;
}
@media only screen and (min-width: 768px) {
  .fwdObj form {
    height: 70px;
  }
  .fwdObj form #freeword {
    width: calc(100% - 70px);
    height: 70px;
    padding: 17px 23px 17px 26px;
    font-size: 20px;
  }
  .fwdObj form #freewordsearch {
    width: 70px;
    height: 70px;
    background-size: 31px;
  }
}
@media only screen and (max-width: 519px) {
  .fwdObj form #freeword {
    font-size: 18px;
  }
}
@media only screen and (max-width: 360px) {
  .fwdObj form #freeword {
    font-size: 14px;
    padding: 0 2px 0 10px;
  }
}
/*-------------------------------------------*/
/*◆マップ用
/*-------------------------------------------*/
#zoneSearch_pack #search_widget {
  position: absolute;
  /*max-width: 420px;*/
  top: 0;
  left: 80px;
  z-index: 100;
  width: 100%;
}
/*スマホにしたときの調整用・位置初期化*/
#zoneSearch_pack #search_widget._js-spmode {
  position: static;
  max-width: initial;
}
@media only screen and (max-width: 900px) and (min-width: 768px) {
  #zoneSearch_pack #search_widget {
    left: 0;
  }
}
/*-------------------------------------------*/
/*◆スクリーンリーダー
/*-------------------------------------------*/
.screen-reader-wrap {
  position: relative;
}
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

/*=============================================================================================================*/
/* ▼検索▼（GPSボタンとフリーワード検索　★★★横並びパターン★★★）：#fwdObj に .sideBySide を追加
/*=============================================================================================================*/
/*-------------------------------------------*/
/*◆外枠（横並び）：#search_widget.sideBySide
/*-------------------------------------------*/
#search_widget.sideBySide {
  position: relative;
  max-width: 1000px;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: start;
}
@media only screen and (max-width: 767px) {
  #search_widget.sideBySide {
    flex-direction: column;
    justify-content: center;
  }
}
/*-------------------------------------------*/
/*◆ロケスマ（横並び）：#search_widget.sideBySide
/*-------------------------------------------*/
#search_widget.sideBySide .locasma {
  width: calc(100% - 30px);
  margin-right: 1em;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  #search_widget.sideBySide .locasma {
    width: 100%;
    max-width: initial;
    margin-right: 0;
  }
}
@media only screen and (max-width: 519px) {
  /* 520px未満 */
  #search_widget.sideBySide .locasma {
    width: 100%;
    max-width: 100%;
  }
}
/*-------------------------------------------*/
/*◆フォーム（横並び）：#search_widget.sideBySide
/*-------------------------------------------*/
#search_widget.sideBySide form {
  /* max-width: 420px; */
  margin-bottom: 1em;
}
@media only screen and (max-width: 767px) {
  #search_widget.sideBySide form {
    width: 100%;
    max-width: initial;
  }
}
@media only screen and (max-width: 519px) {
  #search_widget.sideBySide form {
    max-width: 100%;
  }
}
