@charset "UTF-8";
/*-----------------------------------------------------
	top
-----------------------------------------------------*/
/*common
-----------------------------------------------------*/
.dn{
    display: none;
}
.gjs-dashed .dn{
    display: block;
}


.top-section-head {
  margin-bottom: 40px;
  color: #fff;
}
.top-section-head .head-en {
  font-family: var(--font-en);
  font-weight: 900;
  font-size: 4rem;
  letter-spacing: 0.05em;
}
.top-section-head .head-jp {
  font-size: 1.2rem;
}

@media screen and (min-width: 768px) {
  .top-section-head {
    margin-bottom: 80px;
  }
  .top-section-head .head-en {
    font-size: 6rem;
  }
  .top-section-head .head-jp {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 1200px) {
  .top-section-head {
    margin-bottom: 120px;
  }
  .top-section-head .head-en {
    font-size: 8rem;
  }
  .top-section-head .head-jp {
    font-size: 1.8rem;
  }
}
/*MV
-----------------------------------------------------*/
.top-mv-right {
  margin-left: auto;
  width: 80vw;
}
.top-mv-right .slick-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: end;
  gap: 10px;
}
.top-mv-right .slick-dots button {
  color: #999;
  font-size: 1.2rem;
  font-family: var(--font-en);
  font-weight: 900;
  border: 0;
  background: 0;
}
.top-mv-right .slick-dots .slick-active button {
  color: var(--black);
}

.top-mv-left {
  position: relative;
  margin-left: 5vw;
  margin-top: -9rem;
  z-index: 1;
}

.top-mv-head .head-wrap {
  padding-inline: 5px;
}

.top-mv-head .head {
  font-family: var(--font-en);
  font-weight: 900;
  font-size: 6rem;
  line-height: 1;
  letter-spacing: 0.05em;
  /* background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(0%, #fff));
  background: linear-gradient(transparent 0%, #fff 0%); */
  text-shadow: 0 0 10px #fff;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.top-mv-lead {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  margin-top: 10px;
  font-size: 1.2rem;
}
.top-mv-lead .catch {
  padding-inline: 5px;
  border: 1px solid var(--black);
}
.top-mv-lead .company {
  font-family: var(--font-en);
  font-weight: 700;
}

.top-mv-img {
  display: none;
}

@media screen and (min-width: 768px) {
  .top-mv {
    padding: 0 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    gap: 10%;
  }
  .top-mv-right {
    position: relative;
    margin-left: 0;
    width: 50%;
  }
  .top-mv-right .slick-dots {
    position: absolute;
    left: -2em;
    bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 5px;
  }
  .top-mv-left {
    margin-top: 20px;
    margin-left: 0;
    padding-left: 5vw;
    width: 40%;
  }
  .top-mv-head .head {
    font-size: min(7.5vw, 160px);
    background: transparent;
  }
  .top-mv-lead {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 20px;
    margin-top: 45px;
    font-size: min(1.5vw, 18px);
  }
  .top-mv-lead .catch {
    padding-inline: 10px;
  }
}
@media screen and (min-width: 1024px) {
  .top-mv-img {
    display: block;
    margin: 60px auto 0;
    width: 60%;
  }
}
/* top-strengths
-----------------------------------------------------*/
.top-strengths .head {
  font-size: 2.2rem;
  line-height: 1.6;
  font-weight: 600;
}
.top-strengths .txt-lead {
  margin-top: 20px;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}
.top-strengths .media-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  margin-top: 30px;
  margin-inline: calc(50% - 50vw);
}

@media screen and (min-width: 768px) {
  .top-strengths {
    padding-bottom: 20px;
    background-image: url(/system_panel/uploads/images/top_strengths_bg.png);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 60% auto;
  }
  .top-strengths .head {
    font-size: min(3vw, 4rem);
  }
  .top-strengths .txt-lead {
    margin-top: 40px;
    font-size: min(2vw, 2.4rem);
  }
  .top-strengths .media-img {
    gap: 20px;
    margin-inline: 0;
    margin-top: 0;
  }
}
@media screen and (min-width: 1200px) {
  .top-strengths {
    padding-top: calc(var(--pc-mgt) + 80px);
  }
}
/* top-service
-----------------------------------------------------*/
.top-service {
  position: relative;
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}
.top-service .service-item {
  margin-top: 20px;
  padding: 30px 20px;
  border: 1px solid #fff;
}
.top-service .service-lists {
  padding: 20px;
  font-weight: 500;
  background: #666;
}

