@charset "UTF-8";

/* CSS Document */
/* 共通 */
.bg {
  width: 91.67%;
  margin: 0 auto;
  background-image: url("../img/top/top_bg.png");
  background-position: top left;
  background-repeat: repeat;
  background-size: 1320px 1320px;
}

.content-ttl {
  font-size: 4.0rem;
  letter-spacing: 0.1em;
  font-weight: 700;
  text-align: center;
  background-color: #ffffff;
  padding: 10px 0;
  margin-bottom: 30px;
  -webkit-font-smoothing: antialiased;
}

/*---------------------------------------------------------------------
	お問いわせエリア
---------------------------------------------------------------------*/
.contact-content * {
  color: #ffffff;
}

.contact-content__box {
  padding: 30px 0 40px;
  border: solid 4px #ffffff;
  border-radius: 20px;
  background: #FF9A2A;
  background: linear-gradient(180deg, rgba(255, 154, 42, 1) 0%, rgba(255, 96, 36, 1) 100%);
}

.contact-content .inner {
  max-width: 840px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}

.contact-content__ttl {
  font-size: 3.0rem;
  text-align: center;
  margin-bottom: 30px;
  letter-spacing: 0.075em;
  position: relative;
}

.contact-content__ttl span {
  font-size: 4.2rem;
  letter-spacing: 0.12em;
}

