@charset "UTF-8";
/*****************************************************************
カスタム　特別求人サイトテンプレート用レイアウト
*****************************************************************/
/*==========================================
/
/ 0■body
/ 1■footer_fix
/ 2■Common
/ 3■header
/ 4■Nav
/ 5■footer
/ 6■パンくず
/ 7■under 下層共通
/
==========================================*/
/******************************************************************
  0■body
*****************************************************************/
* {
  margin: 0;
  padding: 0;
}

body {
  color: #666666;
  font-size: 13px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #333333;
  letter-spacing: 0.7px;
  line-height: 1.7em;
}

body .open {
  overflow: hidden;
  height: 100%;
}

h1 {
  margin: 0;
}

.data-for-aidemlog { /* 独自ログ計測用 */ }

/******************************************************************
  1■footer_fix  (footer固定のためのCSS)
*****************************************************************/
html,
body {
  height: 100%;
}

#wrap {
  width: 100%;
  position: relative;
  min-height: 100%;
  overflow: hidden;
}

#container {
  padding: 51px 0 20px 0;
  margin: 0 auto;
}

/******************************************************************
  2■Common
*****************************************************************/
a {
  color: #333333;
}

.contents {
  padding: 20px 0;
  margin: 0 15px;
  position: relative;
}

.contents .tit-cts-wrap {
  overflow: hidden;
  text-align: center;
  margin: 0 0 26px 0;
}

.contents .tit-cts-wrap .tit-cts {
  position: relative;
  display: inline-block;
  padding: 0 18px 0 20px;
  text-align: center;
  font-size: 18px;
  line-height: 1;
  letter-spacing: 2px;
}

.contents .tit-cts-wrap .tit-cts span {
  font-size: 12px;
  letter-spacing: 1px;
}

.contents .tit-cts-wrap .tit-cts .tit-cts-rline,
.contents .tit-cts-wrap .tit-cts .tit-cts-lline {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  content: "";
  width: 400%;
  height: 1px;
  height: 4px;
}

.tit-cts-rline,
.tit-cts-lline {
  border-bottom: 1px solid #ffffff;
  border-top: 1px solid #ffffff;
}

.tit-cts-rline,
.tit-cts-lline {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  content: "";
  width: 400%;
  height: 1px;
  height: 4px;
  border-bottom: 1px solid;
  border-top: 1px solid;
}

.contents .tit-cts-wrap .tit-cts .tit-cts-lline {
  right: 100%;
}

.contents .tit-cts-wrap .tit-cts .tit-cts-rline {
  left: 100%;
}

.list-arrow {
  position: relative;
}

.list-arrow a {
  padding: 0 0 0 12px;
  text-decoration: underline;
}

.list-arrow-text {
  text-decoration: underline;
  font-size: 12px;
  position: relative;
}

.list-arrow-text a {
  padding-left: 12px;
}

.list-arrow::before,
.list-arrow::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}

.list-arrow::before {
  left: 0;
  width: 4px;
  height: 4px;
  border-top: 2px solid;
  border-right: 2px solid;
  transform: rotate(45deg);
}

.list-arrow-text::after {
  display: block;
  content: "";
  position: absolute;
  top: 0.7em;
  left: 0;
  width: 4px;
  height: 4px;
  border-right: 2px solid;
  border-bottom: 2px solid;
  transform: rotate(-45deg);
}

.external {
  background: url(../img/common/icon-external.png) no-repeat right center;
  background-size: 11px 9px;
  padding: 0 15px 0 0;
  word-break: break-all;
}

#page_top {
  position: fixed;
  right: 0;
  bottom: 100px;
}

#page_top a {
  display: block;
  width: 43px;
  height: 0;
  overflow: hidden;
  padding: 43px 0 0;
  opacity: 0.7;
}

.scroll {
  background: url(../img/common/icon-top.png) no-repeat center center;
  background-size: 20px;
}

.feature {
  padding: 5px 10px;
}

/******************************************************************
  3■header
*****************************************************************/
header {
  overflow: hidden;
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 999;
  border-bottom: 3px solid;
}

#lp header {
  position: absolute;
}

header .header-inner {
  height: 49px;
  background: #ffffff;
  position: relative;
}

header .header-logotitle {
  position: absolute;
  left: 0;
}

header .header-logotitle a {
  display: block;
}

header .header-logotitle .header-logo {
  height: 34px;
  margin: 8px 0 0 10px;
  width: 212px;
  position: relative;
  display: block;
}

header .header-logotitle .header-logo img {
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
}

header .header-logotitle .header-title {
  display: table-cell;
  height: 34px;
  vertical-align: middle;
  padding: 8px 10px 5px;
  line-height: 1.2;
}