@media screen and (min-width: 768px) {
  .top-service {
    margin-top: var(--pc-mgt);
    padding-bottom: var(--pc-mgt);
  }
  .top-service .service-item {
    margin-top: 60px;
    padding: 40px;
  }
}
@media screen and (min-width: 1200px) {
  .top-service .service-item {
    margin-top: 160px;
    padding: 70px;
  }
  .top-service .service-head {
    margin-bottom: 40px;
  }
  .top-service .service-head .head-jp {
    font-size: 3.6rem;
  }
  .top-service .service-head .head-en {
    font-size: 1.6rem;
  }
  .top-service .media-img {
    margin-top: -140px;
  }
}
/* top-recruit
-----------------------------------------------------*/
.top-recruit .top-section-head {
  color: var(--black);
}
.top-recruit .recruit-block {
  position: relative;
  padding-bottom: var(--sp-mgt);
}
.top-recruit .recruit-block:before {
  position: absolute;
  bottom: 0;
  left: calc(50% - 50vw);
  content: "";
  width: 100vw;
  height: 80%;
  background: var(--light-blue);
  z-index: -1;
}
.top-recruit .recruit-content {
  margin-top: 30px;
}
.top-recruit .recruit-content .head {
  margin-bottom: 15px;
  font-weight: 600;
  font-size: 2rem;
}

