@charset "utf-8";

/*
 * よく使うパーツ用スタイルシート float
 */

input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
  padding: 10px;
  width: 100%;
  font-size: 18px;
  font-family: inherit;
  border: solid 1px #ccc;
  border-radius: 6px;
  background: #f9f9f9;
  box-shadow: 0 0 6px rgba(0,0,0,0.06) inset;
}

input[type="text"]:focus,
input[type="tel"]:focus,
input[type="email"]:focus,
textarea:focus {
  background: #fff;
}

input[type="submit"] {
  display: table;
  margin-right: auto;
  margin-left: auto;
  padding: 10px 20px;
  color: #fff;
  font-size: 18px;
  font-weight: 800;
  font-family: inherit;
  cursor: pointer;
  background: #004F92;
  border: none;
  border-radius: 3px;
}

hr {
  height: 0;
  border: none;
  border-bottom: solid 2px #BFBFBF;
}

.nallow {
  margin-right: auto;
  margin-left: auto;
  padding-right: 10px;
  padding-left: 10px;
  max-width: 1220px;
}

.nallow-700 , body.page .nallow.nallow-700  { max-width: 720px; }
.nallow-800 , body.page .nallow.nallow-800  { max-width: 820px; }
.nallow-900 , body.page .nallow.nallow-900  { max-width: 920px; }
.nallow-1000, body.page .nallow.nallow-1000 { max-width: 1020px; }
.nallow-1060, body.page .nallow.nallow-1060 { max-width: 1080px; }
.nallow-1100, body.page .nallow.nallow-1100 { max-width: 1120px; }
.nallow-1200, body.page .nallow.nallow-1200 { max-width: 1220px; }
.nallow-1300, body.page .nallow.nallow-1300 { max-width: 1320px; }
.nallow-1400, body.page .nallow.nallow-1400 { max-width: 1420px; }
.nallow-1500, body.page .nallow.nallow-1500 { max-width: 1520px; }
.nallow-1600, body.page .nallow.nallow-1600 { max-width: 1620px; }
.nallow-1700, body.page .nallow.nallow-1700 { max-width: 1720px; }
.nallow-1800, body.page .nallow.nallow-1800 { max-width: 1820px; }

.inner {
  padding-right: 30px;
  padding-left: 30px;
}