.contact-content__ttl .contact-bg {
  width: 58px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

.contact-content p {
  margin-bottom: 40px;
}

.contact-btn {
  font-size: 2.4rem;
  background-color: #000000;
  display: block;
  width: 100%;
  height: 110px;
  border-radius: 200px;
}

.contact-btn span {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 30px;
  -webkit-font-smoothing: antialiased;
}

.contact-btn span::before {
  content: "";
  display: block;
  width: 35px;
  height: auto;
  aspect-ratio: 12 / 19;
  background-image: url("../img/common/contact_btn.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  margin-top: 3px;
}

.contact-content .contact-btn.btn-h::before {
  background-color: #ffffff;
}

@media (hover: hover) and (pointer: fine) {
  .contact-content .contact-btn.btn-h:hover span {
    color: #000000 !important;
  }
}

/*---------------------------------------------------------------------
	メインリード
---------------------------------------------------------------------*/
.main-lead-area {
  padding: 160px 20px 120px;
}

.main-lead-area .big {
  font-size: 3.0rem;
}

.main-lead-area p {
  line-height: 3;
}

.main-lead-area .serif {
  column-gap: 70px;
}

.main-lead-area .serif::before,
.main-lead-area .serif::after {
  content: "";
  display: block;
  width: 3px;
  height: 100px;
  background-color: #000000;
}

.main-lead-area .serif::before {
  -webkit-transform: rotate(-35deg);
  transform: rotate(-35deg);
}

.main-lead-area .serif::after {
  -webkit-transform: rotate(35deg);
  transform: rotate(35deg);
}

.main-lead {
  position: relative;
  max-width: 920px;
  width: 100%;
  margin: 0 auto 80px;
}

.main-lead .anim {
  position: absolute;
  top: 0;
  left: 0;
}

.main-lead .img-wrap {
  width: 100%;
}

/*---------------------------------------------------------------------
	心の声
---------------------------------------------------------------------*/
.employee {
  position: relative;
  padding-top: 40px;
  max-width: 1320px;
  margin: 0 auto;
}

.employee-ttl__img {
  position: absolute;
  aspect-ratio: 89 / 56;
  max-width: 890px;
  width: calc(890 / 1320 * 100%);
  height: auto;
  top: -130px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.employee-ttl-wrap {
  aspect-ratio: 4 / 3;
  max-width: 650px;
  width: calc(650 / 1320 * 100%);
  height: auto;
  background-image: url("../img/top/employee/h2_ttl.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  margin: 0 auto;
  overflow: hidden;
  z-index: 2;
  position: absolute;
  top: clamp(1px, 10.4vw, 150px);
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.employee-ttl-wrap p {
  width: 100%;
  text-align: center;
  top: calc(50% + clamp(1px, 4.8vw, 300px));
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  position: absolute;
  font-size: clamp(0.8rem, 1.1vw, 1.6rem);
}

.employee-ttl {
  text-indent: -9999px;
  position: relative;
  width: 100%;
  height: 100%;
}

.employee_item {
  position: relative;
}

/* 吹き出し 共通*/
.employee_item_fk {
  overflow: hidden;
}

.employee_item_fk p {
  position: relative;
  text-indent: -9999px;
}

.employee_item_fk {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  height: auto;
  position: relative;
  z-index: 2;
}

.employee_img {
  position: absolute;
  height: auto;
}

/* 黒吹き出しテキスト */
.bl-txt {
  color: #000000;
  background-color: #ff7300;
  padding: clamp(10px, 2.1vw, 40px) 40px;
  border: 6px solid #000;
  border-radius: 200px;
  max-width: 1120px;
  width: 90%;
  margin: 0 auto;
  font-size: clamp(0.8rem, 1.25vw, 1.8rem);
  letter-spacing: 0.075em;
  line-height: 2;
  position: relative;
  z-index: 2;
}

.bl-txt::before {
  content: "";
  display: block;
  width: 120px;
  height: 30px;
  clip-path: polygon(0 0, 22% 100%, 100% 100%);
  background-color: #000000;
  position: absolute;
  top: -30px;
}

.bl-txt.bl-txt-right::before {
  right: 60px;
}

.bl-txt.bl-txt-left::before {
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
  left: 60px;
}

/* ブロック1 */
.employee_wrap_01 {
  margin-bottom: 40px;
}

.employee_wrap_01 .employee_item_fk.fk-1 {
  aspect-ratio: 17 / 19;
  width: calc(340 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_01.png");
  left: 2.08%;
}

.employee_wrap_01 .employee_item_fk.fk-2 {
  aspect-ratio: 35 / 32;
  width: calc(350 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_02.png");
  right: 1.39%;
}

.employee_wrap_01 .employee_item_fk.fk-3 {
  aspect-ratio: 58 / 73;
  width: calc(290 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_03.png");
  margin-top: clamp(1px, 2.8vw, 40px);
  left: 1.04%;
}

.employee_wrap_01 .employee_item_fk.fk-4 {
  aspect-ratio: 35 / 24;
  width: calc(350 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_04.png");
  margin-top: clamp(1px, 13.9vw, 200px);
  left: 8.3%;
}

.employee_wrap_01 .employee_item_fk.fk-5 {
  aspect-ratio: 15 / 14;
  width: calc(300 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_05.png");
  right: 9.03%;
  margin-top: -30px;
}

.employee_wrap_01 .employee_img.img01 {
  aspect-ratio: 25 / 32;
  width: calc(300 / 1320 * 100%);
  bottom: -40px;
  left: 20%;
}

.employee_wrap_01 .employee_img.img02 {
  aspect-ratio: 195 / 163;
  width: calc(390 / 1320 * 100%);
  bottom: -40px;
  right: -10px;
}

/* 音 共通 */
.oto {
  position: absolute;
  height: auto !important;
}

.employee_wrap_01 .oto1 {
  width: calc(90 / 300 * 100%);
  top: calc(185 / 384 * 100%);
  left: calc(30 / 300 * 100%);
}

.employee_wrap_01 .oto2 {
  width: calc(84 / 390 * 100%);
  top: calc(50 / 326 * 100%);
  left: calc(90 / 390 * 100%);
  z-index: 2;
}

.employee_wrap_01 .oto3 {
  width: calc(69 / 390 * 100%);
  top: calc(200 / 326 * 100%);
  right: calc(100 / 390 * 100%);
}

/* ブロック2 */
.employee_wrap_02 {
  margin-bottom: 100px;
}

.employee_wrap_02 .employee_item_fk.fk-1 {
  aspect-ratio: 12 / 11;
  width: calc(360 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_06.png");
  left: 36%;
  margin-top: clamp(1px, 1.39vw, 20px);
}

.employee_wrap_02 .employee_item_fk.fk-2 {
  aspect-ratio: 150 / 167;
  width: calc(300 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_07.png");
  right: 2.1%;
}

.employee_wrap_02 .employee_item_fk.fk-3 {
  aspect-ratio: 31 / 30;
  width: calc(310 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_08.png");
  left: 1.4%;
}

.employee_wrap_02 .employee_item_fk.fk-4 {
  aspect-ratio: 75 / 77;
  width: calc(300 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_09.png");
  left: -12.5%;
  margin-top: clamp(1px, 4.17vw, 60px);
}

.employee_wrap_02 .employee_item_fk.fk-5 {
  aspect-ratio: 6 / 5;
  width: calc(360 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_10.png");
  right: 2.1%;
  margin-top: clamp(1px, 2.78vw, 40px);
}

.employee_wrap_02 .employee_img.img01 {
  aspect-ratio: 470 / 364;
  width: calc(470 / 1320 * 100%);
  top: 40px;
  left: 5%;
}

.employee_wrap_02 .employee_img.img01 .main {
  width: auto;
  margin-left: auto;
  height: 95%;
  margin-top: 5%;
}

.employee_wrap_02 .employee_img.img02 {
  aspect-ratio: 16 / 17;
  width: calc(480 / 1320 * 100%);
  bottom: -40px;
  right: 16%;
}

.employee_wrap_02 .oto1 {
  width: calc(38 / 470 * 100%);
  top: calc(55 / 364 * 100%);
  left: calc(30 / 470 * 100%);
}

/* ブロック3 */
.employee_wrap_03 {
  margin-bottom: 40px;
}

.employee_wrap_03 .employee_item_fk.fk-1 {
  aspect-ratio: 199 / 160;
  width: calc(398 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_11.png");
  left: 8.7%;
  margin-top: clamp(1px, 4.17vw, 60px);
}

.employee_wrap_03 .employee_item_fk.fk-2 {
  aspect-ratio: 75 / 88;
  width: calc(300 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_12.png");
  right: 20.8%;
}

.employee_wrap_03 .employee_item_fk.fk-3 {
  aspect-ratio: 30 / 31;
  width: calc(300 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_13.png");
  left: 3.48%;
}

.employee_wrap_03 .employee_item_fk.fk-4 {
  aspect-ratio: 19 / 17;
  width: calc(380 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_14.png");
  right: 4.17%;
}

.employee_wrap_03 .employee_img.img01 {
  aspect-ratio: 608 / 309;
  width: calc(608 / 1320 * 100%);
  top: -50px;
  left: 0;
}

.employee_wrap_03 .employee_img.img01 .main {
  width: auto;
  margin-right: auto;
}

.employee_wrap_03 .employee_img.img01 .oto1 {
  position: absolute;
  height: auto;
  right: 0;
  top: 100px;
  width: 14.6vw;
  max-width: 210px;
}

.employee_wrap_03 .employee_img.img02 {
  aspect-ratio: 11 / 12;
  width: calc(385 / 1320 * 100%);
  top: -140px;
  right: 0;
}

.employee_wrap_03 .employee_img.img03 {
  aspect-ratio: 425 / 600;
  width: calc(425 / 1320 * 100%);
  bottom: 20px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.employee_wrap_03 .employee_img.img03 .main {
  height: auto;
}

.employee_wrap_03 .employee_item_bottom {
  margin-top: -40px;
}

.employee_wrap_03 .oto1 {
  width: calc(74 / 385 * 100%);
  top: calc(64 / 420 * 100%);
  right: calc(95 / 385 * 100%);
}

.employee_wrap_03 .oto2 {
  width: calc(37 / 425 * 100%);
  top: calc(323 / 600 * 100%);
  left: calc(27 / 425 * 100%);
}

.employee_wrap_03 .oto3 {
  width: calc(37 / 425 * 100%);
  top: calc(367 / 600 * 100%);
  right: calc(10 / 425 * 100%);
}

/* ブロック4 */
.employee_wrap_04 .employee_item_fk.fk-1 {
  aspect-ratio: 175 / 138;
  width: calc(350 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_15.png");
  left: 2.1%;
  margin-top: clamp(1px, 2.78vw, 40px);
}

.employee_wrap_04 .employee_item_fk.fk-2 {
  aspect-ratio: 291 / 367;
  width: calc(291 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_16.png");
  left: 8.33%;
  margin-top: -30px;
  z-index: 1;
}

.employee_wrap_04 .employee_item_fk.fk-3 {
  aspect-ratio: 1 / 1;
  width: calc(350 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_17.png");
}

.employee_wrap_04 .employee_item_fk.fk-4 {
  aspect-ratio: 169 / 190;
  width: calc(337 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_18.png");
}

.employee_wrap_04 .employee_item_fk.fk-5 {
  aspect-ratio: 101 / 104;
  width: calc(303 / 1320 * 100%);
  background-image: url("../img/top/employee/fk_19.png");
  right: 30.6%;
}

.employee_wrap_04 .employee_img.img01 {
  aspect-ratio: 381 / 527;
  width: calc(381 / 1320 * 100%);
  top: 40px;
  left: 16.7%;
  z-index: 2;
}

.employee_wrap_04 .employee_img.img02 {
  aspect-ratio: 209 / 226;
  width: calc(418 / 1320 * 100%);
  bottom: 0;
  right: 2.78%;
}

.employee_wrap_04 .employee_img.img02 .main {
  width: auto;
  margin-left: auto;
  height: 95%;
  margin-top: 5%;
}

.employee_wrap_04 .oto1 {
  width: calc(32 / 418 * 100%);
  top: calc(80 / 452 * 100%);
  left: calc(125 / 418 * 100%);
}

/*---------------------------------------------------------------------
	福利厚生
---------------------------------------------------------------------*/
.benefit-item__wrap {
  column-gap: 32px;
  grid-row-gap: 32px;
}

.benefit-item {
  aspect-ratio: 1 / 1;
  max-width: 352px;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  padding: 20px 0;
}

.benefit-item__ttl {
  font-size: 2.6rem;
  font-weight: 700;
  text-align: center;
  height: 64px;
}

.benefit-item__ttl span {
  font-size: 1.4rem;
  font-weight: 400;
  display: block;
}

.benefit-item__img {
  margin-top: -5px;
}

.benefit-item__un {
  text-align: center;
  margin-top: -15px;
}

.benefit-item__un .number {
  font-family: var(--man);
  font-size: 11.1rem;
  font-weight: 700;
  color: var(--orange);
  line-height: 1;
  letter-spacing: -0.03em;
  vertical-align: sub;
}

.benefit-item__un .unit {
  font-size: 3.7rem;
  font-weight: 700;
  display: inline-block;
  margin-left: 10px;
}

/* 年間休日 */
.benefit-item.kyujitu .benefit-item__un {
  margin-top: -30px;
}

.benefit-item.kyujitu .number {
  margin-top: -10px;
  display: inline-block;
}

/*---------------------------------------------------------------------
	よくある質問
---------------------------------------------------------------------*/
.faq .inner {
  max-width: 1160px;
  padding: 0 20px;
}

.faq .accordion-area {
  width: 100%;
  margin: 0 auto;
  grid-row-gap: 24px;
}

.faq .accordion_box {
  position: relative;
}

/*　見出し */
.faq .title {
  cursor: pointer;
  width: 100%;
  padding: 20px 34px 20px 40px;
  background-color: #000000;
  color: #ffffff;
  position: relative;
  border-radius: 100px;
  transition: all var(--cubic);
  z-index: 2;
  letter-spacing: 0.05em;
  column-gap: 10px;
}

.faq .title .question {
  font-size: 1.8rem;
  font-weight: 700;
}

.faq .title .plus {
  display: inline-block;
  width: 40px;
  height: 40px;
  position: relative;
  transition: all var(--cubic);
  flex-shrink: 0;
}

.faq .title.close .plus {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.faq .title.close .plus::before {
  opacity: 0;
}

@media (hover: hover) and (pointer: fine) {
  .faq .title:hover .plus {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
  }
}

.faq .title .plus::before,
.faq .title .plus::after {
  content: "";
  display: inline-block;
  background-color: #ffffff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  opacity: 1;
  transition: all var(--cubic);
}

.faq .title .plus::before {
  width: 100%;
  height: 4px;
}

.faq .title .plus::after {
  width: 4px;
  height: 100%;
}

/*　中身 */
.faq .box {
  display: none;
  padding: 30px 34px 30px 40px;
  border-bottom-left-radius: 60px;
  border-bottom-right-radius: 60px;
}

.faq .box-inner {
  column-gap: 30px;
}

.faq .box-inner .qa {
  font-size: 6.0rem;
  width: 45px;
  text-align: right;
  flex-shrink: 0;
  font-family: var(--man);
  line-height: 1;
}

.faq .box-inner.answer .qa {
  color: var(--orange);
}

.faq .box .answer-txt {
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: 0.05em;
}

/*---------------------------------------------------------------------
	職種紹介
---------------------------------------------------------------------*/
.bg .sec:last-of-type {
  padding-bottom: 160px;
}

.job-wrap {
  column-gap: 30px;
}

.job-item * {
  color: #000000;
}

.job-item {
  width: calc(100%/3);
}

.job-item__img {
  aspect-ratio: 4 / 3;
  width: 100%;
  height: auto;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}

.job-item__img img {
  transition: transform var(--cubic);
}

.job-item__img::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--orange);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transition: all var(--cubic);
}

.job-item__ttl {
  font-size: 2.0rem;
  margin-bottom: 16px;
}

.job-item__txt {
  margin-top: auto;
  margin-bottom: 50px;
}

.job-item__btn {
  background-color: #ffffff;
  height: 60px;
  border-radius: 100px;
  position: relative;
  overflow: hidden;
}

.job-item__btn span {
  z-index: 2;
  position: relative;
}

.job-item__btn:before {
  content: '';
  width: 10px;
  height: 10px;
  border-top: solid 2px #000000;
  border-right: solid 2px #000000;
  position: absolute;
  left: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
  z-index: 2;
}

.job-item__btn::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: #000000;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform var(--cubic);
  border-radius: 100px;
}

@media (hover: hover) and (pointer: fine) {
  .job-item:hover .job-item__img::after {
    top: 8px;
    left: 8px;
  }

  .job-item:hover .job-item__img img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }

  .job-item:hover .job-item__btn::after {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    transform-origin: left top;
  }

  .job-item:hover .job-item__btn span {
    color: #ffffff;
  }

  .job-item:hover .job-item__btn::before {
    border-top: solid 2px #ffffff;
    border-right: solid 2px #ffffff;
  }
}

/*---------------------------------------------------------------------
	おしらせ
---------------------------------------------------------------------*/
.news {
  padding-top: 160px;
}

.news>.w-1120>.flex {
  border-top: 2px solid #FFFFFF;
  margin-bottom: 80px;
}

.news .content-ttl {
  width: 32%;
  text-align: left;
}

.news .newsList {
  width: 68%;
  border-top: rgba(0, 0, 0, 0.5) 1px solid;
}

.news .newsList>li {
  padding: 30px 0;
  border-bottom: rgba(0, 0, 0, 0.5) 1px solid;
}

.news .newsList li .date {
  width: 200px;
  letter-spacing: 0.1em;
}

.news .newsList li .txt {
  width: calc(100% - 200px);
}

/*---------------------------------------------------------------------

	SP

---------------------------------------------------------------------*/
@media screen and (max-width: 768px) {

  /* 共通 */
  .bg {
    width: 91.67%;
    margin: 0 auto;
    background-image: url("../img/top/top_bg.png");
    background-position: top left;
    background-repeat: repeat;
    background-size: 1320px 1320px;
  }

  .content-ttl {
    font-size: 2.8rem;
    padding: 10px 0;
    margin-bottom: 20px;
    letter-spacing: 0.02em;
  }

  /*---------------------------------------------------------------------
	お問いわせエリア
---------------------------------------------------------------------*/
  .contact-content {
    padding-right: 0;
    padding-left: 0;
  }

  .contact-content__box {
    padding: 50px 0;
    border-radius: 0;
    border-right: none;
    border-left: none;
  }

  .contact-content .inner {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
  }

  .contact-content__ttl .contact-bg {
    top: 20px;
  }

  .contact-btn {
    font-size: 1.8rem;
    height: 80px;
    max-width: 400px;
    margin: 0 auto;
  }

  .contact-btn span {
    column-gap: 40px;
  }

  .contact-btn span::before {
    width: 30px;
    margin-top: 3px;
  }

  /*---------------------------------------------------------------------
	メインリード
---------------------------------------------------------------------*/
  .main-lead-area {
    padding: 60px 30px 40px;
  }

  .main-lead-area .big {
    font-size: 2.4rem;
  }

  .main-lead-area p {
    margin: 0 auto;
    width: fit-content;
  }

  .main-lead-area .serif {
    column-gap: 0;
  }

  .main-lead-area .serif::before,
  .main-lead-area .serif::after {
    height: 50px;
  }

  .main-lead-area .serif::before {
    -webkit-transform: rotate(-35deg) translateY(50%) translateX(-20px);
    transform: rotate(-35deg) translateY(50%) translateX(-20px);
  }

  .main-lead-area .serif::after {
    -webkit-transform: rotate(35deg) translateY(50%) translateX(20px);
    transform: rotate(35deg) translateY(50%) translateX(20px);
  }

  .main-lead {
    margin: 0 auto 40px;
    max-width: 500px;
  }

  /*---------------------------------------------------------------------
	心の声
---------------------------------------------------------------------*/
  .employee {
    padding-top: 0;
    max-width: 500px;
    margin: 0 auto;
  }

  .employee-ttl__img {
    width: calc(510 / 343 * 100%);
    top: -40px;
    position: relative;
  }

  .employee-ttl-wrap {
    max-width: 110%;
    aspect-ratio: 1 / 1;
    width: calc(395 / 343 * 100%);
    background-image: url("../img/top/employee/h2_ttl_sp.png");
    top: auto;
    position: relative;
    -webkit-transform: translateX(0) translateY(0);
    transform: translateX(0) translateY(0);
    left: -5%;
    margin-top: -150px;
  }

  .employee_item {
    align-items: center;
  }

  .employee_img {
    position: relative;
  }

  /* 黒吹き出しテキスト */
  .bl-txt {
    padding: 24px;
    border-radius: 30px;
    font-size: 1.6rem;
    line-height: 1.7;
  }

  .bl-txt::before {
    width: 80px;
    height: 20px;
    top: -21px;
  }

  .bl-txt.bl-txt-right::before {
    right: 20px;
  }

  .bl-txt.bl-txt-left::before {
    left: 20px;
  }

  /* ブロック1 */
  .employee_wrap_01 {
    margin-bottom: 40px;
  }

  .employee_wrap_01 .employee_item_fk.fk-1 {
    max-width: 340px;
    width: calc(298 / 343 * 100%);
    left: auto;
    margin-left: auto;
    right: -20px;
    order: 2;
    margin-top: -120px;
  }

  .employee_wrap_01 .employee_item_fk.fk-2 {
    max-width: 350px;
    width: calc(300 / 343 * 100%);
    right: auto;
    margin-right: auto;
  }

  .employee_wrap_01 .employee_item_fk.fk-3 {
    max-width: 290px;
    width: calc(260 / 343 * 100%);
    left: auto;
    margin-left: auto;
    order: 2;
    margin-top: -60px;
  }

  .employee_wrap_01 .employee_item_fk.fk-4 {
    max-width: 350px;
    width: calc(311 / 343 * 100%);
    margin-top: -50px;
    left: auto;
    order: 5;
  }

  .employee_wrap_01 .employee_item_fk.fk-5 {
    max-width: 300px;
    width: calc(275 / 343 * 100%);
    right: auto;
    margin-right: auto;
    margin-top: -80px;
    order: 3;
  }

  .employee_wrap_01 .employee_img.img01 {
    max-width: 300px;
    width: calc(188 / 343 * 100%);
    bottom: auto;
    left: auto;
    order: 1;
    margin-right: auto;
    margin-top: -120px;
    z-index: 3;
  }

  .employee_wrap_01 .employee_img.img02 {
    max-width: 390px;
    width: calc(275 / 343 * 100%);
    bottom: auto;
    right: auto;
    order: 4;
    margin-left: auto;
    margin-top: -100px;
    z-index: 2;
  }

  .employee_wrap_01 .oto1 {
    width: calc(53 / 188 * 100%);
    top: calc(110 / 241 * 100%);
    left: calc(20 / 188 * 100%);
  }

  .employee_wrap_01 .oto2 {
    width: calc(46 / 275 * 100%);
    top: calc(55 / 230 * 100%);
    left: calc(90 / 275 * 100%);
    z-index: 2;
  }

  .employee_wrap_01 .oto3 {
    width: calc(38 / 275 * 100%);
    top: calc(127 / 230 * 100%);
    right: calc(60 / 275 * 100%);
  }

  /* ブロック2 */
  .employee_wrap_02 {
    margin-bottom: 0;
  }

  .employee_wrap_02 .employee_item_fk.fk-1 {
    max-width: 360px;
    width: calc(340 / 343 * 100%);
    left: auto;
    order: 2;
    margin-left: auto;
    right: -20px;
    margin-top: -80px;
  }

  .employee_wrap_02 .employee_item_fk.fk-2 {
    max-width: 300px;
    width: calc(274 / 343 * 100%);
    right: auto;
    order: 3;
    margin-right: auto;
    margin-top: -100px;
  }

  .employee_wrap_02 .employee_item_fk.fk-3 {
    max-width: 310px;
    width: calc(288 / 343 * 100%);
    left: auto;
    margin-left: auto;
    margin-top: -80px;
    order: -2;
  }

  .employee_wrap_02 .employee_item_fk.fk-4 {
    max-width: 300px;
    width: calc(246 / 343 * 100%);
    left: auto;
    margin-top: -80px;
    margin-right: auto;
  }

  .employee_wrap_02 .employee_item_fk.fk-5 {
    max-width: 360px;
    width: calc(307 / 343 * 100%);
    right: auto;
    margin-top: -40px;
    margin-left: auto;
  }

  .employee_wrap_02 .employee_img.img01 {
    max-width: 330px;
    aspect-ratio: 82 / 69;
    width: calc(308 / 343 * 100%);
    top: auto;
    left: auto;
    order: 1;
  }

  .employee_wrap_02 .employee_img.img02 {
    max-width: 480px;
    aspect-ratio: 370 / 339;
    width: calc(360 / 343 * 100%);
    bottom: auto;
    right: auto;
    order: -1;
    margin-top: 0;
  }

  .employee_wrap_02 .oto1 {
    width: calc(23 / 308 * 100%);
    top: calc(40 / 260 * 100%);
    left: 0;
  }

  /* ブロック3 */
  .employee_wrap_03 .employee_item_fk.fk-1 {
    max-width: 335px;
    width: calc(398 / 343 * 100%);
    left: auto;
    margin-left: auto;
    margin-top: -60px;
  }

  .employee_wrap_03 .employee_item_fk.fk-2 {
    max-width: 275px;
    background-image: url("../img/top/employee/fk_12_sp.png");
    width: calc(300 / 343 * 100%);
    right: auto;
    margin-right: auto;
    margin-top: -80px;
  }

  .employee_wrap_03 .employee_item_fk.fk-3 {
    max-width: 289px;
    width: calc(300 / 309 * 100%);
    left: auto;
    margin-top: 0;
  }

  .employee_wrap_03 .employee_item_fk.fk-4 {
    max-width: 360px;
    width: calc(380 / 343 * 100%);
    right: auto;
    order: 2;
    margin-top: -90px;
  }

  .employee_wrap_03 .employee_img.img01 {
    max-width: 380px;
    width: calc(370 / 343 * 100%);
    top: auto;
    left: auto;
    order: -1;
    margin-right: auto;
    margin-top: -20px;
  }

  .employee_wrap_03 .employee_img.img02 {
    max-width: 385px;
    width: calc(330 / 343 * 100%);
    top: auto;
    right: auto;
    margin-top: -100px;
    aspect-ratio: 1 / 1;
  }

  .employee_wrap_03 .employee_img.img02 .main {
    width: auto;
    margin-right: auto;
    height: 100%;
  }

  .employee_wrap_03 .employee_img.img03 {
    aspect-ratio: 356 / 395;
    max-width: 345px;
    width: calc(425 / 343 * 100%);
    bottom: auto;
    -webkit-transform: translateX(0);
    transform: translateX(0);
    margin-top: -50px;
    z-index: 2;
    left: -20px;
  }

  .employee_wrap_03 .employee_item_bottom {
    margin-top: -40px;
  }

  .employee_wrap_03 .oto1 {
    width: calc(53 / 330 * 100%);
    top: calc(90 / 330 * 100%);
    right: 0;
  }

  .employee_wrap_03 .oto2 {
    width: calc(27 / 345 * 100%);
    top: calc(130 / 382 * 100%);
    left: calc(60 / 345 * 100%);
  }

  .employee_wrap_03 .oto3 {
    width: calc(27 / 345 * 100%);
    top: calc(94 / 382 * 100%);
    right: calc(46 / 345 * 100%);
  }

  /* ブロック4 */
  .employee_wrap_04 .employee_item_fk.fk-1 {
    max-width: 350px;
    width: calc(310 / 343 * 100%);
    left: auto;
    margin-top: 0;
    order: 1;
    margin-right: auto;
  }

  .employee_wrap_04 .employee_item_fk.fk-2 {
    max-width: 291px;
    width: calc(275 / 343 * 100%);
    left: auto;
    z-index: 1;
    order: 4;
    margin-right: auto;
    margin-top: -60px;
  }

  .employee_wrap_04 .employee_item_fk.fk-3 {
    max-width: 350px;
    width: calc(310 / 343 * 100%);
    order: 3;
    margin-left: auto;
    margin-top: -100px;
    z-index: 3;
  }

  .employee_wrap_04 .employee_item_fk.fk-4 {
    max-width: 337px;
    width: calc(320 / 343 * 100%);
    margin-right: auto;
    margin-top: -40px;
    left: -20px;
  }

  .employee_wrap_04 .employee_item_fk.fk-5 {
    max-width: 303px;
    width: calc(260 / 343 * 100%);
    right: auto;
    order: 2;
    margin-left: auto;
    margin-top: -60px;
    z-index: 3;
  }

  .employee_wrap_04 .employee_img.img01 {
    max-width: 381px;
    aspect-ratio: 360 / 402;
    width: calc(350 / 343 * 100%);
    top: auto;
    left: auto;
    z-index: 2;
    order: 2;
    margin-right: auto;
    margin-top: -60px;
  }

  .employee_wrap_04 .employee_img.img02 {
    max-width: 418px;
    width: calc(315 / 343 * 100%);
    bottom: auto;
    margin-left: auto;
    margin-top: -100px;
    right: -10px;
    z-index: 2;
  }

  .employee_wrap_04 .oto1 {
    width: calc(24 / 315 * 100%);
    top: calc(100 / 341 * 100%);
    left: calc(65 / 315 * 100%);
  }

  /*---------------------------------------------------------------------
	福利厚生
---------------------------------------------------------------------*/
  .benefit .w-1120 {
    padding: 0 10px;
  }

  .benefit-item {
    width: calc(100% / 2 - 4px);
    padding: 10px 0;
  }

  .benefit-item__wrap {
    column-gap: 8px;
    grid-row-gap: 8px;
    justify-content: flex-start;
  }

  .benefit-item__ttl {
    font-size: clamp(1rem, 3.2vw, 2.6rem);
    height: calc(34 / 135 * 100%);
  }

  .benefit-item__ttl span {
    font-size: clamp(0.8rem, 2.67vw, 1.4rem);
  }

  .benefit-item__un {
    margin-top: -5px;
  }

  .benefit-item__un .number {
    font-size: clamp(1rem, 10.67vw, 11.1rem);
    letter-spacing: -0.05em;
  }

  .benefit-item__un .unit {
    font-size: clamp(1rem, 4vw, 3.7rem);
    margin-left: 4px;
  }

  /* 賞与 */
  .benefit-item.syoyo .benefit-item__un {
    margin-top: -30px;
  }

  .benefit-item.syoyo .benefit-item__un:last-of-type {
    margin-top: -10px;
  }

  .benefit-item.syoyo .un-ttl {
    font-size: clamp(1rem, 5.3vw, 2.2rem);
  }

  .benefit-item.syoyo .number {
    font-size: clamp(1rem, 15.47vw, 6.7rem);
  }

  .benefit-item.syoyo .unit {
    font-size: clamp(1rem, 5.3vw, 2.2rem);
    margin-left: 5px;
  }

  /* 年間休日 */
  .benefit-item.kyujitu .benefit-item__un {
    margin-top: -10px;
  }

  .benefit-item.kyujitu .number {
    margin-top: 0;
  }

  .benefit-item.kyujitu p {
    font-size: clamp(0.6rem, 2.13vw, 1.4rem);
    letter-spacing: -0.03em;
  }

  /*---------------------------------------------------------------------
	よくある質問
---------------------------------------------------------------------*/
  .faq .inner {
    padding: 0;
  }

  .faq .accordion-area {
    grid-row-gap: 10px;
  }

  /*　見出し */
  .faq .title {
    padding: 20px 16px;
    border-radius: 30px;
  }

  .faq .title.close {
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
  }

  .faq .title .question {
    font-size: 1.4rem;
  }

  .faq .title .plus {
    width: 30px;
    height: 30px;
  }

  /*　中身 */
  .faq .box {
    padding: 20px;
  }

  .faq .box-inner {
    column-gap: 16px;
  }

  .faq .box-inner .qa {
    font-size: clamp(1rem, 10.67vw, 6.0rem);
    max-width: 45px;
    width: 8vw;
  }

  .faq .box .answer-txt {
    font-size: 1.4rem;
  }

  /*---------------------------------------------------------------------
	職種紹介
---------------------------------------------------------------------*/
  .bg .sec:last-of-type {
    padding-bottom: 80px;
  }

  .job-wrap {
    grid-row-gap: 40px;
    flex-direction: column;
  }

  .job-item {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }

  .job-item__ttl {
    font-size: 1.8rem;
  }

  .job-item__txt {
    margin-bottom: 30px;
  }

  .job-item__btn span {
    font-size: 1.6rem;
  }

  /*---------------------------------------------------------------------
	おしらせ
---------------------------------------------------------------------*/
  .news {
    padding-top: 40px;
  }

  .news>.w-1120>.flex {
    margin-bottom: 40px;
  }

  .news .content-ttl {
    width: 100%;
    text-align: center;
  }

  .news .newsList {
    width: 100%;
  }

  .news .newsList>li {
    padding: 24px 0;
    grid-row-gap: 6px;
  }

  .news .newsList li .date {
    width: 100%;
  }

  .news .newsList li .txt {
    width: 100%;
  }
}

@media screen and (max-width: 374px) {
  .benefit-item {
    min-height: 80vw;
  }
}

.blur {
  animation-fill-mode: forwards;
  -webkit-filter: blur(10px);
  -moz-filter: blur(10px);
  -ms-filter: blur(10px);
  -o-filter: blur(10px);
  filter: blur(10px);
  will-change: filter;
  transition: 2s ease-out;
  opacity: 0;
}

.blur.action {
  -webkit-filter: blur(0px);
  -moz-filter: blur(0px);
  -ms-filter: blur(0px);
  -o-filter: blur(0px);
  filter: blur(0px);
  will-change: filter;
  opacity: 1;
}

@media screen and (max-width: 768px) {
  .blur {
    animation-fill-mode: forwards;
    -webkit-filter: blur(10px);
    -moz-filter: blur(10px);
    -ms-filter: blur(10px);
    -o-filter: blur(10px);
    filter: blur(10px);
    will-change: filter;
    transition: 1.4s ease-out;
    opacity: 0;
  }
}

.gata {
  opacity: 0;
}

.gata.action {
  animation: glitch 0.2s ease;
  animation-iteration-count: 3;
  opacity: 1;
  transition: opacity 0.5s;
}

@keyframes glitch {
  0% {
    -webkit-transform: translate(0);
    transform: translate(0);
  }

  12.5% {
    -webkit-transform: translate(-3px, 1px);
    transform: translate(-3px, 1px);
  }

  37.5% {
    -webkit-transform: translate(-3px, -1px);
    transform: translate(-3px, -1px);
  }

  62.5% {
    -webkit-transform: translate(3px, 1px);
    transform: translate(3px, 1px);
  }

  87.5% {
    -webkit-transform: translate(3px, -1px);
    transform: translate(3px, -1px);
  }

  100% {
    -webkit-transform: translate(0);
    transform: translate(0);
  }
}

.bouncing,
.kuru1 {
  animation: bounce 1.2s ease infinite;
}

.bouncing2,
.kuru2 {
  animation: bounce 1.2s 0.4s ease infinite;
}

@keyframes bounce {
  0% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  70% {
    -webkit-transform: translateY(5px);
    transform: translateY(5px);
  }

  90% {
    -webkit-transform: translateY(5px);
    transform: translateY(5px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

.slidein {
  animation: slidein 2.5s ease-out infinite;
}

@keyframes slidein {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-40px);
    transform: translateY(-40px);
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

.kati {
  animation: kati 1.8s ease infinite;
}

@keyframes kati {
  0% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg);
  }

  100% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
}