@media screen and (min-width: 768px) {
  .top-recruit .recruit-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 40px;
    margin-top: 60px;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: end;
  }
  .top-recruit .recruit-content .head {
    margin-bottom: 30px;
    font-size: 2.4rem;
  }
  .top-recruit .recruit-info {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
  .top-recruit .recruit-btn {
    width: min(40%, 330px);
  }
  .top-recruit .txt-lead {
    font-weight: 500;
  }
}
@media screen and (min-width: 1200px) {
  .top-recruit .recruit-img {
    margin-left: calc(30% - 30vw);
    margin-right: calc(50% - 50vw);
  }
}
/* top-info
-----------------------------------------------------*/
.top-info .top-section-head {
  margin-bottom: 0;
}
.top-info .info-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
.top-info .info-head {
  width: 90px;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
.top-info .top-section-head {
  color: var(--black);
}
.top-info .info-content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.top-info .info-content .info-article-lists {
  margin-top: 0;
}

@media screen and (min-width: 768px) {
  .top-info .info-head .head-en {
    font-size: 3rem;
  }
}
@media screen and (min-width: 1200px) {
  .top-info .info-head {
    width: 140px;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
  .top-info .info-head .head-en {
    font-size: 5rem;
  }
}
/* top-about
-----------------------------------------------------*/
.top-about {
  margin-top: var(--sp-mgt);
  padding-block: var(--sp-mgt);
  background-image: url(/system_panel/uploads/images/top_about_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
}
.top-about .about-menu {
  border-top: 1px solid #fff;
}
.top-about .about-item {
  position: relative;
  border-bottom: 1px solid #fff;
}
.top-about .about-item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding-block: 20px;
  padding-right: 35px;
  color: #fff;
}
.top-about .about-item a:hover {
  text-decoration: none;
}
.top-about .about-item:before, .top-about .about-item:after {
  content: "";
  position: absolute;
  -webkit-transform-origin: calc(100% - 2px) 50%;
  transform-origin: calc(100% - 2px) 50%;
  transition: all .3s;
}
.top-about .about-item:before {
  top: calc(50% - 1px);
  right: 5px;
  width: 25px;
  height: 1px;
  background-color: #fff;
}
.top-about .about-item:after {
  width: 7px;
  height: 7px;
  top: calc(50% - 3px);
  right: 6px;
  border: 1.5px solid;
  border-color: #fff #fff transparent transparent;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.top-about .about-item:hover:before{
  right: 0;
  transition: all .3s;
}
.top-about .about-item:hover:after{
  right: 1px;
  transition: all .3s;
}
.top-about .item-en {
  font-family: var(--font-en);
  font-weight: 900;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
}
.top-about .item-jp {
  font-weight: 600;
}

@media screen and (min-width: 768px) {
  .top-about {
    padding-block: var(--pc-mgt);
  }
}
@media screen and (min-width: 1024px) {
  .top-about {
    margin-top: var(--pc-mgt);
  }
  .top-about .about-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .top-about .about-item a {
    padding-block: 30px;
    padding-right: 45px;
  }
  .top-about .about-head {
    width: 40%;
  }
  .top-about .about-content {
    width: 45%;
    margin-top: 20px;
  }
}
@media screen and (min-width: 1200px) {
  .top-about .about-block {
    gap: 80px;
  }
  .top-about .about-content {
    margin-top: 40px;
  }
  .top-about .item-en {
    font-size: 2.4rem;
  }
  .top-about .item-jp {
    font-size: 1.8rem;
  }
}
/*-----------------------------------------------------
	about us
-----------------------------------------------------*/
/*会社概要
-----------------------------------------------------*/
.company-area .media-img {
  margin-top: 30px;
}

@media screen and (min-width: 768px) {
  .company-area .media-block {
    display: block;
  }
  .company-area .media-content {
    width: 100%;
  }
  .company-area .media-img {
    margin-inline: auto;
    width: 80%;
  }
}
@media screen and (min-width: 1024px) {
  .company-area .media-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 4%;
  }
  .company-area .media-content {
    width: 48%;
  }
  .company-area .media-img {
    margin-top: 0;
    margin-inline: 0;
    width: auto;
  }
}
/*代表挨拶
-----------------------------------------------------*/
.greeting-area {
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}

.greeting-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
.greeting-block .media-img {
  margin-left: auto;
  margin-bottom: 10px;
  width: min(80%, 200px);
}
.greeting-block .media-content p + p {
  margin-top: 1em;
}

@media screen and (min-width: 768px) {
  .greeting-area {
    margin-top: var(--pc-mgt);
    padding-bottom: var(--pc-mgt);
  }
  .greeting-block .media-content {
    width: 60%;
  }
}
@media screen and (min-width: 1024px) {
  .greeting-block {
    gap: 80px;
  }
}
/*アクセス
-----------------------------------------------------*/
.access-map {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 75%;
}
.access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media screen and (min-width: 768px) {
  .access-map {
    padding-top: 50%;
  }
}
/*-----------------------------------------------------
	当社の強み
-----------------------------------------------------*/
.strengths-item {
  margin-top: 40px;
  padding-bottom: 20px;
}
.strengths-item:before {
  top: auto;
  bottom: 0;
  height: 90%;
}

.strengths-num {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-family: var(--font-en);
  line-height: 1;
  letter-spacing: 0.05em;
}
.strengths-num .txt {
  padding: 3px 10px;
  font-size: 1.2rem;
  font-weight: 700;
  border: 1px solid #fff;
}
.strengths-num .num {
  font-size: 4rem;
  font-weight: 900;
}

.strengths-head {
  margin-top: 10px;
}
.strengths-head .head-jp {
  font-size: 2.3rem;
  font-weight: 600;
  line-height: 1.8;
}
.strengths-head strong {
  font-weight: 700;
}

.strengths-info {
  margin-top: 25px;
  padding: 20px;
}
.strengths-info.blue {
  background: #368fc6;
}
.strengths-info.black {
  background: #666;
}

@media screen and (min-width: 414px) {
  .strengths-head strong br {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .strengths-item {
    margin-top: 60px;
    padding-block: 60px;
  }
  .strengths-item:before {
    height: 100%;
  }
  .strengths-head strong br {
    display: block;
  }
}
@media screen and (min-width: 1024px) {
  .strengths-item {
    padding-block: 60px;
  }
  .strengths-item:before {
    height: 100%;
  }
  .strengths-num .txt {
    font-size: 1.6rem;
  }
  .strengths-num .num {
    font-size: 6rem;
  }
  .strengths-head {
    margin-top: 30px;
  }
  .strengths-head .head-jp {
    font-size: 2.8rem;
  }
  .strengths-head strong br {
    display: none;
  }

  .strengths-info {
    margin-top: 35px;
    padding: 20px 30px;
  }
}
@media screen and (min-width: 1400px) {
  .strengths-item {
    margin-top: var(--pc-mgt);
    padding-block: 90px 10px;
  }
  .strengths-item:before {
    top: 0;
    bottom: auto;
    height: min(90%, 640px);
  }
}
/*-----------------------------------------------------
	service
-----------------------------------------------------*/
/*サービス内容
-----------------------------------------------------*/
.service-area {
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}
.service-area .service-item {
  margin-bottom: 60px;
}
.service-area .service-item:last-child {
  margin-bottom: 0;
}
.service-area .service-item .list-disc + p {
  margin-top: 1.5em;
}
.service-area .media-img {
  position: relative;
}
.service-area .catch {
  position: absolute;
  bottom: 0;
  right: 0;
  font-family: var(--font-en);
  font-weight: 900;
  font-size: 3.5rem;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #fff;
  opacity: 0.25;
  white-space: nowrap;
  -webkit-transform: translateY(50%);
  transform: translateY(50%);
}

.service-img-lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
}
.service-img-lists .service-img-item {
  width: calc((100% - 10px) / 3);
}

@media screen and (min-width: 768px) {
  .service-area {
    margin-top: var(--pc-mgt);
    padding-bottom: var(--pc-mgt);
  }
  .service-area .service-item {
    margin-bottom: 100px;
  }
  .service-area .catch {
    font-size: 6rem;
  }
  .service-area .media-content {
    width: 40%;
  }
  .service-img-lists {
    gap: 20px;
    margin-top: 80px;
  }
  .service-img-lists .service-img-item {
    width: calc((100% - 40px) / 3);
  }
}
@media screen and (min-width: 1024px) {
  .service-area .catch {
    font-size: 10rem;
  }
}
/*選ばれる理由
-----------------------------------------------------*/
.reason-area .reason-lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 30px;
}
.reason-area .reason-content {
  margin-top: 5px;
  font-size: 2rem;
  text-align: center;
  font-weight: 600;
}