header .header-title-img {
  height: 49px;
  display: block;
}
header .header-title-img img {
  height: 100%;
  width: auto;
}

header .header-menu .header-menu-list {
  list-style: none;
}

header .header-menu .header-menu-list .menu-kyujin {
  display: none;
}

header .header-menu .header-menu-list .menu-kyujin a {
  display: block;
  background: url(../img/common/icon-kyujin.png) no-repeat left center;
  background-size: 15px;
  padding: 0 0 0 20px;
}

/******************************************************************
  4■Nav
*****************************************************************/
#gnav {
  overflow-y: auto;
  opacity: 0;
  transition: opacity 500ms ease, transform 500ms ease;
  transform: scale(0.98);
  -webkit-overflow-scrolling: touch;
  width: 100%;
  overflow: auto;
  background: #ffffff;
  position: fixed;
  z-index: 999;
  top: 52px;
  -moz-height: calc(100% - 52px);
  -o-height: calc(100% - 52px);
  -ms-height: calc(100% - 52px);
  -webkit-height: calc(100% - 52px);
  height: calc(100% - 52px);
}

#wrap.gnav_open nav#gnav {
  opacity: 1;
  transform: scale(1);
  line-height: 1.4;
}

/*お気に入り*/
header .header-inner .header-menu {
  position: fixed;
  top: 0;
  right: 49px;
  z-index: 999;
  overflow: hidden;
}

header .header-menu .header-menu-list .menu-favorite a {
  display: block;
  position: relative;
  width: 49px;
  height: 49px;
}

header .header-menu .header-menu-list .menu-favorite a .btnKeep-ic {
  display: block;
  width: 25px;
  height: 25px;
  overflow: hidden;
  position: absolute;
  left: 8px;
  top: 0;
  bottom: 0;
  margin: auto;
  fill: #bfbfbf;
}

header .header-menu .header-menu-list .menu-favorite a .status {
  position: absolute;
  right: 8px;
  bottom: 13px;
  color: #ffffff;
  width: 16px;
  font-size: 9px;
  line-height: 1;
  border-radius: 2px;
  padding: 4px 0 3px 0;
}

header .header-menu .header-menu-list .menu-favorite a .status .num {
  margin: auto;
  letter-spacing: 0;
  display: block;
  text-align: center;
}

/*gnav_btn*/
header .header-inner p.slide_btn {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 999;
  width: 49px;
  height: 49px;
  cursor: pointer;
}

header .header-inner p.slide_btn span {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
  position: absolute;
  left: 11px;
  width: 26px;
  height: 3px;
}

header .header-inner p.slide_btn span:nth-of-type(1) {
  top: 15px;
}

header .header-inner p.slide_btn span:nth-of-type(2) {
  top: 24px;
}

header .header-inner p.slide_btn span:nth-of-type(3) {
  bottom: 13px;
}

#wrap.gnav_open header .header-inner p.slide_btn span:nth-of-type(1) {
  transform: translateY(9px) rotate(-45deg);
}

#wrap.gnav_open header .header-inner p.slide_btn span:nth-of-type(2) {
  opacity: 0;
}

#wrap.gnav_open header .header-inner p.slide_btn span:nth-of-type(3) {
  transform: translateY(-9px) rotate(45deg);
}

/*gnav_style*/
nav#gnav ul li a {
  display: block;
  background: url(../img/common/arrow-gnav.png) no-repeat right 10px center;
  background-size: 5px;
  padding: 15px 15px 15px 10px;
  font-weight: bold;
}

.gnav-list-link {
  border-bottom: 1px solid #ffffff;
}

nav#gnav ul li.menu-kyujin a {
  background: url(../img/common/arrow-gnav.png) no-repeat right 10px center, url(../img/common/icon-kyujin.png) no-repeat 10px center;
  background-size: 8px, 15px;
  padding: 15px 35px 15px 30px;
}

nav#gnav ul li.menu-favorite a {
  position: relative;
  padding: 15px 15px 15px 30px;
}

nav#gnav ul.lists a {
  background-size: 8px, 15px;
}

nav#gnav ul.lists li:last-child a {
  border: none;
}

nav#gnav .gnav_guide li a span {
  background: url(../img/common/icon-external.png) no-repeat right center;
  background-size: 11px 9px;
  padding: 0 15px 0 0;
}

.gnav_BOX_wrap {
  border-bottom: 1px solid #ffffff;
}

nav#gnav ul li.menu-favorite a svg {
  height: 13px;
  width: 16px;
  margin-right: 5px;
  position: absolute;
  top: 17px;
  left: 8px;
}

nav#gnav ul li.menu-favorite a .status {
  display: inline;
}

nav#gnav ul .gnav_ttl {
  color: #ffffff;
  padding: 8px 15px;
  font-size: 15px;
  font-weight: bold;
}

