@charset "UTF-8";
.mt0 {
  margin-top: 0 !important;
}

.mt8 {
  margin-top: 8px !important;
}

.mt16 {
  margin-top: 16px !important;
}

.mt24 {
  margin-top: 24px !important;
}

.mt32 {
  margin-top: 32px !important;
}

.mt64 {
  margin-top: 64px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

.mb16 {
  margin-bottom: 16px !important;
}

.mb24 {
  margin-bottom: 24px !important;
}

.mb32 {
  margin-bottom: 32px !important;
}

.mb64 {
  margin-bottom: 64px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pl32 {
  padding-left: 32px !important;
}

.is_pc {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  .is_pc {
    display: block;
  }
}

.is_sp {
  display: block;
}
@media print, screen and (min-width: 1024px) {
  .is_sp {
    display: none;
  }
}

.serif {
  font-family: serif !important;
}

.table_rows tbody th {
  background-color: #E1E1E1 !important;
  color: #333 !important;
  width: 30%;
}
@media print, screen and (min-width: 1200px) {
  .table_rows tbody th {
    width: 300px;
  }
}
.table_rows tbody td {
  vertical-align: top;
}
.table_rows tbody td:first-child {
  font-weight: 700;
  background-color: #E1E1E1;
  color: #333 !important;
}
@media print, screen and (min-width: 1200px) {
  .table_rows tbody td:first-child {
    width: 300px;
  }
}
@media print, screen and (max-width: 639px) {
  .table_rows {
    display: block;
  }
  .table_rows tbody {
    display: block;
    width: 100%;
  }
  .table_rows tr {
    display: block;
    width: 100%;
  }
  .table_rows tr:first-child th, .table_rows tr:first-child td {
    border-bottom: 0;
  }
  .table_rows th, .table_rows td {
    display: block;
    width: 100%;
  }
}

.table_cols tr:first-of-type td {
  background-color: #E1E1E1;
  color: #333;
  font-weight: 700;
}

.p-contactform {
  max-width: 100%;
}
@media print, screen and (max-width: 639px) {
  .p-contactform {
    padding-left: 0;
  }
}
.p-contactform input[type=text].full, .p-contactform input[type=tel], .p-contactform input[type=email] {
  width: 100%;
  max-width: 100%;
}
.p-contactform input[type=text], .p-contactform input[type=tel], .p-contactform input[type=email] {
  padding: 3px 5px;
  border: 1px solid #CCC;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
.p-contactform input[type=text]:focus, .p-contactform input[type=tel]:focus, .p-contactform input[type=email]:focus {
  background-color: #EEE;
}
.p-contactform input[type=text].wpcf7-not-valid, .p-contactform input[type=tel].wpcf7-not-valid, .p-contactform input[type=email].wpcf7-not-valid {
  border: 1px solid #E00;
}
.p-contactform textarea {
  width: 100%;
  padding: 3px 5px;
  border: 1px solid #CCC;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}
.p-contactform textarea:focus {
  background-color: #EEE;
}
.p-contactform textarea.wpcf7-not-valid {
  border: 1px solid #E00;
}
.p-contactform select {
  padding: 8px;
  border-color: #CCC;
}
.p-contactform .wpcf7-list-item {
  margin: 0 1em 0 0;
  margin-bottom: 8px !important;
}
@media print, screen and (max-width: 639px) {
  .p-contactform .wpcf7-list-item {
    margin-bottom: 0.8rem;
    display: block !important;
  }
}
.p-contactform span.wpcf7-not-valid-tip {
  margin-top: 2px;
  color: #E00;
}
.p-contactform p {
  margin-bottom: 0;
}
.p-contactform .u-ai_center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-contactform .u-flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.p-contactform .wpcf7-form-control-wrap input {
  width: 100%;
}
@media print, screen and (max-width: 639px) {
  .p-contactform th {
    width: 100% !important;
  }
}

input::-webkit-input-placeholder {
  color: #999;
}

input::-moz-placeholder {
  color: #999;
}

input:-ms-input-placeholder {
  color: #999;
}

input::-ms-input-placeholder {
  color: #999;
}

input::placeholder {
  color: #999;
}

.p-required_mark::after {
  display: inline-block;
  margin-left: 0.3rem;
  color: #ED1C24;
  content: "*";
}

.wpcf7-submit {
  font-weight: bold;
  margin-left: 72px;
}

.bl_cv_btn .bl_cv_btn_contact {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #E84345;
  color: #ffffff;
  display: block;
  font-size: 20px;
  font-weight: bold;
  margin-top: 4px;
  padding: 10px 50px;
  text-decoration: none;
}
.bl_cv_btn .bl_cv_btn_contact:hover {
  opacity: 0.8; /* 透過率20% */
  -webkit-transition: 0.2s;
  transition: 0.2s; /* 0.2秒アニメーション */
}

.p-contactform .wpcf7-form-control-wrap input {
  width: 100%;
}

@media print, screen and (max-width: 639px) {
  .p-contactform th {
    width: 100% !important;
  }
}

/* h1 - メインタイトル */
body:not(.home) h1.c-entry__title {
  color: var(--accent-color);
  font-weight: 600;
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--accent-color);
}

body:not(.home) .l-container .c-page-header {
  padding-top: 0;
  padding-bottom: 0;
}

body:not(.home) .l-contents__inner {
  margin-top: 1.8em;
}

h1.c-page-header__title {
  color: var(--accent-color);
  font-weight: 600;
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--accent-color);
}

/* h2 - セクション見出し */
body:not(.home):not(.single-job) h2:not(.p-related-posts__title.c-entry-aside__title):not(.smb-section__title):not(.c-entry-summary__title) {
  color: var(--accent-color);
  font-weight: 600;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  padding-left: 1rem;
  border-left: 4px solid var(--accent-color);
}

/* h3 - サブセクション見出し */
body:not(.home) h3:not(.c-entry-summary__title) {
  color: var(--sub-accent-color);
  font-weight: 500;
  margin-top: 2rem;
  margin-bottom: 0.8rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--sub-accent-color);
}
@media print, screen and (max-width: 639px) {
  body:not(.home) h3:not(.c-entry-summary__title) {
    font-size: 1rem;
  }
}

/* h4 - 小見出し */
body:not(.home) h4 {
  color: var(--accent-color);
  font-weight: 500;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

/* h5 - 詳細見出し */
body:not(.home) h5 {
  color: var(--sub-accent-color);
  font-weight: 500;
  margin-top: 1.2rem;
  margin-bottom: 0.5rem;
}

/* h6 - 最小見出し */
body:not(.home) h6 {
  color: #666;
  font-weight: 500;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

/* フォーム全体 */
#main_form {
  max-width: 720px;
  margin: 0 auto;
  font-size: 15px;
  line-height: 1.6;
  color: #333;
}

/* dl レイアウト */
.dl-table {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  margin-bottom: 20px;
}

.dl-table dt {
  width: 25%;
  padding: 10px;
  font-weight: bold;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.dl-table dd {
  width: 75%;
  padding: 10px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* ラベル内の必須マーク */
.red {
  color: #d00;
  font-size: 0.9em;
  margin-left: 0.3em;
}

/* 補足説明 */
.form_ex {
  display: block;
  font-size: 0.85em;
  color: #666;
  margin-top: 5px;
}

/* フォーム入力要素 */
#main_form input[type=text],
#main_form input[type=email],
#main_form input[type=tel],
#main_form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #bbb;
  border-radius: 4px;
  font-size: 14px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

#main_form textarea {
  min-height: 120px;
  resize: vertical;
}

/* ボタンエリア */
.fx-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 20px;
}

.submitbtn input[type=submit] {
  background: var(--accent-color);
  color: #fff;
  border: none;
  padding: 12px 28px;
  font-size: 16px;
  font-weight: bold;
  border-radius: 4px;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.submitbtn input[type=submit]:hover {
  -webkit-filter: brightness(1.1);
          filter: brightness(1.1);
}

/* スマホ対応 */
@media screen and (max-width: 640px) {
  .dl-table dt,
  .dl-table dd {
    width: 100%;
    padding: 5px 0;
  }
}
.p_contact_pp {
  text-align: center;
  padding-bottom: 1rem;
}

.wp-block-snow-monkey-blocks-buttons .button_web {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
.wp-block-snow-monkey-blocks-buttons .button_web::before {
  content: "＼来社不要／";
  font-size: 14px;
  font-weight: bold;
  color: var(--accent-color);
}

.button_nav_web a {
  position: relative;
}
.button_nav_web a::before {
  content: "＼来社不要／";
  position: absolute;
  font-size: 12px;
  font-weight: bold;
  color: var(--accent-color);
  top: 0;
}

.button_footer_web {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.button_footer_web::before {
  content: "＼来社不要／";
  top: -24px;
  position: absolute;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
}

.button_footer_neo {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.button_footer_neo::before {
  content: "-登録済みの方-";
  top: -24px;
  position: absolute;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
}

.l-footer .wp-block-snow-monkey-blocks-buttons {
  gap: 2.5rem;
}

.h2_top_radiation::before {
  content: "";
  background-image: url(/cms/wp-content/plugins/my-snow-monkey/assets/img/img_radiation.png);
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100%;
  display: inline-block;
  width: 100px;
  height: 100px;
  margin-right: -30px;
  margin-bottom: -12px;
}
@media print, screen and (max-width: 1023px) {
  .h2_top_radiation::before {
    display: none;
  }
}
@media print, screen and (max-width: 1023px) {
  .h2_top_radiation {
    font-size: 1.5rem;
  }
}

.c-meta__item--author, .c-meta__item--modified {
  display: none !important;
}

.u-text_center {
  text-align: center;
}

html {
  scroll-padding-top: 120px; /* 固定ヘッダの高さ分 */
}

.post-type-archive-entrance .c-entry {
  display: none;
}

/* 横いっぱいに広げる */
/* 中身をコンテナー幅に収める */
.l-2row-header .p-global-nav > *,
.p-header-sub-nav > * {
  margin: 0 auto;
  max-width: 1240px;
  padding-right: 1.8rem;
  padding-left: 1.8rem;
}

.l-2row-header {
  max-width: 1240px;
  margin: 0 auto;
}

.l-2row-header .p-global-nav .c-navbar__item > a {
  padding-left: 4px;
  padding-right: 4px;
}

@media screen and (max-width: 1040px) {
  .l-2row-header .p-global-nav .c-navbar__item > a {
    padding-left: 4px;
    padding-right: 4px;
    font-size: 0.8rem;
  }
}
@media screen and (min-width: 1024px) {
  header.l-header.l-header--2row.l-header--sticky-sm.l-header--overlay-lg {
    background-image: -webkit-gradient(linear, left top, left bottom, from(#ffffff), color-stop(95%, rgba(255, 255, 255, 0.831372549)), to(transparent));
    background-image: -webkit-linear-gradient(#ffffff, rgba(255, 255, 255, 0.831372549) 95%, transparent);
    background-image: linear-gradient(#ffffff, rgba(255, 255, 255, 0.831372549) 95%, transparent);
  }
}
.l-2row-header__row:not(.u-invisible-md-down) {
  background-color: #356b7f;
}

@media screen and (max-width: 1024px) {
  .l-header.l-header--2row.l-header--sticky-sm {
    background-color: #356b7f;
  }
  .l-header .c-hamburger-btn__bar {
    background-color: #fff;
  }
  .c-hamburger-btn__label {
    color: #fff;
  }
}
.l-2row-header {
  max-width: 100%;
  margin: 0;
}
.l-2row-header .c-container, .l-2row-header .c-fluid-container {
  padding: 0;
}
.l-2row-header .c-row.c-row--margin-s.c-row--lg-margin.c-row--middle.c-row--nowrap {
  max-width: 1280px;
  margin: 0 auto;
}

.p-drop-nav .p-global-nav .c-navbar__item > a {
  padding-left: 10px;
  padding-right: 10px;
}

@media screen and (max-width: 1040px) {
  .p-drop-nav .p-global-nav .c-navbar__item > a {
    padding-left: 10px;
    padding-right: 10px;
    font-size: 0.8rem;
  }
}
.c-navbar__item > a span {
  border-bottom: 1px solid transparent;
  -webkit-transition: border-bottom 0.3s;
  transition: border-bottom 0.3s;
}
.c-navbar__item > a span:hover {
  border-bottom: 1px solid var(--accent-color);
}

.l-header__drop-nav .p-drop-nav .p-global-nav .c-navbar__item > li:not(.button_nav_web) a span {
  border-bottom: 1px solid transparent;
  -webkit-transition: border-bottom 0.3s;
  transition: border-bottom 0.3s;
}
.l-header__drop-nav .p-drop-nav .p-global-nav .c-navbar__item > li:not(.button_nav_web) a span:hover {
  border-bottom: 1px solid var(--accent-color);
}

.current_page_item.c-navbar__item > a span {
  border-bottom: 1px solid var(--accent-color) !important;
}

.current-menu-item.c-navbar__item > a span {
  border-bottom: 1px solid var(--accent-color) !important;
}

.c-navbar__item.menu_business > a span:hover {
  border-bottom: 1px solid #112cff;
}

.l-header__drop-nav .p-drop-nav .p-global-nav .c-navbar__item.menu_business > a span {
  border-bottom: 1px solid transparent;
  -webkit-transition: border-bottom 0.3s;
  transition: border-bottom 0.3s;
}
.l-header__drop-nav .p-drop-nav .p-global-nav .c-navbar__item.menu_business > a span:hover {
  border-bottom: 1px solid #112cff;
}

.current_page_item.c-navbar__item.menu_business > a span {
  border-bottom: 1px solid #112cff !important;
}

.current-menu-item.c-navbar__item.menu_business > a span {
  border-bottom: 1px solid #112cff !important;
}

.button_nav_web span {
  background-color: var(--accent-color);
  color: #fff;
  border-radius: 50px;
  padding: 5px 20px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.menu_business span {
  color: #112cff;
}

.header_sp_container {
  display: none;
}
@media print, screen and (max-width: 639px) {
  .header_sp_container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    gap: 4px;
  }
}

.button_houjin {
  background-color: #112cff;
  color: #fff;
  font-size: 0.7rem;
  padding: 4px 6px;
  border: 0;
  font-weight: bold;
}
@media print, screen and (max-width: 639px) {
  .button_houjin {
    display: inline-block;
  }
}

.button_houjin_container {
  text-align: end;
  padding-right: 1rem;
}

.faq .c-entry__title::before {
  content: "Q.";
  font-size: 3rem;
  font-weight: bold;
  font-family: "Arial Black";
  margin-right: 1.6rem;
  color: #349CF7;
}

.faq .c-entry__body::before {
  content: "A.";
  font-size: 3rem;
  font-weight: bold;
  font-family: "Arial Black";
  margin-right: 1.6rem;
  color: #cf2e2e;
}

.c-entry-summary--type-faq .c-entry-summary__title::before {
  content: "Q.";
  font-weight: bold;
  font-size: 2.5rem;
  font-family: "Arial Black";
  margin-right: 1.5rem;
  color: #349CF7;
}

.c-entry-summary__body .c-entry-summary__header .c-entry-summary__title {
  line-height: 2rem;
}

.l-footer-widget-area {
  background-color: #356b7f;
}

.l-footer .c-copyright--inverse {
  background-color: #356b7f;
}
.l-footer .c-copyright {
  padding: 8px;
}
.l-footer a.smb-btn {
  min-width: 150px;
}
.l-footer .footer_button_line a.smb-btn {
  border-radius: 50px 50px 0 50px;
}
.l-footer .menu-item a {
  color: #ffffff;
  font-size: 1rem;
  font-weight: bold;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.l-footer .footer_item_child a {
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: normal;
  margin-left: 1rem;
}
@media print, screen and (max-width: 1023px) {
  .l-footer .footer_item_child a {
    margin-left: 0;
  }
}
@media print, screen and (max-width: 1023px) {
  .l-footer .widget_nav_menu ul {
    text-align: center;
  }
}
@media print, screen and (max-width: 1023px) {
  .l-footer .wp-block-snow-monkey-blocks-buttons {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-align-content: center;
        -ms-flex-line-pack: center;
            align-content: center;
  }
}

.c-header-content {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.search-form__fields {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.search-form__fields label {
  cursor: pointer;
  min-width: 350px;
}
@media print, screen and (max-width: 639px) {
  .search-form__fields label {
    min-width: 180px;
    font-size: 0.8rem;
  }
}

.simple-job-search-form .search-form {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.simple-job-search-form .search-field {
  width: 100%;
  padding: 0.8em 1em 0.8em 1em;
  border: 1px solid #ddd;
  border-right: none;
  font-size: 1em;
  line-height: 1.5;
  height: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 0;
}
@media print, screen and (max-width: 639px) {
  .simple-job-search-form .search-field {
    padding: 0.6em 0 0.6em 0.8em;
  }
}

.simple-job-search-form .search-submit {
  position: relative;
  width: 3em;
  background: var(--accent-color);
  border: 1px solid #ddd;
  border-left: none;
  color: #fff;
  cursor: pointer;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media print, screen and (max-width: 639px) {
  .simple-job-search-form .search-submit {
    width: 2em;
  }
}

.simple-job-search-form .search-submit:hover {
  background: #e9e9e9;
  color: #000;
}

/* フォーム全体のコンテナ */
.job-filter-form {
  background-color: #fff;
  padding: 24px;
  border-radius: 8px;
  -webkit-box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
          box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 32px;
  margin-bottom: 32px;
}

@media (min-width: 768px) {
  .job-filter-form {
    padding: 32px;
  }
}
/* 各検索セクションの装飾 */
.job-filter-section.job-filter-keyword-section {
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  padding: 20px;
  margin-bottom: 24px;
  background-color: #fcfcfc;
}

.job-filter-accordion-item {
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  padding: 10px 20px;
  margin-bottom: 24px;
  background-color: #fcfcfc;
}

/* 検索ボタンの上のセクションは下マージンなし */
.job-filter-form > .job-filter-section:last-of-type {
  margin-bottom: 0;
}

/* ラベルのスタイル */
.job-filter-label {
  display: block;
  color: #374151;
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 12px;
  padding-bottom: 5px;
  border-bottom: 2px solid #a9d2d9;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

/* キーワード入力欄 */
.job-filter-input {
  -webkit-box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
          box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 1px solid #d1d5db;
  border-radius: 4px;
  width: 100%;
  padding: 10px 14px;
  color: #374151;
  line-height: 1.5;
  outline: none;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

.job-filter-input:focus {
  -webkit-box-shadow: 0 0 0 3px rgba(164, 253, 247, 0.5);
          box-shadow: 0 0 0 3px rgba(164, 253, 247, 0.5);
  border-color: #a9d2d9;
}

/* --- 職種（ボタン風チェックボックス）のスタイル --- */
.job-filter-occupation-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 768px) {
  .job-filter-occupation-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
/* 職種チェックボックス（入力要素を完全に隠すが、`:checked`は機能させる） */
.job-filter-occupation-checkbox-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  opacity: 0;
}

/* 職種ボタン風チェックボックスのラベル */
.job-filter-occupation-button-label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 12px 16px;
  border-radius: 4px;
  border: 1px solid #e5e7eb;
  background-color: #f9fafb;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  position: relative;
  font-weight: 500;
  color: #374151;
  min-height: 48px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.job-filter-occupation-button-label:hover {
  background-color: #f3f4f6;
  border-color: #a9d2d9;
}

/* チェックボックスがチェックされた時のラベルのスタイル */
.job-filter-occupation-checkbox-hidden:checked + .job-filter-occupation-button-label {
  background-color: #a9d2d9;
  border-color: #006d80;
  color: #374151;
}

/* 職種のハイライト */
.job-filter-occupation-button-highlight {
  background-color: #a9d2d9;
  border-color: #006d80;
}

.job-filter-occupation-button-highlight:hover {
  background-color: #a9d2d9;
}

/* ハイライトされたチェックボックスがチェックされた時のラベルのスタイル */
.job-filter-occupation-checkbox-hidden:checked + .job-filter-occupation-button-label.job-filter-occupation-button-highlight {
  background-color: #a9d2d9;
  border-color: #006d80;
}

/* 職種テキスト */
.job-filter-occupation-text {
  font-size: 0.9rem;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

/* --- 給与、エリア、期間の3カラムレイアウト --- */
.job-filter-three-col-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 24px; /* 各 job-filter-section 間の横方向の隙間 */
}

/* job-filter-three-col-wrapperが最後のjob-filter-sectionではない場合のみマージンが必要 */
.job-filter-form > .job-filter-three-col-wrapper:last-of-type {
  margin-bottom: 0;
}

.job-filter-col-item {
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 calc(33.333% - 16px);
      -ms-flex: 1 1 calc(33.333% - 16px);
          flex: 1 1 calc(33.333% - 16px); /* 3カラム（gap 24px を考慮し、24/3 = 8px * 2 = 16px を引く） */
  min-width: 280px; /* 最小幅を設定してスマホで潰れないように */
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* paddingとborderを幅に含める */
}

/* スマホ向け調整 */
@media (max-width: 767px) {
  .job-filter-three-col-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column; /* 縦並びに戻す */
    gap: 0; /* セクション間のgapは不要 */
  }
  .job-filter-col-item {
    width: 100%;
    -webkit-box-flex: 0;
    -webkit-flex: none;
        -ms-flex: none;
            flex: none; /* flexを解除 */
    min-width: unset;
  }
  .job-filter-col-item:last-child {
    margin-bottom: 0;
  }
}
/* チェックボックスの縦並びリスト */
.job-filter-checkbox-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4px; /* チェックボックス間の縦方向の間隔 */
  padding-left: 0;
}

/* --- 通常のチェックボックスのラベルの装飾を削除 --- */
.job-filter-default-checkbox-label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0; /* パディング削除 */
  border: none; /* ボーダー削除 */
  background-color: transparent; /* 背景色削除 */
  cursor: pointer;
  -webkit-transition: none;
  transition: none; /* トランジション削除 */
}

.job-filter-default-checkbox-label:hover {
  background-color: transparent; /* ホバー時の背景色も削除 */
  border-color: transparent; /* ホバー時のボーダー色も削除 */
}

/* 通常のチェックボックス（入力要素） */
.job-filter-default-checkbox {
  margin-right: 8px;
  width: 16px;
  height: 16px;
  border: 1px solid #d1d5db;
  border-radius: 3px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  outline: none;
  cursor: pointer;
  background-color: #fff;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  position: relative;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
}

.job-filter-default-checkbox:checked {
  background-color: #006d80;
  border-color: #006d80;
}

.job-filter-default-checkbox:checked::before {
  content: "";
  display: block;
  width: 6px;
  height: 10px;
  border: solid white;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: absolute;
  top: 1px;
  left: 4px;
}

.job-filter-default-checkbox:focus {
  -webkit-box-shadow: 0 0 0 3px rgba(164, 253, 247, 0.5);
          box-shadow: 0 0 0 3px rgba(164, 253, 247, 0.5);
}

/* 通常のチェックボックスのテキスト */
.job-filter-default-checkbox-text {
  color: #374151;
  font-size: 0.875rem;
}

/* 給与の親ターム（時給、日給など） */
.job-filter-salary-parent {
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 1px dashed #e0e0e0;
}

.job-filter-salary-parent:last-of-type {
  margin-bottom: 0;
  border-bottom: none;
  padding-bottom: 0;
}

.job-filter-salary-parent-title {
  color: #1f2937;
  font-weight: 600;
  margin-bottom: 8px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.95rem;
}

.job-filter-icon {
  height: 20px;
  width: 20px;
  margin-right: 4px;
  color: #0ABAB5;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
}

/* 検索ボタンのコンテナ */
.job-filter-button-wrapper {
  text-align: center;
}

.job-search-modal .job-filter-button-wrapper {
  display: none;
}

/* 検索ボタン */
.job-filter-submit-button {
  background-color: #0ABAB5;
  color: #fff;
  font-weight: 700;
  padding: 12px 32px;
  border-radius: 9999px;
  -webkit-box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
          box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  outline: none;
  border: none;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

.job-filter-submit-button:hover {
  background-color: #0ABAB5;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
          box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.job-filter-submit-button:focus {
  -webkit-box-shadow: 0 0 0 3px rgba(164, 253, 241, 0.5);
          box-shadow: 0 0 0 3px rgba(164, 253, 241, 0.5);
}

/* Collapsible search form */
.job-search-criteria {
  background: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 4px;
  padding: 16px;
  margin-bottom: 20px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: right;
  -webkit-justify-content: right;
      -ms-flex-pack: right;
          justify-content: right;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 10px;
}
.job-search-criteria-text {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 12px;
  margin-right: 15px;
}
.job-search-criteria .criteria-item {
  background: #fff;
  border: 1px solid #dee2e6;
  border-radius: 4px;
  padding: 4px 12px;
  font-size: 14px;
  color: #495057;
}

.job-search-toggle {
  background: #007cba;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 8px 16px;
  cursor: pointer;
  font-size: 14px;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.job-search-toggle:hover {
  background: #005a87;
}
.job-search-toggle .toggle-icon {
  display: inline-block;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  font-size: 10px;
}
.job-search-toggle[aria-expanded=true] .toggle-icon {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.job-filter-form--collapsible {
  -webkit-transition: max-height 0.3s ease-out, opacity 0.3s ease-out;
  transition: max-height 0.3s ease-out, opacity 0.3s ease-out;
  overflow: hidden;
}

@media print, screen and (max-width: 1023px) {
  .job-search-criteria {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .job-search-criteria-text {
    margin-bottom: 10px;
    margin-right: 0;
  }
  .job-search-toggle {
    width: 100%;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.job-search-modal.is-active + .job-filter-form .job-filter-submit-button {
  display: none;
}

.job-search-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
}
.job-search-modal.is-active {
  display: block;
}
.job-search-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1;
}
.job-search-modal__content {
  position: fixed;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 90%;
  max-width: 1000px;
  max-height: 90vh;
  background-color: #fff;
  border-radius: 8px;
  -webkit-box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
          box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
  z-index: 2;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.3s ease, visibility 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease, -webkit-transform 0.3s ease;
}
.is-active .job-search-modal__content {
  opacity: 1;
  visibility: visible;
  -webkit-animation: modalFadeIn 0.3s ease-out;
          animation: modalFadeIn 0.3s ease-out;
}
@-webkit-keyframes modalFadeIn {
  from {
    opacity: 0;
    -webkit-transform: translate(-50%, -40%);
            transform: translate(-50%, -40%);
  }
  to {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
@keyframes modalFadeIn {
  from {
    opacity: 0;
    -webkit-transform: translate(-50%, -40%);
            transform: translate(-50%, -40%);
  }
  to {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
.job-search-modal__header {
  padding: 20px;
  border-bottom: 1px solid #eee;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.job-search-modal__title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: bold;
}
.job-search-modal__close {
  background: none;
  border: none;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  padding: 0 10px;
  color: #666;
}
.job-search-modal__close:hover {
  color: #000;
}
.job-search-modal__body {
  padding: 20px;
  overflow-y: auto;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.job-search-modal__footer {
  padding: 15px 20px;
  border-top: 1px solid #eee;
  text-align: center;
}
.job-search-modal__submit {
  padding: 10px 24px;
  background-color: #0073aa;
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1rem;
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.job-search-modal__submit:hover {
  background-color: #005177;
}
.job-search-modal .job-filter-form {
  margin: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: none;
  padding: 0;
}
@media (max-width: 768px) {
  .job-search-modal__content {
    width: 95%;
    margin: 2vh auto;
    max-height: 96vh;
  }
  .job-search-modal__body {
    padding: 15px;
  }
}

.home .job-search-criteria {
  display: none;
}

.job-search-criteria {
  margin-bottom: 20px;
}
.job-search-criteria-text .criteria-item {
  display: inline-block;
  margin-right: 15px;
  padding: 4px 12px;
  background-color: #f5f5f5;
  border-radius: 4px;
  font-size: 0.9rem;
  color: #333;
}
.job-search-criteria .job-search-modal-toggle {
  background: none;
  border: 1px solid #ccc;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.9rem;
  color: #333;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.job-search-criteria .job-search-modal-toggle:hover {
  background-color: #f5f5f5;
  border-color: #999;
}
.job-search-criteria button.job-search-modal-toggle {
  background-color: #0ABAB5;
  color: #fff;
  font-weight: 700;
  padding: 12px 32px;
  -webkit-box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
          box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  outline: none;
  border: none;
  cursor: pointer;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.job-search-criteria button.job-search-modal-toggle:hover {
  background-color: #0ABAB5;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
          box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}
.job-search-criteria button.job-search-modal-toggle:focus {
  -webkit-box-shadow: 0 0 0 3px rgba(164, 250, 253, 0.5);
          box-shadow: 0 0 0 3px rgba(164, 250, 253, 0.5);
}
.job-search-criteria.is-front-page + .job-filter-form {
  display: block !important;
  margin-top: 20px;
  padding: 20px;
  background-color: #f9f9f9;
  border-radius: 8px;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.job-search-criteria.is-front-page + .job-filter-form .job-search-fields {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}
.job-search-criteria.is-front-page + .job-filter-form .job-search-fields .search-field {
  margin-bottom: 0;
}
.job-search-criteria.is-front-page + .job-filter-form .job-search-fields .search-field label {
  display: block;
  margin-bottom: 8px;
  font-weight: bold;
  font-size: 0.9rem;
}
.job-search-criteria.is-front-page + .job-filter-form .job-search-fields .search-field select,
.job-search-criteria.is-front-page + .job-filter-form .job-search-fields .search-field input[type=text] {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 1rem;
}
.job-search-criteria.is-front-page + .job-filter-form .search-submit {
  text-align: right;
}
.job-search-criteria.is-front-page + .job-filter-form .search-submit button[type=submit] {
  padding: 10px 24px;
  background-color: #0ABAB5;
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1rem;
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.job-search-criteria.is-front-page + .job-filter-form .search-submit button[type=submit]:hover {
  background-color: #0ABAB5;
}

.search-results form.p-search-form {
  display: none;
}

.search-no-results form.p-search-form {
  display: none;
}

.job-filter-accordion-header {
  cursor: pointer;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 10px 0;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.job-filter-accordion-header .job-filter-label {
  margin: 0;
  font-weight: bold;
}

.job-filter-accordion-arrow {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.job-filter-accordion.is-open .job-filter-accordion-arrow {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

/* 職種セクションの初期状態（開いている状態）のアロー */
.job-filter-occupation-section.is-open .job-filter-accordion-arrow {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.job-filter-accordion-content {
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.3s ease;
  transition: max-height 0.3s ease;
}

.job-filter-accordion.is-open .job-filter-accordion-content {
  max-height: 2000px !important; /* 十分に大きな値に設定 */
}

.post-type-archive-job h1.c-entry__title, .tax-job_area h1.c-entry__title, .tax-job_occupation h1.c-entry__title, .tax-job_term h1.c-entry__title {
  display: none;
}
@media (min-width: 1024px) {
  .post-type-archive-job .c-entries, .tax-job_area .c-entries, .tax-job_occupation .c-entries, .tax-job_term .c-entries {
    --entries--item-width: 100%;
  }
}
.post-type-archive-job .c-entry-summary__figure > img, .tax-job_area .c-entry-summary__figure > img, .tax-job_occupation .c-entry-summary__figure > img, .tax-job_term .c-entry-summary__figure > img {
  -o-object-fit: contain;
     object-fit: contain;
  background-color: #ffffff;
}
.post-type-archive-job li.c-entries__item, .tax-job_area li.c-entries__item, .tax-job_occupation li.c-entries__item, .tax-job_term li.c-entries__item {
  padding: 2.5rem 4rem 2.5rem;
  -webkit-box-shadow: 0 4px 30px rgba(4, 0, 0, 0.1019607843);
          box-shadow: 0 4px 30px rgba(4, 0, 0, 0.1019607843);
  border-radius: 1rem;
  margin-bottom: 3rem;
}
@media print, screen and (max-width: 639px) {
  .post-type-archive-job li.c-entries__item, .tax-job_area li.c-entries__item, .tax-job_occupation li.c-entries__item, .tax-job_term li.c-entries__item {
    padding: 2rem 1rem;
  }
}
.post-type-archive-job .c-entries--simple, .post-type-archive-job .c-entries--text, .post-type-archive-job .c-entries--text2, .tax-job_area .c-entries--simple, .tax-job_area .c-entries--text, .tax-job_area .c-entries--text2, .tax-job_occupation .c-entries--simple, .tax-job_occupation .c-entries--text, .tax-job_occupation .c-entries--text2, .tax-job_term .c-entries--simple, .tax-job_term .c-entries--text, .tax-job_term .c-entries--text2 {
  border-top: 0;
}
.post-type-archive-job section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job, .tax-job_area section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job, .tax-job_occupation section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job, .tax-job_term section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (max-width: 1023px) {
  .post-type-archive-job section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job, .tax-job_area section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job, .tax-job_occupation section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job, .tax-job_term section.c-entry-summary.c-entry-summary--job.c-entry-summary--type-job {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.post-type-archive-job .c-entries--simple .c-entry-summary__figure, .tax-job_area .c-entries--simple .c-entry-summary__figure, .tax-job_occupation .c-entries--simple .c-entry-summary__figure, .tax-job_term .c-entries--simple .c-entry-summary__figure {
  min-width: 300px;
  margin-right: 2rem;
  aspect-ratio: 3/2;
}
@media print, screen and (max-width: 639px) {
  .post-type-archive-job .c-entries--simple .c-entry-summary__figure, .tax-job_area .c-entries--simple .c-entry-summary__figure, .tax-job_occupation .c-entries--simple .c-entry-summary__figure, .tax-job_term .c-entries--simple .c-entry-summary__figure {
    margin-right: 0;
  }
}
.post-type-archive-job .c-entries--simple .c-entries__item > a, .tax-job_area .c-entries--simple .c-entries__item > a, .tax-job_occupation .c-entries--simple .c-entries__item > a, .tax-job_term .c-entries--simple .c-entries__item > a {
  padding: 0;
}
.post-type-archive-job .c-entry-summary__body a, .tax-job_area .c-entry-summary__body a, .tax-job_occupation .c-entry-summary__body a, .tax-job_term .c-entry-summary__body a {
  text-decoration: none;
  color: #333;
}
.post-type-archive-job .c-entry-summary__body, .tax-job_area .c-entry-summary__body, .tax-job_occupation .c-entry-summary__body, .tax-job_term .c-entry-summary__body {
  padding-left: 2rem;
  border-left: 1px solid #EEE;
  width: 100%;
}
@media print, screen and (max-width: 1023px) {
  .post-type-archive-job .c-entry-summary__body, .tax-job_area .c-entry-summary__body, .tax-job_occupation .c-entry-summary__body, .tax-job_term .c-entry-summary__body {
    margin-top: 1rem;
    padding: 0 1rem;
    border-left: none;
  }
}
.post-type-archive-job .container_job_detail, .tax-job_area .container_job_detail, .tax-job_occupation .container_job_detail, .tax-job_term .container_job_detail {
  margin-left: 1rem;
  font-size: 0.9rem;
  max-width: 60%;
}
@media print, screen and (max-width: 639px) {
  .post-type-archive-job .container_job_detail, .tax-job_area .container_job_detail, .tax-job_occupation .container_job_detail, .tax-job_term .container_job_detail {
    margin-left: 0;
  }
}
.post-type-archive-job .container_button, .tax-job_area .container_button, .tax-job_occupation .container_button, .tax-job_term .container_button {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 10px;
  margin-top: -90px;
}
@media print, screen and (max-width: 1023px) {
  .post-type-archive-job .container_button, .tax-job_area .container_button, .tax-job_occupation .container_button, .tax-job_term .container_button {
    margin-top: 10px;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.post-type-archive-job .container_button a:first-child, .tax-job_area .container_button a:first-child, .tax-job_occupation .container_button a:first-child, .tax-job_term .container_button a:first-child {
  display: none;
}
.post-type-archive-job .details-btn, .tax-job_area .details-btn, .tax-job_occupation .details-btn, .tax-job_term .details-btn {
  font-size: 15px;
  color: #006d80 !important;
  width: 150px;
  background: #fff;
  border: 2px solid #006d80;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 37px;
  height: 48px;
  font-weight: 700;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  letter-spacing: 0.08rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.post-type-archive-job .details-btn:hover, .tax-job_area .details-btn:hover, .tax-job_occupation .details-btn:hover, .tax-job_term .details-btn:hover {
  -webkit-filter: drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.16));
}
.post-type-archive-job .apply-btn, .tax-job_area .apply-btn, .tax-job_occupation .apply-btn, .tax-job_term .apply-btn {
  font-size: 15px;
  color: #fff !important;
  width: 150px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 47px;
  height: 48px;
  letter-spacing: 0.15rem;
  font-weight: 700;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-image: -webkit-gradient(linear, right top, left top, color-stop(1%, #2d92a4), color-stop(51%, #0a798d), to(#006d80));
  background-image: -webkit-linear-gradient(right, #2d92a4 1%, #0a798d 51%, #006d80);
  background-image: linear-gradient(270deg, #2d92a4 1%, #0a798d 51%, #006d80);
  margin-bottom: 4px;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media print, screen and (max-width: 639px) {
  .post-type-archive-job .apply-btn, .tax-job_area .apply-btn, .tax-job_occupation .apply-btn, .tax-job_term .apply-btn {
    margin-bottom: 0;
  }
}
.post-type-archive-job .apply-btn:hover, .tax-job_area .apply-btn:hover, .tax-job_occupation .apply-btn:hover, .tax-job_term .apply-btn:hover {
  -webkit-filter: drop-shadow(0px 2px 2px rgba(0, 109, 128, 0.585));
          filter: drop-shadow(0px 2px 2px rgba(0, 109, 128, 0.585));
}

.home .c-section:first-child {
  padding-top: 0;
}

.job_station {
  font-size: 0.8rem;
}

@media (min-width: 1024px) {
  .c-entries {
    --entries--item-width: 25%;
  }
}
@media print, screen and (max-width: 1023px) {
  .flex_top_about {
    gap: 8px !important;
  }
}

@media print, screen and (max-width: 1023px) {
  p.p_top_about_right {
    width: 100%;
    text-align: right;
  }
}

@media print, screen and (max-width: 1023px) {
  .smb-buttons.is-content-justification-right {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.section_job_post .c-entry-summary__figure > img {
  -o-object-fit: contain;
     object-fit: contain;
  background-color: #ffffff;
}

.post-type-archive-entrance ul {
  list-style: none;
}
.post-type-archive-entrance ul a {
  font-weight: bold;
}
.post-type-archive-entrance .fx-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-content: stretch;
      -ms-flex-line-pack: stretch;
          align-content: stretch;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media print, screen and (max-width: 1023px) {
  .post-type-archive-entrance ul.fx-box.box3.wrap.entrancelist-ul {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.post-type-archive-entrance .wrap {
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
.post-type-archive-entrance .box3 {
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.post-type-archive-entrance .content-box .mb40, .post-type-archive-entrance .post .mb40, .post-type-archive-entrance .mb40 {
  margin-bottom: 4em;
}
.post-type-archive-entrance .fx-box.box3 {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.post-type-archive-entrance #content .entrancelist-ul {
  list-style: disc;
  color: #999;
}
.post-type-archive-entrance #content .entrancelist-ul li {
  margin-bottom: 0.5rem;
  text-indent: 0;
  padding-left: 0;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 28%;
      -ms-flex: 0 0 28%;
          flex: 0 0 28%;
  margin-right: 2em;
}
.post-type-archive-entrance #content ul li {
  margin-bottom: 0.5rem;
  text-indent: -1.5em;
  padding-left: 1.5em;
}
.post-type-archive-entrance .fx-box.box3 li {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 30%;
      -ms-flex: 0 0 30%;
          flex: 0 0 30%;
}
.post-type-archive-entrance #content .entrance-ul {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.post-type-archive-entrance #content .entrance-ul li {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 20%;
      -ms-flex: 0 0 20%;
          flex: 0 0 20%;
  line-height: 2.8rem;
}
@media print, screen and (max-width: 1023px) {
  .post-type-archive-entrance #content .entrance-ul li {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
    line-height: 1.5rem;
  }
}
.post-type-archive-entrance #content .entrance-ul li:before {
  content: "▶︎";
  font-weight: bold;
  padding-right: 0.5rem;
  color: var(--accent-color);
}
.post-type-archive-entrance h3 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  color: var(--accent-color);
  font-size: 1.2rem;
}
.post-type-archive-entrance h3 span.linktop a {
  font-size: 1rem;
  text-decoration: none;
  color: var(--accent-color);
}
.post-type-archive-entrance h3 span.linktop a::before {
  content: "▲";
  font-weight: 900;
  padding-right: 0.5rem;
  font-size: 1rem;
  vertical-align: text-bottom;
  line-height: 1rem;
}
.post-type-archive-entrance ul.entrance-ul.fx-box.wrap {
  padding-left: 0;
}

.entrance_append_content {
  max-width: var(--wp--custom--content-width);
  margin: 2rem auto;
  text-align: center;
  padding: 1.5rem;
  background-color: #f8f9fa;
  border-radius: 8px;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}
.entrance_append_content .button_entrance_line_container {
  margin-bottom: 1.5rem;
}
.entrance_append_content .button_entrance_line_container p {
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}
.entrance_append_content .button_entrance_client_container {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid #e0e0e0;
}
.entrance_append_content .button_entrance_client_container p {
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}

a.button_entrance_line {
  background-color: #64c463;
  color: white !important;
  padding: 0.8rem 2rem;
  border-radius: 4px;
  text-decoration: none;
  font-weight: 600;
  display: inline-block;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
  min-width: 200px;
}
a.button_entrance_line:hover {
  background-color: #44b143;
}
a.button_entrance_line span {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.5rem;
}

a.button_entrance_client {
  background-color: #0abab5;
  color: white !important;
  padding: 0.8rem 2rem;
  border-radius: 4px;
  text-decoration: none;
  font-weight: 600;
  display: inline-block;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
  min-width: 200px;
}
a.button_entrance_client:hover {
  background-color: #078a86;
}
a.button_entrance_client span {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.5rem;
}

.sp_menu_button_web {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.sp_menu_button_web::before {
  content: "＼来社不要／";
  font-size: 14px;
  font-weight: bold;
  color: #fff;
}
.sp_menu_button_web button {
  font-size: var(--_font-size);
  font-weight: bolder;
  background-color: #356b7f;
  border: 1px solid #fff;
  color: #fff;
  padding: 9.6px 19.2px;
  border-radius: 24px;
  min-width: 150px;
}

.sp_menu_button_neo {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.sp_menu_button_neo::before {
  content: "-登録済みの方-";
  font-size: 14px;
  font-weight: bold;
  color: #fff;
}
.sp_menu_button_neo button {
  font-size: var(--_font-size);
  font-weight: bolder;
  background-color: var(--_light-color-gray);
  color: #fff;
  padding: 9.6px 19.2px;
  border-radius: 24px;
  border: none;
  min-width: 150px;
}

@media screen and (max-width: 1140px) {
  .column_top_about {
    -webkit-flex-wrap: wrap !important;
        -ms-flex-wrap: wrap !important;
            flex-wrap: wrap !important;
  }
  .column_top_about .wp-block-column {
    -webkit-flex-basis: calc(50% - 1rem) !important;
        -ms-flex-preferred-size: calc(50% - 1rem) !important;
            flex-basis: calc(50% - 1rem) !important;
  }
}
.secton_top_news .c-entry-summary__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 10px;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (max-width: 639px) {
  .secton_top_news .c-entry-summary__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: left;
    -webkit-justify-content: left;
        -ms-flex-pack: left;
            justify-content: left;
    -webkit-box-align: start;
    -webkit-align-items: start;
        -ms-flex-align: start;
            align-items: start;
  }
}
.secton_top_news .c-entry-summary__meta {
  margin-top: 0;
}
.secton_top_news .c-entry-summary__term {
  color: var(--wp--preset--color--sm-accent);
  background-color: var(--wp--preset--color--white);
  width: 100px;
  text-align: center;
  border-radius: 50px;
  border: 1px solid var(--wp--preset--color--sm-accent);
}

@media print, screen and (max-width: 639px) {
  .wp-block-columns.column_top_voice {
    gap: 6px;
  }
}

.top_section_staff-voice .spider__arrow[data-direction=next]:before {
  border-right: 1px solid #333;
  border-top: 1px solid #333;
}
.top_section_staff-voice .spider__arrow[data-direction=prev]:before {
  border-bottom: 1px solid #333;
  border-left: 1px solid #333;
}
.top_section_staff-voice .spider__arrow[data-direction=prev] {
  left: -35px;
}
.top_section_staff-voice .spider__arrow[data-direction=next] {
  right: -35px;
}

.home .smb-box {
  position: relative;
  overflow: visible;
  margin-top: 24px !important;
}
.home .smb-box::before {
  content: "";
  position: absolute;
  top: -24px;
  left: 15%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 38px 38px;
  border-color: transparent transparent #fff transparent;
  z-index: 1;
}
.home .wp-block-columns.column_top_voice .wp-block-column {
  position: relative;
}
.home .wp-block-columns.column_top_voice .wp-block-column::before {
  content: "";
  position: absolute;
  top: -24px;
  left: 15%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 38px 38px;
  border-color: transparent transparent #fff transparent;
}
@media (max-width: 781px) {
  .home .wp-block-columns.column_top_voice .wp-block-column {
    -webkit-flex-basis: 45% !important;
        -ms-flex-preferred-size: 45% !important;
            flex-basis: 45% !important;
    padding: 10px;
    margin-bottom: 1.5rem;
  }
}
.home .single-staff-voice h1 {
  display: none;
}

.post-type-archive-staff-voice .c-entry-summary__figure > img {
  -o-object-fit: contain;
     object-fit: contain;
}
.post-type-archive-staff-voice .c-entry-summary__header {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
}
.post-type-archive-staff-voice .c-entry-summary__header::before {
  content: "";
  width: 2rem;
  height: 2rem;
  background-color: var(--accent-color);
  border-radius: 50%;
  display: block;
}

span.wpcf7-form-control.wpcf7-checkbox {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}/*# sourceMappingURL=style.css.map */