@media screen and (min-width: 768px) {
  .reason-area .reason-lists {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: 20px;
  }
  .reason-area .reason-item:nth-child(2) {
    margin-top: 20px;
  }
  .reason-area .reason-item:nth-child(3) {
    margin-top: 40px;
  }
  .reason-area .reason-content {
    margin-top: 10px;
  }
}
@media screen and (min-width: 1024px) {
  .reason-area .reason-lists {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: 50px;
  }
  .reason-area .reason-item:nth-child(2) {
    margin-top: 50px;
  }
  .reason-area .reason-item:nth-child(3) {
    margin-top: 100px;
  }
  .reason-area .reason-content {
    font-size: 2.4rem;
  }
}
/*設備紹介
-----------------------------------------------------*/
.facility-area {
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}
.facility-area .facility-lists {
  border-top: 1px solid #ccc;
}
.facility-area .facility-item {
  padding-block: 30px;
  border-bottom: 1px solid #ccc;
}

@media screen and (min-width: 768px) {
  .facility-area {
    margin-top: var(--pc-mgt);
    padding-bottom: var(--pc-mgt);
  }
  .facility-area .facility-item {
    padding-block: 40px;
  }
  .facility-area .media-content {
    width: 55%;
  }
}
/*　事例紹介
-----------------------------------------------------*/
.works-area .section-head01 {
  text-align: left;
  margin-bottom: 0;
}
.works-area .works-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
.works-area .works-content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.works-area .works-content .info-article-lists {
  margin-top: 0;
}

@media screen and (min-width: 768px) {
  .works-area .works-block {
    gap: 40px;
  }
}
@media screen and (min-width: 1024px) {
  .works-area .works-block {
    gap: 80px;
  }
}
/*　FAQ
-----------------------------------------------------*/
.faq-area .faq-lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 20px;
}
.faq-area .faq-item {
  padding: 20px;
  border: 1px solid #999;
  border-radius: 5px;
}
.faq-area .faq-head {
  position: relative;
  padding-right: 30px;
  font-weight: 600;
}
.faq-area .faq-head:before, .faq-area .faq-head:after {
  position: absolute;
  top: 20px;
  width: 20px;
  height: 2px;
  content: "";
  -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transition: transform 0.3s ease, opacity 0.3s ease, -webkit-transform 0.3s ease;
}
.faq-area .faq-head:before {
  right: 0;
  background: var(--blue);
}
.faq-area .faq-head:after {
  right: 0;
  background: var(--blue);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
.faq-area .faq-head.is_active:after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}
.faq-area .icon-q, .faq-area .icon-a {
  text-indent: -1.8em;
  padding-left: 1.8em;
}
.faq-area .icon-q:before, .faq-area .icon-a:before {
  margin-right: 0.5em;
  font-weight: 700;
  font-size: 2rem;
}
.faq-area .icon-q:before {
  content: "Q.";
  color: var(--blue);
}
.faq-area .icon-a:before {
  content: "A.";
  color: #666;
}
.faq-area .faq-content {
  display: none;
  padding-top: 10px;
}
.gjs-dashed .faq-area .faq-content{
  display: block;
}