nav#gnav ul.gnav_2-column {
  overflow: hidden;
}

nav#gnav ul.gnav_2-column li {
  width: 50%;
  float: left;
}

nav#gnav ul.gnav_2-column a {
  height: 52px;
  padding: 0 20px 0 10px;
  line-height: 1;
}

.gnav-list-link-col2 {
  border-right: 1px solid #ffffff;
}

nav#gnav ul.gnav_2-column li:nth-child(odd) a {
  border-right: none;
}

nav#gnav ul.gnav_2-column li:last-child a {
  border-bottom: none;
}

nav#gnav ul.gnav_2-column span {
  height: 52px;
  display: table-cell;
  vertical-align: middle;
}

/*検索窓*/
nav#gnav .freeword_box {
  padding: 13px 15px;
}

.freeword_box .class_fwForm {
  width: 100%;
  background: #ffffff;
  display: table;
}

.freeword_box .class_fwForm .txt-field {
  display: table-cell;
  padding: 0 5px;
  font-size: 15px;
  vertical-align: middle;
  border: 1px solid #bfbfbf;
}

.freeword_box .class_fwForm .txt-field .kwText {
  width: 100%;
  height: 100%;
}

.freeword_box .class_fwForm .int-btn {
  display: table-cell;
  width: 40px;
  height: 40px;
}

.freeword_box .class_fwForm .int-btn .pushEnter {
  background: #bfbfbf url(../img/common/icon-search.png) no-repeat center center;
  background-size: 20px;
  height: 100%;
  overflow: hidden;
  width: 100%;
}

/*閉じるボタン*/
#gnav .gnav_BOX .gnav_BOX_inner p.slide_btn {
  background: #bfbfbf;
  text-align: center;
  color: #ffffff;
  padding: 10px;
  margin: 30px 15px;
}

/******************************************************************
  5■footer
*****************************************************************/
footer {
  width: 100%;
  background: #ffffff;
  border-top: 1px solid #bfbfbf;
  border-bottom: 6px solid;
}

.footer-inner {
  padding: 20px 15px 10px;
}

.footer-inner ul {
  padding: 0 0 20px 0;
}

.footer-inner ul li {
  padding-left: 12px;
  text-indent: -12px;
}

.footer-inner .logo-footer {
  text-align: right;
}

.footer-inner .logo-footer a {
  display: inline-block;
  background: url(../img/common/logo-aidem.png) no-repeat top right;
  background-size: 124px auto;
  height: 0;
  padding-top: 18px;
  overflow: hidden;
  width: 124px;
}

.list-arrow-text .list-arrow {
  display: inline-block;
  text-decoration: underline;
}

.list-arrow-text .list-arrow::before, .list-arrow::after {
  bottom: 5px;
}

/******************************************************************
  6■パンくず
*****************************************************************/
#breadcrumbs {
  padding: 10px 0;
  line-height: 1.4;
}

#breadcrumbs ul {
  overflow: hidden;
  margin: 0 0 -5px -5px;
}

#breadcrumbs li {
  float: left;
  font-size: 11px;
  padding: 0 3px;
  line-height: 1.4;
  margin: 0 0 5px;
}

#breadcrumbs li a {
  text-decoration: underline;
}

/******************************************************************
  7■under 下層共通
*****************************************************************/
/*見出し*/
.cts-h2 {
  padding: 5px 0 5px 12px;
  border-width: 5px;
  border-left-style: solid;
  font-weight: bold;
}

/*コンテンツ*/
.under-cts {
  margin: -20px 0 0 0;
}

.under_tit {
  font-size: 15px;
  padding: 10px 15px;
  margin: 0 -15px 20px;
  color: #ffffff;
}

/*ボタン*/
.list-btn {
  width: 100%;
  height: 40px;
  text-align: center;
  margin: 0 auto;
}

.list-btn a {
  color: #ffffff;
  display: block;
  font-size: 15px;
  width: auto;
  text-align: center;
  padding: 9px 0;
}

#interview-d .list-btn span {
  position: relative;
  padding: 0 0 0 25px;
}

#interview-d .list-btn span::before {
  content: "←";
  position: absolute;
  left: 0px;
}

/*お気に入りハート*/
.actionList_item .btnKeep-ic {
  fill: #bfbfbf;
}

.btnKeep-ic {
  border: 1px solid #ffffff;
}

/*ボタンアイコン*/
.list-button-app a img {
  width: 12px;
  height: 14px;
  padding: 0 10px 0 0;
}

.list-button-phone a img {
  width: 6px;
  height: 14px;
  padding: 0 8px 0 0;
}

.list-button-method a img {
  width: 13px;
  height: 14px;
  padding: 0 10px 0 0;
}/*# sourceMappingURL=s-common.css.map */