.box-border { border: solid 1px #B7B7B7; }
.box-border-blue { border: solid 1px #85A1BF; }
.box-border-brown-b { border: solid 7px #9D8C6F; }
.box-fill { background: #fff; }
.box-fill-grey { background: #F7F7F7; }

.oflow {
  overflow: hidden;
}

.cf:after {
  content: "";
  display: block;
  clear: both;
}

.ta-c {
  text-align: center;
}

.ta-c-pc {
  text-align: center;
}

.ta-r {
  text-align: right;
}

.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.alignright {
  float: right;
  display: inline;
  margin-left: 40px;
}

.alignleft {
  float: left;
  display: inline;
  margin-right: 40px;
}

.only-sp {
  display: none;
}

.flex-row {
  display: flex;
}

.flex-row.wrap { flex-wrap: wrap; }
.flex-row.jc-c { justify-content: center; }
.flex-row.jc-sb { justify-content: space-between; }
.flex-row.jc-fe { justify-content: flex-end; }
.flex-row.ai-c { align-items: center; }
.flex-row.ai-fe { align-items: flex-end; }

.heading-section-bi {
  margin-bottom: 24px;
  position: relative;
  text-align: center;
  /*mix-blend-mode: difference;*/
}

.heading-section-bi span {
  display: block;
}

.heading-section-bi .jp {
  margin-bottom: 4px;
  font-size: 48px;
  font-weight: 600;
  color: #007790;
  letter-spacing: 0.04em;
}

.heading-section-bi .jp:before {
  content: '';
  display: block;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 20px;
  width: 56px;
  height: 9px;
  background: #7AC8CB;
}

.heading-section-bi .en {
  font-size: 24px;
  color: #969CA2;
}

.heading-quotation {
  display: flex;
  justify-content: center;
  color: #FE8400;
  font-size: 30px;
  font-weight: 800;
}

.heading-quotation:before {
  content: '';
  display: block;
  margin-right: 10px;
  width: 19px;
  height: 16px;
  background: url(../../img/online_recruit/concept_dt_1.png) no-repeat;
  background-size: contain;
}

.heading-quotation:after {
  content: '';
  display: block;
  margin-left: 10px;
  width: 19px;
  height: 16px;
  background: url(../../img/online_recruit/concept_dt_2.png) no-repeat;
  background-size: contain;
}

.entry-button {
  display: table;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.entry-button a {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 10px;
  padding: 0.7em 1em;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 34px;
  background: #FEBE30;
  border-radius: 8px;
}

.entry-button a:before {
  content: '';
  display: block;
  margin-right: 0.8em;
  width: 1.5em;
  height: 1em;
  background: 50% url(../../img/online_recruit/contact_icon.png) no-repeat;
  background-size: contain;
}

.entry-button a:after {
  content: '';
  display: block;
  margin-left: 0.8em;
  width: 0.7em;
  height: 1em;
  background: 50% url(../../img/online_recruit/contact_dt.png) no-repeat;
  background-size: contain;
}

.link-popup a {
  position: relative;
  display: table;
  margin-right: auto;
  margin-left: auto;
  padding: 2px 30px;
  text-align: center;
  color: #fff;
  background: #7AC8CB top 50% right 8px url(../../img/online_recruit/ah_dt.png) no-repeat;
  transition: 0.1s;
}

.link-popup a:hover {
  opacity: 0.8;
}

.link-form {
  display: inline-block;
  padding-left: 34px;
  color: #FE8400;
  text-decoration: underline;
  background: left url(../../img/online_recruit/flow_img_1.png) no-repeat;
}

.link-more a,
a.link-more,
a .link-more {
  position: relative;
  display: table;
  margin-right: auto;
  margin-left: auto;
  padding: 2px 30px;
  text-align: center;
  color: #fff;
  background: #7AC8CB top 50% right 8px url(../../img/online_recruit/ah_dt.png) no-repeat;
  transition: 0.1s;
}

.link-more a:hover,
a.link-more:hover,
a:hover .link-more {
  opacity: 0.8;
}

table.ta-c th,
table.ta-c td {
  text-align: center;
}

table.va-c th,
table.va-c td,
table th.va-c,
table td.va-c {
  vertical-align: middle;
}

hr.bd {
  display: block;
  height: 0;
  border: none;
  border-bottom: dashed #ddd 1px;
}

.pd-10 { padding: 10px; }
.pd-20 { padding: 20px; }
.pd-30 { padding: 30px; }
.pd-40 { padding: 40px; }

.mt-10 { margin-top: 10px; }
.mt-20 { margin-top: 20px; }
.mt-30 { margin-top: 30px; }
.mt-40 { margin-top: 40px; }
.mt-50 { margin-top: 50px; }
.mt-60 { margin-top: 60px; }
.mt-70 { margin-top: 70px; }
.mt-80 { margin-top: 80px; }
.mt-100 { margin-top: 100px; }
.mt-120 { margin-top: 120px; }
.mt-140 { margin-top: 140px; }

.mb-10, body.page *.mb-10 { margin-bottom: 10px; }
.mb-20, body.page *.mb-20 { margin-bottom: 20px; }
.mb-30, body.page *.mb-30 { margin-bottom: 30px; }
.mb-40, body.page *.mb-40 { margin-bottom: 40px; }
.mb-50, body.page *.mb-50 { margin-bottom: 50px; }
.mb-60, body.page *.mb-60 { margin-bottom: 60px; }
.mb-70, body.page *.mb-70 { margin-bottom: 70px; }
.mb-80, body.page *.mb-80 { margin-bottom: 80px; }
.mb-100, *body.page .mb-100 { margin-bottom: 100px; }
.mb-120, *body.page .mb-120 { margin-bottom: 120px; }
.mb-140, *body.page .mb-140 { margin-bottom: 140px; }

.mr-0 { margin-right: 0px; }

.pt-10 { padding-top: 10px; }
.pt-20 { padding-top: 20px; }
.pt-30 { padding-top: 30px; }
.pt-40 { padding-top: 40px; }
.pt-50 { padding-top: 50px; }
.pt-60 { padding-top: 60px; }
.pt-70 { padding-top: 70px; }
.pt-80 { padding-top: 80px; }
.pt-100 { padding-top: 100px; }
.pt-120 { padding-top: 120px; }
.pt-140 { padding-top: 140px; }

.pb-10 { padding-bottom: 10px; }
.pb-20 { padding-bottom: 20px; }
.pb-30 { padding-bottom: 30px; }
.pb-40 { padding-bottom: 40px; }
.pb-50 { padding-bottom: 50px; }
.pb-60 { padding-bottom: 60px; }
.pb-70 { padding-bottom: 70px; }
.pb-80 { padding-bottom: 80px; }
.pb-100 { padding-bottom: 100px; }
.pb-120 { padding-bottom: 120px; }
.pb-140 { padding-bottom: 140px; }

.lh-14 { line-height: 1.4; }
.lh-16 { line-height: 1.6; }
.lh-18 { line-height: 1.8; }
.lh-20 { line-height: 2.0; }
.lh-22 { line-height: 2.2; }
.lh-24 { line-height: 2.4; }

.ls-4 { letter-spacing: 0.04em; }
.ls-6 { letter-spacing: 0.06em; }
.ls-8 { letter-spacing: 0.08em; }
.ls-10 { letter-spacing: 0.1em; }
.ls-16 { letter-spacing: 0.16em; }
.ls-20 { letter-spacing: 0.2em; }
.ls-m4 { letter-spacing: -0.04em; }
.ls-m6 { letter-spacing: -0.06em; }
.ls-m8 { letter-spacing: -0.08em; }
.ls-m10 { letter-spacing: -0.1em; }
.ls-m16 { letter-spacing: -0.16em; }
.ls-m20 { letter-spacing: -0.2em; }

.tx-indent { padding-left: 1em; }

.fc-black { color: #000; }
.fc-grey { color: #AEAEAE; }
.fc-red { color: #F03540; }
.fc-pink { color: #FF6C87; }
.fc-pink-d { color: #E41B5B; }
.fc-blue { color: #0C437F; }
.fc-green { color: #0F99A1; }
.fc-yellow { color: #FFFF00; }
.fc-orange { color: #FFA000; }
.fc-orange-d { color: #ED7900; }
.fc-brown { color: #846300; }
.fc-brown-d { color: #513300; }

.fw-normal { font-weight: 400; }
.fw-bold { font-weight: 800; }

.ff-serif { font-family: 'Yu Mincho', YuMincho, serif; }

.fs-12 { font-size: 12px;}
.fs-14 { font-size: 14px;}
.fs-16 { font-size: 16px;}
.fs-18 { font-size: 18px;}
.fs-20 { font-size: 20px;}
.fs-22 { font-size: 22px;}
.fs-24 { font-size: 24px;}
.fs-26 { font-size: 26px;}
.fs-28 { font-size: 28px;}
.fs-30 { font-size: 30px;}
.fs-32 { font-size: 32px;}
.fs-34 { font-size: 34px;}
.fs-36 { font-size: 36px;}
.fs-38 { font-size: 38px;}
.fs-40 { font-size: 40px;}
.fs-42 { font-size: 42px;}
.fs-44 { font-size: 44px;}
.fs-46 { font-size: 46px;}
.fs-48 { font-size: 48px;}
.fs-50 { font-size: 50px;}
.fs-52 { font-size: 52px;}
.fs-54 { font-size: 54px;}
.fs-56 { font-size: 56px;}
.fs-58 { font-size: 58px;}
.fs-60 { font-size: 60px;}
.fs-62 { font-size: 62px;}
.fs-64 { font-size: 64px;}
.fs-66 { font-size: 66px;}
.fs-68 { font-size: 68px;}
.fs-70 { font-size: 70px;}
.fs-72 { font-size: 72px;}
.fs-74 { font-size: 74px;}
.fs-76 { font-size: 76px;}
.fs-78 { font-size: 78px;}
.fs-80 { font-size: 80px;}
.fs-82 { font-size: 82px;}
.fs-84 { font-size: 84px;}
.fs-86 { font-size: 86px;}
.fs-88 { font-size: 88px;}
.fs-90 { font-size: 90px;}
.fs-92 { font-size: 92px;}
.fs-94 { font-size: 94px;}
.fs-96 { font-size: 96px;}
.fs-98 { font-size: 98px;}
.fs-100 { font-size: 100px;}

section.bg,
body.page section:nth-child(even) {
  background-color: #F2FCF9;
}

section.bg-l {
  position: relative;
  background-position: left center;
  background-repeat: no-repeat;
  background-size: auto 100%;
}

section.bg-r {
  position: relative;
  background-position: right center;
  background-repeat: no-repeat;
  background-size: auto 100%;
}

section.bg-l-t {
  position: relative;
  background-position: left top;
  background-repeat: no-repeat;
}

section.bg-r-t {
  position: relative;
  background-position: right top;
  background-repeat: no-repeat;
}

section.bg-l:before,
section.bg-r:before,
section.bg-l-t:before,
section.bg-r-t:before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
}

section.bg-l:before, section.bg-l-t:before { background: linear-gradient(to left, rgba(255, 255, 255, 0.8) 720px, rgba(255, 255, 255, 0.5) 1140px, rgba(255, 255, 255, 0) 1480px); }
section.bg-r:before, section.bg-r-t:before { background: linear-gradient(to right, rgba(255, 255, 255, 0.8) 720px, rgba(255, 255, 255, 0.5) 1140px, rgba(255, 255, 255, 0) 1480px); }

section:nth-child(even).bg-l:before, section:nth-child(even).bg-l-t:before { background: linear-gradient(to left, rgba(243, 243, 243, 0.8) 720px, rgba(243, 243, 243, 0.5) 1140px, rgba(243, 243, 243, 0) 1480px); }
section:nth-child(even).bg-r:before, section:nth-child(even).bg-r-t:before { background: linear-gradient(to right, rgba(243, 243, 243, 0.8) 720px, rgba(243, 243, 243, 0.5) 1140px, rgba(243, 243, 243, 0) 1480px); }

section.bg-l > *,
section.bg-r > *,
section.bg-l-t > *,
section.bg-r-t > * {
  position: relative;
  z-index: 1;
}

.video-youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.video-youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