@media screen and (min-width: 768px) {
  .faq-area .faq-item {
    padding-inline: 30px;
  }
  .faq-area .faq-head {
    font-size: 1.8rem;
    cursor: pointer;
  }
  .faq-area .icon-q:before {
    font-size: 2.2rem;
  }
  .faq-area .faq-content {
    padding-top: 20px;
  }
}
/*-----------------------------------------------------
	採用情報
-----------------------------------------------------*/
/*求める人物像
-----------------------------------------------------*/
.candidate-area {
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}
.candidate-area .candidate-lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 10px;
}
.candidate-area .candidate-item {
  padding: 20px 15px;
  background: #fff;
}
.candidate-area .candidate-item .icon {
  padding-left: 50px;
  font-size: 1.7rem;
  font-weight: 600;
  line-height: 1.4;
  background-repeat: no-repeat;
  background-position: 0 50%;
  background-size: 40px auto;
}
.candidate-area .candidate-item .icon-01 {
  background-image: url(/system_panel/uploads/images/recruit_icon01.png);
}
.candidate-area .candidate-item .icon-02 {
  background-image: url(/system_panel/uploads/images/recruit_icon02.png);
}
.candidate-area .candidate-item .icon-03 {
  background-image: url(/system_panel/uploads/images/recruit_icon03.png);
}

@media screen and (min-width: 768px) {
  .candidate-area {
    margin-top: var(--pc-mgt);
    padding-bottom: var(--pc-mgt);
  }
}
@media screen and (min-width: 1024px) {
  .candidate-area .candidate-lists {
    padding-top: 60px;
    gap: 20px;
  }
  .candidate-area .candidate-item {
    padding: 25px 30px;
  }
  .candidate-area .candidate-item .icon {
    padding-left: 80px;
    font-size: 2.1rem;
    background-size: 50px auto;
  }
}
@media screen and (min-width: 1400px) {
  .candidate-area:before {
    height: min(90%, 800px);
  }
}
/* 業務内容
-----------------------------------------------------*/
.jpbdesc-area .media-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  margin-top: 30px;
  margin-inline: calc(50% - 50vw);
}
.jpbdesc-area .jpbdesc-txt {
  font-weight: 600;
}
.jpbdesc-area .jpbdesc-info {
  margin-top: 20px;
  padding: 20px;
  border: 1px solid #666;
}

