/* variable */ :root {
    --base-color: #50b39a;
    --dark-gray: #00061e;
    --medium-gray: #515151;
    --aluminium-gray: rgba(255, 255, 255, 0.6);
}
/* reset */
body {
    font-size: 16px;
    font-weight: 500;
    line-height: 30px;
}
a:hover {
    color: var(--dark-gray);
}
h1, .h1 {
    font-size: 3.275rem;
    line-height: 4.175rem;
}
h2, .h2 {
    font-size: 2.813rem;
    line-height: 4.15rem;
}
h3, .h3 {
    font-size: 2.413rem;
    line-height: 3.125rem;
}
h4, .h4 {
    font-size: 2.013rem;
    line-height: 2.625rem;
}
h5, .h5 {
    font-size: 1.45rem;
    line-height: 2.2rem;
}
h5, .h5 {
    font-size: 1.45rem;
    line-height: 2.2rem;
}
h6, .h6 {
    font-size: 1.15rem;
    line-height: 2rem;
}
.lead {
    font-size: 1.08rem;
    font-weight: 700;
    line-height: 2.15rem;
    color: #00061e;
}
.heading-1 {
    color: #fff;
    background-color: #50b39a;
    padding: 12px;
    border-radius: 4px;
}
footer .footer-logo img {
    max-height: 42px;
}
.copy {
    font-family: var(--alt-font) !important;
    font-size: 14px;
    letter-spacing: 1px;
}
/* bg color */
.bg-gradient-emerald-blue-emerald-green {
    background-image: linear-gradient(50deg, #004098 0, #19e089 100%);
}
.bg-gradient-black-green {
    background-image: linear-gradient(to right top, #1f2021, #1b1d1c, #1b1d1c, #222523, #333c37);
}
.bg-gradient-sherpa-blue-black {
    background-image: linear-gradient(to right top, #23248C, #22236D, #232348, #222226, #232323);
}
.bg-entry {
    background-color: #fdf9ed;
}
.bg-faq {
    background-color: #ffd17a;
}
/* header */
.navbar .navbar-nav .nav-link {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 1px;
}
.navbar .navbar-nav .dropdown.open .dropdown-menu {
    background-color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    font-size: 17px;
    font-weight: 500;
    color: var(--white);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
header .navbar-brand img {
    max-height: 44px;
}
.header-top-bar div > a {
    color: var(--light-gray);
}
.header-top-bar div > a:hover {
    color: var(--white);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a i {
    font-size: 30px;
}
.navbar .navbar-nav .dropdown .dropdown-menu a i {
    width: 35px;
}
header .btn.btn-small {
    font-size: 15px;
    padding: 10px 18px;
}
/* btn */
.btn.btn-hover-animation-switch.btn-link {
    padding-top: 0;
}
.btn {
    text-transform: inherit;
    font-weight: 600;
    letter-spacing: 0;
}
.btn.btn-extra-large {
    font-size: 16px;
    padding: 16px 32px;
}
.btn.btn-large {
    font-size: 17px;
    padding: 14px 28px;
}
.btn.btn-medium {
    font-size: 16px;
    padding: 12px 24px;
}
.btn.btn-small {
    font-size: 15px;
}
.btn.btn-very-small {
    font-size: 14px;
    padding: 9px 20px;
}
/* counter style */
.counter-style-04 .vertical-counter:after {
    color: var(--base-color);
}
.review-star-icon i {
    color: var(--base-color);
}
.google-maps-link a:hover {
    color: var(--white);
}
/* page title */
.page-title-double-large h1 {
    font-size: 3.875rem;
    line-height: 4.688rem;
}
.page-title-double-large h2 {
    font-size: 16px;
    line-height: 28px;
}
/* top bottom left right class */
.right-12 {
    right: 12%;
}
.bg-jungle-green {
    background-color: #2ebb79;
}
/* Outside box */
.outside-box-top-205px {
    margin-top: -205px;
}
/* Transparent background color */
.bg-gradient-gray-light-dark-transparent {
    background-image: linear-gradient(to top, #f7f7f7 0%, transparent 100%);
}
/* etc */
.bg-earth {
    width: 320px;
}
.slide-logo {
    width: 320px;
}
.icons-about {
    width: 100px;
}
.text-about-blue {
    color: #13afd3;
}
.faq {
    width: 620px;
}
/* table */
table {
    border-collapse: collapse;
    width: 100%;
}
.custom-1 {
    border-collapse: collapse;
    table-layout: fixed;
    width: 100%;
    background: #fff;
    border: none;
}
.custom-1 th {
	color: #00061e;
    font-weight: 600;
    background: #eee;;
}
.custom-1 th, .custom-1 td {
    display: block;
    width: 100%;
    border: none;
    padding: 6px 15px;
    vertical-align: top;
    text-align: left;
    box-sizing: border-box;
    border-radius: 4px;
}
@media screen and (min-width: 768px) {
    .custom-1 th, .custom-1 td {
        display: table-cell;
        border-bottom: 1px solid #E6E6E6;
        background: #fff;
    }
    .custom-1 th {
        color: #00061e;
        background: #fff;
        letter-spacing: 1px;
        vertical-align: middle;
        text-align: center;
    }
    .custom-1 tr th:first-child {
        width: 34%;
    }
}
@media (max-width: 1399px) {
    .xl-h-180px {
        height: 180px;
    }
    .xl-w-180px {
        width: 180px;
    }
}
@media (max-width: 1199px) {
    .outside-box-top-200px {
        margin-top: -150px;
    }
}
@media (max-width: 991px) {
    .outside-box-top-200px {
        margin-top: 0;
    }
    .navbar .navbar-nav .dropdown.open .dropdown-menu {
        padding-bottom: 15px;
    }
    .navbar .navbar-nav .dropdown .dropdown-menu.show {
        background-color: var(--dark-gray);
    }
}
@media (max-width: 767px) {
    body {
        font-size: 15px;
    }
    h1, .h1 {
        font-size: 2.975rem;
        line-height: 4.075rem;
    }
    h2, .h2 {
        font-size: 2.538rem;
        line-height: 3.538rem;
    }
    h3, .h3 {
        font-size: 2.213rem;
        line-height: 3.225rem;
    }
    h4 {
        font-size: 1.965rem;
        line-height: 2.65rem;
    }
    h5 {
        font-size: 1.585rem;
        line-height: 2.185rem;
    }
    h6, .h6 {
        font-size: 1.45rem;
    }
    p {
        margin-bottom: 20px;
    }
    .page-title-double-large h1 {
        font-size: 2.875rem;
        line-height: 3.888rem;
    }
    .lead {
        font-size: 1.35rem;
    }
    .bg-earth {
        width: 200px;
    }
    .faq {
        width: 260px;
    }
}



/* =============================================================
   中央鐵骨 採用エントリーフォーム スタイル
   ─ すべて eform- プレフィックスで Litho と干渉しない独立クラス
   テーマの style.css 末尾、または「外観 > カスタマイズ > 追加CSS」に貼り付け
   ============================================================= */


/* ----- カラートークン（このフォーム内でのみ使用） ----- */
.wpcf7-form {
  --eform-navy:    #0a2a5e;
  --eform-navy-d:  #061e45;
  --eform-ink:     #1a1a1a;
  --eform-sub:     #6b7280;
  --eform-line:    #e5e7eb;
  --eform-bg-soft: #fafbfc;
  --eform-req:     #c53030;
}


/* ===== 1. CF7 自動挿入の <p> / <br> 余白を抑制 ===== */
.wpcf7-form > p {
  margin: 0;
  padding: 0;
}
.wpcf7-form > br {
  display: none;
}


/* ===== 2. 上部の必須案内 ===== */
.eform-note {
  max-width: 860px;
  margin: 0 auto 30px;
  font-size: 13px;
  text-align: center;
  color: var(--eform-sub);
  letter-spacing: 0.04em;
}


/* ===== 3. 必須・任意 バッジ ===== */
.eform-req-pill,
.eform-opt-pill {
  display: inline-block;
  padding: 3px 8px;
  margin: 0 4px !important;
  font-size: 10px;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: #fff;
  border-radius: 2px;
  vertical-align: middle;
}
.eform-req-pill { background: var(--eform-req); }
.eform-opt-pill { background: var(--eform-sub); }


/* ===== 4. セクション見出し（01 応募内容 など） ===== */
.eform-section {
  max-width: 860px;
  margin: 70px auto 0;
  display: flex;
  align-items: center;
  gap: 16px;
}
.eform-section-num {
  font-family: 'Cormorant Garamond', 'Times New Roman', serif;
  font-size: 28px;
  font-weight: 500;
  color: var(--eform-navy);
  letter-spacing: 0.05em;
  line-height: 1;
}
.eform-section-ttl {
  font-size: 16px;
  font-weight: 700;
  color: var(--eform-navy);
  letter-spacing: 0.1em;
}
.eform-section-line {
  flex: 1;
  height: 1px;
  background: var(--eform-line);
}


/* ===== 5. フォーム グループラッパー ===== */
.eform-wrap {
  max-width: 860px;
  margin: 20px auto 0;
}


/* ===== 6. フォーム行（ラベル240px / 入力 1fr） ===== */
.eform-row {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 30px;
  padding: 24px 0;
  border-bottom: 1px solid var(--eform-line);
  align-items: start;
}
.eform-row:first-of-type {
  border-top: 1px solid var(--eform-line);
}
.eform-row p {
	margin-bottom: 0;
}
.eform-row br {
	display: none;
}

/* ===== 7. ラベル ===== */
.eform-label {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 12px;
  font-size: 14px;
  font-weight: 700;
  color: var(--eform-ink);
  letter-spacing: 0.05em;
}
.eform-label .eform-req-pill,
.eform-label .eform-opt-pill {
  margin: 0;
}


/* ===== 8. 入力フィールド共通 ===== */
.eform-input {
  width: 100%;
  padding: 12px 16px;
  font-family: inherit;
  font-size: 14px;
  line-height: 1.6;
  color: var(--eform-ink);
  background: #fff;
  border: 1px solid var(--eform-line);
  border-radius: 2px;
  box-sizing: border-box;
  box-shadow: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.eform-input:focus {
  outline: none;
  border-color: var(--eform-navy);
  box-shadow: 0 0 0 3px rgba(10, 42, 94, 0.08);
}
textarea.eform-input {
  min-height: 140px;
  line-height: 1.8;
  resize: vertical;
}
textarea.eform-input.eform-textarea-lg {
  min-height: 200px;
}
/* ===== プレースホルダー ===== */
.eform-input::placeholder,
.eform-select::placeholder {
  color: #b0b3b8;
  opacity: 0.3; /* Firefox はデフォルトで opacity: 0.54 になるので明示 */
}

/* ===== 9. セレクト（応募職種など） ===== */
.eform-select {
  width: 100%;
  padding: 12px 40px 12px 16px;
  font-family: inherit;
  font-size: 14px;
  color: var(--eform-ink);
  background-color: #fff;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%230a2a5e' stroke-width='1.5' fill='none'/></svg>");
  background-repeat: no-repeat;
  background-position: right 16px center;
  border: 1px solid var(--eform-line);
  border-radius: 2px;
  -webkit-appearance: none;
          appearance: none;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.eform-select:focus {
  outline: none;
  border-color: var(--eform-navy);
  box-shadow: 0 0 0 3px rgba(10, 42, 94, 0.08);
}


/* ===== 10. 日付入力 ===== */
.eform-input.eform-date {
  max-width: 220px;
}


/* ===== 11. 郵便番号 + 住所の複合入力 ===== */
.eform-address {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.eform-postal {
  display: flex;
  align-items: center;
  gap: 8px;
  max-width: 280px;
}
.eform-postal-prefix {
  flex-shrink: 0;
  font-size: 13px;
  color: var(--eform-sub);
}
.eform-postal .wpcf7-form-control-wrap {
  flex: 1;
  display: block;
}


/* ===== 12. ヘルプテキスト ===== */
.eform-help {
  display: block;
  margin-top: 8px;
  font-size: 11px;
  color: var(--eform-sub);
  letter-spacing: 0.03em;
}


/* ===== 13. ラジオボタン（カード型） ===== */
.eform-radio-group .wpcf7-form-control-wrap {
  display: block;
}
.eform-radio-group .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  margin: 0;
  padding-top: 8px;
}
.eform-radio-group .wpcf7-list-item {
  margin: 0;
  padding: 0;
}
.eform-radio-group .wpcf7-list-item label {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 500;
  color: var(--eform-ink);
  background: #fff;
  border: 1px solid var(--eform-line);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.eform-radio-group .wpcf7-list-item label:hover {
  border-color: var(--eform-navy);
}
.eform-radio-group .wpcf7-list-item input[type="radio"] {
  width: 16px;
  height: 16px;
  margin: 0;
  flex-shrink: 0;
  accent-color: var(--eform-navy);
}
/* チェック中（古いブラウザ向けフォールバック） */
.eform-radio-group .wpcf7-list-item input[type="radio"]:checked + .wpcf7-list-item-label {
  color: var(--eform-navy);
  font-weight: 700;
}
/* チェック中のカード全体（モダンブラウザ） */
.eform-radio-group .wpcf7-list-item label:has(input:checked) {
  border-color: var(--eform-navy);
  background: #f8f9fa;
  color: var(--eform-navy);
  font-weight: 700;
}


/* ===== 14. ファイル添付（履歴書・職務経歴書） ===== */
.eform-file {
  padding: 28px 20px;
  text-align: center;
  background: var(--eform-bg-soft);
  border: 2px dashed var(--eform-line);
  border-radius: 4px;
  transition: all 0.2s;
}
.eform-file:hover {
  border-color: var(--eform-navy);
  background: #fff;
}
.eform-file .wpcf7-form-control-wrap {
  display: block;
}
.eform-file input[type="file"] {
  display: inline-block;
  font-size: 13px;
  color: var(--eform-ink);
  background: transparent;
  border: 0;
  cursor: pointer;
}
/* ファイル選択ボタン（モダンブラウザ） */
.eform-file input[type="file"]::file-selector-button {
  margin-right: 12px;
  padding: 10px 24px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--eform-navy);
  background: #fff;
  border: 1.5px solid var(--eform-navy);
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.2s;
}
.eform-file input[type="file"]::file-selector-button:hover {
  background: var(--eform-navy);
  color: #fff;
}
.eform-file-hint {
  margin-top: 12px;
  font-size: 11px;
  color: var(--eform-sub);
  letter-spacing: 0.05em;
}


/* ===== 15. 個人情報同意 ===== */
.eform-privacy {
  margin: 50px 0 0;
  padding: 30px;
  background: var(--eform-bg-soft);
  border: 1px solid var(--eform-line);
}
.eform-policy-box {
  max-height: 160px;
  overflow-y: auto;
  margin-bottom: 20px;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--eform-line);
  font-size: 12px;
  line-height: 1.8;
  color: var(--eform-sub);
}
.eform-acceptance {
  text-align: center;
}
.eform-acceptance .wpcf7-acceptance {
  display: block;
}
.eform-acceptance .wpcf7-list-item {
  margin: 0;
  padding: 0;
}
.eform-acceptance .wpcf7-list-item label {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--eform-ink);
  cursor: pointer;
}
.eform-acceptance .wpcf7-list-item input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  flex-shrink: 0;
  accent-color: var(--eform-navy);
}


/* ===== 16. 送信ボタン ===== */
.eform-submit-area {
  margin: 60px 0 0;
  text-align: center;
}
input.eform-submit,
button.eform-submit {
  display: inline-block;
  min-width: 320px;
  padding: 20px 60px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.25em;
  color: #fff;
  background: var(--eform-navy);
  border: 1.5px solid var(--eform-navy);
  border-radius: 0;
  cursor: pointer;
  -webkit-appearance: none;
          appearance: none;
  transition: all 0.25s ease;
}
input.eform-submit:hover,
button.eform-submit:hover {
  background: var(--eform-navy-d);
  border-color: var(--eform-navy-d);
}
.eform-submit-note {
  margin-top: 16px;
  font-size: 11px;
  color: var(--eform-sub);
  letter-spacing: 0.05em;
}


/* ===== 17. CF7 バリデーション ===== */
.wpcf7-form .eform-input.wpcf7-not-valid,
.wpcf7-form .eform-select.wpcf7-not-valid {
  border-color: var(--eform-req);
}
.wpcf7-form .wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: var(--eform-req);
  letter-spacing: 0.04em;
}
.wpcf7-form .wpcf7-response-output {
  margin: 30px auto 0;
  max-width: 860px;
  padding: 14px 20px;
  font-size: 13px;
  text-align: center;
  border-radius: 2px;
}
.wpcf7-form .wpcf7-spinner {
  margin-left: 12px;
  vertical-align: middle;
}


/* ===== 18. レスポンシブ ===== */
@media (max-width: 768px) {
  .eform-section {
    margin-top: 50px;
    padding: 0 5px;
  }
  .eform-section-num {
    font-size: 24px;
  }
  .eform-row {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 20px 0;
  }
  .eform-label {
    padding-top: 0;
  }
  .eform-privacy {
    padding: 20px;
  }
  input.eform-submit,
  button.eform-submit {
    min-width: 100%;
    padding: 18px 30px;
  }
}


/* ===== 確認モード時：入力欄を読み取り専用らしく ===== */
.wpcf7-form .eform-input[readonly],
.wpcf7-form .eform-input[disabled],
.wpcf7-form .eform-select[disabled] {
  background: var(--eform-bg-soft);
  color: var(--eform-ink);
  border-color: var(--eform-line);
  cursor: default;
  box-shadow: none;
}

/* Confirm Plus が生成する「戻る」ボタン */
.wpcf7-form .wpcf7c-btn-back,
.wpcf7-form input[type="button"].wpcf7c-elm-step1 {
  display: inline-block;
  min-width: 200px;
  padding: 18px 40px;
  margin-right: 16px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--eform-ink);
  background: #fff;
  border: 1.5px solid var(--eform-line);
  border-radius: 0;
  cursor: pointer;
  -webkit-appearance: none;
          appearance: none;
  transition: all 0.25s ease;
}
.wpcf7-form .wpcf7c-btn-back:hover {
  border-color: var(--eform-ink);
}

@media (max-width: 575.98px) {
  .wpcf7-form .wpcf7c-btn-back {
    display: block;
    width: 100%;
    margin: 0 0 12px 0;
  }
}

/* ===== 確認・戻るボタン（Confirm Plus） ===== */

/* 「修正する」ボタン */
input.eform-back,
button.eform-back {
  display: inline-block;
  min-width: 200px;
  padding: 20px 40px;
  margin-right: 16px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--eform-ink);
  background: #fff;
  border: 1.5px solid var(--eform-line);
  border-radius: 0;
  cursor: pointer;
  -webkit-appearance: none;
          appearance: none;
  transition: all 0.25s ease;
}
input.eform-back:hover,
button.eform-back:hover {
  border-color: var(--eform-ink);
}

/* 「入力内容を確認する」ボタン */
input.eform-confirm,
button.eform-confirm {
  display: inline-block;
  min-width: 320px;
  padding: 20px 60px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.25em;
  color: #fff;
  background: var(--eform-navy);
  border: 1.5px solid var(--eform-navy);
  border-radius: 0;
  cursor: pointer;
  -webkit-appearance: none;
          appearance: none;
  transition: all 0.25s ease;
}
input.eform-confirm:hover,
button.eform-confirm:hover {
  background: var(--eform-navy-d);
  border-color: var(--eform-navy-d);
}

/* 確認モード時：入力欄を読み取り専用らしく */
.wpcf7-form .eform-input[readonly],
.wpcf7-form .eform-input[disabled],
.wpcf7-form .eform-select[disabled] {
  background: var(--eform-bg-soft);
  color: var(--eform-ink);
  border-color: var(--eform-line);
  cursor: default;
  box-shadow: none;
}
.wpcf7-form .eform-input[readonly]:focus,
.wpcf7-form .eform-input[disabled]:focus,
.wpcf7-form .eform-select[disabled]:focus {
  border-color: var(--eform-line);
  box-shadow: none;
}

/* スマホで戻る・送信を縦並びに */
@media (max-width: 575.98px) {
  input.eform-back,
  button.eform-back,
  input.eform-confirm,
  button.eform-confirm {
    display: block;
    width: 100%;
    min-width: 0;
    margin: 0 0 12px 0;
  }
}