@media screen and (min-width: 768px) {
  .jpbdesc-area .media-block {
    padding-top: 40px;
  }
  .jpbdesc-area .media-img {
    gap: 20px;
    margin-inline: 0;
    margin-top: 0;
  }
  .jpbdesc-area .jpbdesc-txt {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 1200px) {
  .jpbdesc-area .media-block {
    padding-top: 80px;
  }
  .jpbdesc-area .jpbdesc-info {
    margin-top: 50px;
    padding-inline: 30px;
  }
}
/* 仕事の流れ
-----------------------------------------------------*/
.workflow-area {
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}
.workflow-area .workflow-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
.workflow-area .workflow-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.workflow-area .flow-item {
  padding-block: 20px;
  border-bottom: 1px solid #ccc;
}
.workflow-area .flow-item:first-child {
  border-top: 1px solid #ccc;
}
.workflow-area .flow-head {
  margin-bottom: 20px;
}
.workflow-area .flow-head .head-jp {
  font-weight: 600;
  font-size: 2rem;
}

@media screen and (min-width: 768px) {
  .workflow-area {
    margin-top: var(--pc-mgt);
    padding-bottom: var(--pc-mgt);
  }
  .workflow-area .flow-head .head-jp {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .workflow-area .media-content {
    width: 60%;
  }
  .workflow-area .flow-item {
    padding-block: 30px;
  }
}
/* 募集要項
-----------------------------------------------------*/
.recruit-area .recruit-contact {
  margin-top: 30px;
  padding: 20px;
  border: 1px solid #ccc;
  border-radius: 5px;
}
.recruit-area .contact-lead {
  text-align: center;
  font-weight: 600;
}
.recruit-area .contact-lead strong {
  font-weight: 700;
}
.recruit-area .contact-btn {
  margin-top: 20px;
  text-align: center;
}
.recruit-area .btn-tel, .recruit-area .btn-contact {
  margin-inline: auto;
  max-width: 400px;
}
.recruit-area .btn-tel a, .recruit-area .btn-contact a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0;
  height: 70px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.recruit-area .btn-tel {
  margin-top: 15px;
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.05em;
}
.recruit-area .btn-tel a {
  color: var(--black);
  background: var(--gray);
}
.recruit-area .btn-tel p {
  display: inline-block;
  padding-left: 35px;
  background-image: url(/system_panel/uploads/images/contact_tel.png);
  background-repeat: no-repeat;
  background-position: 0 50%;
  background-size: 20px auto;
}
.recruit-area .btn-contact {
  font-weight: 600;
}
.recruit-area .btn-contact a {
  color: #fff;
  background: var(--blue);
}
.recruit-area .btn-contact a:hover {
  text-decoration: none;
}
.recruit-area .btn-contact p {
  display: inline-block;
  padding-left: 35px;
  background-image: url(/system_panel/uploads/images/contact_mail.png);
  background-repeat: no-repeat;
  background-position: 0 50%;
  background-size: 20px auto;
}
@media screen and (min-width: 414px) {
  .recruit-area .contact-lead br {
    display: none;
  }
  .recruit-area .contact-lead strong {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .recruit-area .content-inner {
    max-width: 1000px;
  }
  .recruit-area .recruit-contact {
    margin-top: 60px;
    padding: 40px;
  }
  .recruit-area .contact-lead {
    font-size: 2.1rem;
  }
  .recruit-area .contact-btn {
    margin-inline: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 30px;
    margin-top: 30px;
    width: min(90%, 690px);
  }
  .recruit-area .btn-tel, .recruit-area .btn-contact {
    width: 100%;
    max-width: 330px;
  }
  .recruit-area .btn-tel a, .recruit-area .btn-contact a {
    height: 80px;
  }
  .recruit-area .btn-tel {
    margin-top: 0;
  }
}
@media screen and (min-width: 1024px) {
  .recruit-area .recruit-contact {
    padding: 50px;
  }
  .recruit-area .contact-lead strong {
    display: inline;
  }
}
/*-----------------------------------------------------
	info / インフォメーション
-----------------------------------------------------*/
/* 一覧
-----------------------------------------------------*/
.info-category {
  text-align: center;
}
.info-category .webgene-item {
  position: relative;
  display: inline-block;
  padding-right: 12px;
  margin-right: 12px;
}
.info-category .webgene-item:after {
  position: absolute;
  top: 50%;
  right: 0;
  content: "";
  width: 1px;
  height: 12px;
  background: var(--black);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.info-category .webgene-item:last-child {
  padding-right: 0;
  margin-right: 0;
}
.info-category .webgene-item:last-child:after {
  display: none;
}
.info-category a {
  display: block;
  color: var(--black);
}
.info-category a:hover {
  text-decoration: none;
}
.info-category a.is-current {
  position: relative;
  color: var(--blue);
}
.info-category a.is-current:after {
  position: absolute;
  bottom: -2px;
  left: 0;
  content: "";
  width: 100%;
  height: 2px;
  background: var(--blue);
}

.info-article-lists {
  margin-top: 30px;
}
.info-article-lists .webgene-blog {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 30px;
}
.info-article-lists a {
  color: var(--black);
}
.info-article-lists .info-img {
  position: relative;
  background-image: url(/system_panel/uploads/images/info_noimg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 50% 50%;
}
.info-article-lists .info-img .ojf {
  position: relative;
  width: 100%;
  aspect-ratio: 6/4.5;
  overflow: hidden;
  margin: 0;
}
.info-article-lists .info-img .ojf img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}
.info-article-lists .info-img .cate {
  position: absolute;
  top: 0;
  left: 0;
  padding: 0 10px;
  color: #fff;
  font-size: 1.4rem;
  background: var(--black);
}
.info-article-lists .date {
  margin-top: 10px;
  font-size: 1.4rem;
  font-weight: 500;
}
.info-article-lists .webgene-pagination {
  margin-top: var(--sp-mgt);
  width: 100%;
}
.info-article-lists .webgene-pagination ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.info-article-lists .webgene-pagination li a {
  display: block;
  padding: 3px 14px;
  color: var(--blue);
  background: fff;
  border: 1px solid var(--blue);
}
.info-article-lists .webgene-pagination li.selected a {
  color: #fff;
  background: var(--blue);
}

@media screen and (min-width: 768px) {
  .info-article-lists {
    margin-top: 70px;
  }
  .info-article-lists .webgene-blog {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 20px;
  }
  .info-article-lists .webgene-item {
    width: calc((100% - 40px) / 3);
  }
}
@media screen and (min-width: 1024px) {
  .info-category .webgene-item {
    padding-right: 25px;
    margin-right: 25px;
  }
  .info-article-lists .webgene-blog {
    gap: 40px;
  }
  .info-article-lists .webgene-item {
    width: calc((100% - 80px) / 3);
  }
}
/* 記事
-----------------------------------------------------*/
.info-article {
  margin-bottom: var(--sp-mgt);
  padding: 20px;
  border: 1px solid var(--black);
}
.info-article .info-detail-header {
  margin-bottom: 20px;
  padding-bottom: 15px;
  text-align: center;
  border-bottom: 1px solid var(--black);
}
.info-article .info-detail-header .date {
  font-size: 1.2rem;
}
.info-article .info-detail-header .head {
  margin-top: 10px;
  font-size: 2rem;
  font-weight: 600;
}
.info-article .post-thumb-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 10px;
  gap: 5px;
}
.info-article .post-photo {
  width: calc((100% - 15px) / 4);
}
.info-article .ojf {
  position: relative;
  /*width: 100%;*/
  aspect-ratio: 6/4;
  overflow: hidden;
  margin: 0;
}
.info-article .ojf img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block;
}
.info-article .info-detail-content {
  margin-top: 20px;
}

@media screen and (min-width: 768px) {
  .info-article {
    padding: 40px 60px;
  }
  .info-article .info-detail-top {
    margin-bottom: 80px;
  }
  .info-article .info-detail-header {
    margin-bottom: 40px;
    padding-bottom: 30px;
  }
  .info-article .post-thumb-list {
    gap: 10px;
    margin-top: 20px;
  }
  .info-article .post-photo {
    width: calc((100% - 30px) / 4);
  }
  .info-back-btn {
    margin-inline: auto;
    width: 320px;
  }
}
@media screen and (min-width: 1024px) {
  .info-article {
    padding: 80px 100px;
  }
  .info-article .info-detail-header {
    margin-bottom: 60px;
  }
  .info-article .info-detail-header .date {
    font-size: 1.6rem;
  }
  .info-article .info-detail-header .head {
    font-size: 2.2rem;
  }
}
/*-----------------------------------------------------
	お問い合わせ
-----------------------------------------------------*/
/* お電話でのお問い合わせ
-----------------------------------------------------*/
.contact-tel .contact-tel-item {
  text-align: center;
  border: 1px solid var(--black);
  border-radius: 5px;
}
.contact-tel .contact-tel-item .btn-tel {
  display: block;
  padding-block: 15px;
  color: var(--black);
}
.contact-tel .contact-tel-item .btn-tel p {
  display: inline-block;
  padding-left: 27px;
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.05em;
  background-image: url(/system_panel/uploads/images/icon_phone.png);
  background-repeat: no-repeat;
  background-size: 20px auto;
  background-position: 0 50%;
}

@media screen and (min-width: 768px) {
  .contact-tel .contact-tel-item {
    margin-inline: auto;
    max-width: 540px;
  }
  .contact-tel .contact-tel-item .btn-tel {
    padding-block: 30px;
  }
  .contact-tel .contact-tel-item .btn-tel p {
    padding-left: 37px;
    font-size: 3rem;
    background-size: 25px auto;
  }
}
/* お問い合わせフォーム
-----------------------------------------------------*/
.contact-form {
  margin-top: var(--sp-mgt);
  padding-bottom: var(--sp-mgt);
}

.contact-form-txt {
  text-align: center;
}
.contact-form-box {
  margin-top: 30px;
  padding-block: 20px;
  padding-inline: 20px;
  color: var(--black);
  background: #fff;
}
.contact-form-box .requiredText {
  color: #b10000;
  font-size: 1.4rem;
}

.formWrap {
  margin-top: 20px;
}

.formRow {
  margin-right: 0 !important;
  margin-left: 0 !important;
  padding-block: 20px;
  border-bottom: 1px solid #ccc;
}
.formRow:first-child {
  border-top: 1px solid #ccc;
}
.formRow:nth-last-child(-n+2) {
  border-bottom: 0;
}
.formRow:nth-last-child(2) {
  padding-top: 30px;
  padding-bottom: 20px;
}

.formTh {
  margin-bottom: 10px;
  padding-left: 0;
  padding-right: 0;
  font-weight: 600;
}

.formTd {
  padding-left: 0;
  padding-right: 0;
}

.zipInput {
  margin-inline: 5px;
  width: 30%;
}

.formInput {
  width: 100%;
}

.formTextArea {
  width: 100%;
  height: 200px;
}

.d-inline-block {
  padding-right: 20px;
}

.labelText02 {
  margin-left: 5px;
}

.privacyLabel {
  margin-left: 5px;
  font-size: 1.3rem;
}

.formBtnTd {
  position: relative;
  display: block;
  padding-right: 0;
  padding-left: 0;
  text-align: center;
  max-width: 320px;
}
.formBtnTd:before, .formBtnTd:after {
  content: "";
  position: absolute;
  -webkit-transform-origin: calc(100% - 2px) 50%;
  transform-origin: calc(100% - 2px) 50%;
  z-index: 1;
}
.formBtnTd:before {
  top: calc(50% - 1px);
  right: 25px;
  width: 30px;
  height: 1px;
  background-color: #fff;
}
.formBtnTd:after {
  width: 7px;
  height: 7px;
  top: calc(50% - 3px);
  right: 26px;
  border: 1.5px solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  border-color: #fff #fff transparent transparent;
}
.formBtnTd:hover {
  text-decoration: none;
}
.formBtnTd:hover:before{
  background-color: var(--blue);
}
.formBtnTd:hover:after{
  border-color: var(--blue) var(--blue) transparent transparent;
}

.formBtn {
  height: 55px;
  width: 100%;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  background: var(--blue);
  border: solid 1px var(--blue) !important;
  border-radius: 0 !important;
  font: inherit !important;
  outline: none !important;
  color: #fff;
  transition: all .3s;
}
.formBtn:hover {
  cursor: pointer;
  background: #fff;
  color: var(--blue);
}

@media screen and (min-width: 768px) {
  .contact-form-box {
    margin-top: 50px;
    padding-block: 30px;
    padding-inline: 40px;
  }
  .contact-form-txt br {
    display: none;
  }

  .formRow {
    padding-block: 30px;
  }
  .formTh {
    margin-bottom: 0;
  }
  .formBtnTd {
    margin-inline: auto;
  }
  .formBtn {
    height: 68px;
  }
  .privacyLabel {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .contact-form-box {
    padding-block: 60px;
    padding-inline: 100px;
  }
}
/* プライバシーポリシー
-----------------------------------------------------*/
.privacyBox {
  overflow-y: scroll;
  text-align: left;
  max-width: 1000px;
  margin: 0 auto;
  height: 300px;
  border: 1px solid #9f9f9e;
  padding: 30px 20px 0;
  background: #fff;
}

.privacyDd {
  margin-bottom: 30px;
}
.privacyDd a {
  color: var(--black);
  text-decoration: underline;
}
.privacyDd a:hover {
  opacity: --hover;
}
.privacyDd a[href*="tel:"] {
  text-decoration: none;
}

/* 完了画面
-----------------------------------------------------*/
.back-btn {
  text-align: center;
}
.back-btn .btn-arrow {
  margin-inline: auto;
}


/*チャットボット*/
#chatbot-btn {
    max-width: 230px;
    max-height: 180px;
    bottom: 60px !important;
    z-index: 1001 !important;
}

@media screen and (min-width: 768px) {
    #chatbot-btn {
        bottom: 90px !important;
    }
}