@charset "UTF-8";
/*
Theme Name:ワークスタッフ株式会社｜コーポレートサイト
Theme URI:
Description:ワークスタッフ株式会社｜コーポレートサイト テーマ
Version:1
*/

* {
  box-sizing: border-box;
  font-feature-settings: "palt";
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: min(8rem, 80px);
  font-size: calc(100vw / 118.5);
}

body, h1, h2, h3, h4, h5, p {
  margin: 0;
  line-height: 1;
}

body {
  color: #4B4B4B;
  letter-spacing: .1em;
  font-family: "Zen Kaku Gothic New", sans-serif;
  /* font-family: 'Oswald', sans-serif; */
  /* font-family: 'Montserrat', sans-serif; */
}

body.active {
  height: 100%;
  overflow: hidden;
}

p {
  text-align: justify;
}

img {
  width: 100%;
  height: auto;
  display: flex;
  align-items: center;
  margin: auto;
  vertical-align: bottom;
}

ul, li {
  margin: 0;
  padding: 0;
  list-style: none;
}

a {
  text-decoration: none;
}

table {
  border-collapse: collapse;
}

@media (hover: hover) {
  a:hover {
    opacity: 0.6;
  }
}

a:visited {
}

span {
  display: inline-block;
}

dl, dt, dd {
  all: unset;
  display: block;
}

button {
  all: unset;
  display: block;
}

.sp_obj {
  display: none;
}

.container {
  /* max-width: 1040px; */
  max-width: 1080px;
  margin: 0 auto;
  /* padding: min(10.8rem, 108px) min(2rem, 20px); */
  padding: min(10.8rem, 60px) min(2rem, 20px);
}

h2.common_h2 {
  /* font-size: min(4.8rem, 48px); */
  /* font-size: min(3.8rem, 38px); */
  font-size: min(3.6rem, 36px);
  font-weight: 700;
  text-align: center;
  position: relative;
  color: #3a3a3a;
}

h2.common_h2_02 {
  /* font-size: min(4.8rem, 48px); */
  /* font-size: min(3.8rem, 38px); */
  font-size: min(3.6rem, 36px);
  font-weight: 700;
  position: relative;
  color: #194B04;
  /* padding: 0 min(15rem, 155px) min(1.6rem, 16px); */
  padding: 0 min(14rem, 140px) min(1.6rem, 16px);
  border-bottom: 2px solid #E8E8E8;
  width: fit-content;
  margin: 0 auto;

}

.common_h2_02::after {
  position: absolute;
  display: block;
  /* font-size: min(2.6rem, 26px); */
  /* font-size: min(2.0rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 700;
  color: #6CC04A;
  text-align: center;
  right: 0;
  left: 0;
  margin: auto;
  /* bottom: min(-3.4rem, -34px); */
  bottom: min(-3rem, -30px);
  font-family: 'Montserrat', sans-serif;
}

.common_txt {
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 400;
  line-height: 2;
  text-align: center;
}

.target {
  width: 54%;
  /* transform: translateY(min(8rem, 80px)); */
  transform: translateY(min(4rem, 40px));
  opacity: 0;
  transition: all .8s;
}

.target.appear {
  transform: none;
  opacity: 1;
}

.sp_obj {
  display: none !important;
}

/* =========================
   btn-line
========================= */
.btn-line{
  position: relative;
  display: flex; 
  align-items: center;
  gap: 16px;

  border: 1px solid #231815;
  padding: 25px 30px;
  color:  #231815;
  text-decoration: none;

  overflow: hidden;
  width: 400px;
}

/* ホバーで入る薄い水色の“面” */
.btn-line::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(120, 200, 220, 0.22); /* 薄い水色（お好みで濃さ調整） */

  transform: translateX(-100%);
  transition: transform 0.35s ease;
  z-index: 0;
}

.btn-line__text,
.btn-line__arrow{
  position: relative;
  z-index: 1; /* ← hover面より前に */
}

.btn-line__text{
  letter-spacing: .02em;
  line-height: 1;
  white-space: nowrap;
  margin-right: auto;
  font-size: 18px;
  letter-spacing: 0.2em;
}

.btn-line__arrow{
  width: 34px;      /* 矢印画像の見た目に合わせて調整 */
  height: auto;
  flex: 0 0 auto;
  display: block;
}

/* hover/focusで左から色が入る */
.btn-line:hover::before,
.btn-line:focus-visible::before{
  transform: translateX(0);
}

/* キーボード操作の見やすさ */
.btn-line:focus-visible{
  outline: 2px solid rgba(120, 200, 220, 0.55);
  outline-offset: 3px;
}

@media (max-width: 799px) {
  .btn-line{
  width: 330px;
}
  .btn-line__text{
      font-size: 15px;
  }
}
/* =========================
   btn-line ここまで
========================= */

@media (max-width: 799px) {
  
  html {
    scroll-padding-top: 8rem;
    font-size: calc(100vw / 37.5);
  }

  a:hover {
    opacity: 1;
  }
  
  .container {
    padding: 3.2rem 3.5rem;
    width: 100%;
  }

  h2.common_h2 {
    font-size: 2.4rem;
    line-height: 1.4;
  }

  h2.common_h2_02 {
    font-size: 2.4rem;
    padding: 0 0 .8rem;
    border-bottom: .2rem solid #E8E8E8;
    width: 23.0rem;
    margin: 0 auto;
    text-align: center;
  }

  .common_h2_02::after {
    font-size: 1.4rem;
    bottom: -1.8rem;
  }

  .common_txt {
    font-size: 1.6rem;
    line-height: 1.6;
  }

  .target {
    transform: translateY(min(4rem));
  }
  
  .sp_obj {
    display: block !important;
  }
  
  .pc_obj {
    display: none !important;
  }
}

/* ----- index_header ----- */

header.index_header {
  width: 100%;
  background-color: transparent;
  position: fixed;
  transition: all .8s;
  z-index: 99;
  background-color: #fff;
}

header.index_header.changed {
  background-color: #fff;
}

header.index_header div.header_container {
  width: 100%;
  height: 90px;
  /* padding: min(4rem, 40px) min(2.0rem, 20px); */
  padding: min(1.2rem, 15px) min(2.0rem, 20px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all .8s;
}

header.index_header.changed div.header_container {
  padding: min(1.0rem, 10px) min(2.0rem, 20px);
}

header.index_header div.header_container h1 a {
  display: block;
  /* font-size: min(1.4rem, 14px); */
  font-size: min(1.3rem, 13px);
  font-weight: 500;
  display: flex;
  align-items: center;
  /* gap: min(1.6rem, 16px); */
  gap: min(1.4rem, 14px);
  color: #231815;
}

header.index_header div.header_container h1 a::before {
  content: '';
  display: block;
  background-image: url(img/logo1.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(26rem, 260px); */
  width: min(23rem, 230px);
  /* height: min(8.3rem, 83px); */
  height: min(7.2rem, 72px);
  transition: all .8s;
}

header.index_header.changed div.header_container h1 a::before {
  width: min(20rem, 200px);
  height: min(6.3rem, 63px);
}

header.index_header div.header_container ul.gnav_ul {
  display: flex;
  align-items: center;
}

header.index_header div.header_container li.gnav_li a {
  /* font-size: min(1.5rem, 15px); */
  font-size: min(1.4rem, 14px);
  font-weight: 500;
  /* padding: 0 min(2rem, 20px); */
  padding: 0 min(1.8rem, 18px);
  color: #231815;
}
header.index_header div.header_container li.btn-menu{
  margin-right: 20px;
  border-radius: 3px;
}
header.index_header div.header_container li.btn-menu a{
  font-size: min(1.4rem, 14px);
  font-weight: 500;
  padding: 0 min(1.8rem, 18px);
  background-color: #F5883F;
  color: #fff ;
  padding: 10px 20px !important;
  border-radius: 3px;
}

header.index_header div.header_container li.gnav_li:first-of-type a {
  padding-left: 0;
}

header.index_header div.header_container li.gnav_li:last-of-type a {
  padding-right: 0;
}

@media (max-width: 799px) {


  header.index_header div.header_container {
    width: 100%;
    padding: 2.4rem 1.5rem;
    height: 65px;
  }
  
  header.index_header.changed div.header_container {
    padding: 2.4rem 1.5rem;
  }
    header.index_header div.header_container-sp {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: min(1.0rem, 10px) min(2.0rem, 20px);
    height: 65px;
  }
	header.index_header div.header_container-sp img{
		margin: unset !important;}
		
  header.index_header.changed div.header_container-sp {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: min(1.0rem, 10px) min(2.0rem, 20px);
    height: 65px;
  }
  #open {
    width: 2.7rem;
    margin-left: auto;
  }

  div.overlay {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    color: #fff;
    padding: 6.662rem 4.6rem 24.0rem;
    overflow-y: scroll;
    opacity: 0;
    pointer-events: none;
    transition: all .8s;
    z-index: 99;
  }

  div.overlay.show {
    opacity: 1;
    pointer-events: auto;
  }

  #close {
    position: absolute;
    width: 2.7rem;
    height: 1.8rem;
    top: 2.4rem;
    right: 1.5rem;
  }

  div.overlay h1 {
    font-size: 0;
    width: 60%;
    margin: 0 auto;
  }

  div.overlay ul.overlay_ul {
    margin-top: 6.4rem;
  }

  div.overlay ul.overlay_ul li.overlay_li + li.overlay_li {
    margin-top: 3.8rem;
  }

  div.overlay ul.overlay_ul li.overlay_li a {
    font-size: 2.0rem;
    font-weight: 500;
    color: #231815;
    padding-left: .8rem;
    border-left: .6rem solid #83C3E4;
  }

  div.overlay a.overlay_link {
    margin: 7.8rem auto 0;
    width: 100%;
    background-color: #F5883F;
    border-radius: 99px;
    font-size: 2.0rem;
    font-weight: 500;
    color: #fff;
    padding: 1.6rem 2.4rem;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  div.overlay a.overlay_link + a.overlay_link {
    margin-top: 1.6rem;
  }


  div.overlay div.sns {
    margin: 6.4rem auto 0;
    width: 22.0rem;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 2.2rem;
  }
}

main {
}

@media (max-width: 799px) {
  main {
  }
}

/* ----- mv ----- */

@media screen and (min-width: 768px){
  main.index section.mv{
    padding-top: 80px;
    display: flex;
    align-items: center;       /* 上下中央揃え */
    gap: 40px;                 /* 文字と画像の間隔（お好みで） */
  }

  main.index section.mv .mv_container{
    flex: 1 1 auto;            /* 左：テキスト */
    max-width: 620px;          /* 文字幅が広がりすぎるのを防ぐ（お好み） */
    margin-left: max(
      24px,
      calc((100vw - 1080px) / 2)
    );
  }

  main.index section.mv .mv-pc-fade{
    flex: 0 0 auto;            /* 右：画像 */
    margin-left: auto;         /* 右端寄せ */
    width: min(1027px, 55vw);  /* さっき決めた幅 */
    height: 520px;             /* MV高さ（必要に応じて調整） */
  }
}


main.index section.mv {
  width: 100%;
  background-image: url(img/mv-bg-pc.png);
  background-size: cover;
  background-position: center;
}

main.index section.mv div.mv_container {
  /* max-width: 1600px; */
  /* max-width: 1400px; */
  max-width: 1140px;
   /*margin: 0 auto;*/
  /* padding: min(12rem, 120px) min(2rem, 20px) min(35rem, 350px); */
  /* padding: calc(min(12rem, 120px) + min(16.244rem, 162.44px)) min(2rem, 20px) min(35rem, 350px); */
  padding: calc(min(8rem, 80px) + min(10rem, 100px)) min(2rem, 20px) min(18rem, 180px);
}

main.index section.mv div.mv_container h2.mv_h2 {
  /* font-size: min(6.1rem, 61px); */
  /* font-size: min(4.8rem, 48px); */
  font-size: min(4.4rem, 55px);
  font-weight: 700;
  line-height: 1.5;
  color: #fff;
  letter-spacing: .2em;
  margin-bottom: 20px;
}

main.index section.mv div.mv_container p.mv_p {
  font-size: min(2.4rem, 19px);
  font-weight: 500;
  line-height: 1.8;
  color: #fff;
  letter-spacing: .1em;
  margin-bottom: 20px;
}
/* =========================
   PC MV Fade
========================= */

.mv-pc-fade{
  position: relative;
  margin-left: auto;        /* 右寄せ */
  width: min(1027px, 55vw);  height: 520px;          /* ← PC用MVの高さ */
  overflow: hidden;
  margin: 100px 0;
}

.mv-pc-fade__slides{
  position: relative;
  width: 100%;
  height: 100%;
}

.mv-pc-fade__slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 4s ease;
}

.mv-pc-fade__slide.is-active{
  opacity: 1;
  z-index: 1;
}

.mv-pc-fade__slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* =========================
   PC MV Fadeここまで
========================= */
/* =========================
   SP MV move
========================= */

.mv-marquee{
  width: 100%;
  overflow: hidden;
  padding: 8px 0 40px; /* 上下の余白は必要に応じて調整 */
}

/* 流れるレーン */
.mv-marquee__track{
  display: flex;
  align-items: flex-end; /* 下揃えで段差がきれいに見える */
  gap: 6px;              /* 画像間隔（狭め） */
  will-change: transform;
}

/* figureのデフォルトmargin(左右40px)を確実に消す */
.mv-marquee__item{
  margin: 0;
  padding: 0;

  flex: 0 0 auto;
  width: clamp(180px, 85vw, 200px); /* 2〜3枚見える幅感 */

  border-radius: 0px;
  overflow: hidden;
}

/* 画像は “見切れなし” で表示 */
.mv-marquee__item img{
  width: 100%;
  height: auto;    /* ← これが見切れ防止 */
  display: block;
}

/* 段差：カード位置を下にずらして開始位置に差を出す */
.mv-marquee__item.is-tall{
  transform: translateY(0px);
}
.mv-marquee__item.is-mid{
  transform: translateY(24px);
}
.mv-marquee__item.is-short{
  transform: translateY(48px);
}

/* JSが距離と時間をCSS変数で入れる（is-readyが付いたら動く） */
.mv-marquee.is-ready .mv-marquee__track{
  /*animation: mvMarquee var(--mv-marquee-duration, 20s) linear infinite;*/
  animation: mvMarquee var(--mv-marquee-duration) linear infinite;
}

@keyframes mvMarquee{
  from{ transform: translate3d(0,0,0); }
  to{   transform: translate3d(calc(-1 * var(--mv-marquee-distance, 100px)),0,0); }
}

/* 動きが苦手な人向け 
@media (prefers-reduced-motion: reduce){
  .mv-marquee__track{
    animation: none !important;
    transform: none !important;
  }
}*/

/* =========================
   PC MV move ここまで
========================= */

main.index section.mv div.mv_container div.mv_link {
  /* margin-top: min(8.8rem, 88px); */
  /* margin-top: min(7rem, 70px); */
  margin-top: min(6.4rem, 64px);
  width: fit-content;
  display: flex;
  /* gap: min(6.4rem, 64px); */
  gap: min(2.4rem, 24px);
}

main.index section.mv div.mv_container div.mv_link a.link_item {
  /* width: min(30rem, 300px); */
  width: min(28rem, 280px);
  /* padding: min(2rem, 20px) min(1.8rem, 18px); */
  padding: min(1.6rem, 16px) min(1rem, 10px);
  color: #fff;
  /* font-size: min(3rem, 30px); */
  /* font-size: min(2.4rem, 24px); */
  font-size: min(2rem, 20px);
  letter-spacing: .3em;
  font-weight: 500;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 2px solid #fff;
  transition: all .4s;
}

main.index section.mv div.mv_container div.mv_link a.link_item span span {
  font-size: min(1.4rem, 14px);
}

main.index section.mv div.mv_container div.mv_link a.link_item::after {
  display: block;
  content: '';
  background-image: url(img/icon_circleArrow_white.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  /* width: min(3rem, 30px); */
  /* width: min(2.4rem, 24px); */
  width: min(2.0rem, 20px);
  /* height: min(3rem, 30px); */
  /* height: min(2.4rem, 24px); */
  height: min(2.0rem, 20px);
  transition: all .4s;
}

@media (hover: hover) {
  
  main.index section.mv div.mv_container div.mv_link a.link_item:hover {
    color: #6CC04A;
    border: 2px solid #fff;
    background-color: #fff;
    opacity: 1;
  }
  
  main.index section.mv div.mv_container div.mv_link a.link_item:hover::after {
    background-image: url(img/icon_circleArrow_green.png);
  }
}

@media (max-width: 799px) {
  main.index section.mv {
    background-image: url(img/mv-bg-sp.png);
  }
  
  main.index section.mv div.mv_container {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 6.662rem 4.6rem 2rem;
  }
  
  main.index section.mv div.mv_container h1 {
    font-size: 0;
    width: 45%;
    margin: 0 auto;
  }
  
  main.index section.mv div.mv_container p.mv_sttl {
    margin-top: 1.6rem;
    font-size: 1.4rem;
    text-align: center;
    line-height: 1.4;
    color: #fff;
    font-weight: 500;
  }
  
  main.index section.mv div.mv_container h2.mv_h2 {
    font-size: 36px;
    margin: 3rem auto 0;
    font-weight: 700;
    line-height: 1.6;
    margin-bottom: 20px;
  }
  
  main.index section.mv div.mv_container p.mv_p {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.6;
    margin-bottom: 50px;
  }

  main.index section.mv div.mv_container div.mv_link {
    margin-top: 3.0rem;
    width: 100%;
    flex-direction: column;
    gap: 2.4rem;
  }
  
  main.index section.mv div.mv_container div.mv_link a.link_item {
    width: 100%;
    padding: 1.5rem 2.2rem;
    font-size: 1.6rem;
    border: .2rem solid #fff;
  }
  
  main.index section.mv div.mv_container div.mv_link a.link_item::after {
    width: 2.0rem;
    height: 2.0rem;
  }
}

/* ----- message ----- */

main.index section.message {
  width: 860px;
  background-color: #ffffff;
  margin: 0 auto;
}

main.index section.message div.about_conts {
  width: 100%;
  display: flex;
  align-items: start;
  /* gap: min(5.6rem, 56px); */
  /* gap: min(4.4rem, 44px); */
  gap: min(4rem, 40px);
}

main.index section.message div.message_conts div.txt_area {
  width: auto;
}

main.index section.message div.message_conts h2.common_h2 {
  text-align: left;
  line-height: 1.4;
  font-weight: 400;
  font-size: 27px;
  color: #83C3E4;
}


main.index section.message div.message_conts div.txt_area p.common_txt {
  /* margin-top: min(4rem, 40px); */
  /* margin-top: min(3.2rem, 32px); */
  margin-top: min(2.9rem, 29px);
  text-align: left;
  letter-spacing: -.01em;
  font-weight: 400;
  line-height: 2.5;
  margin-left: 240px;
  margin-top: -38px;
  margin-bottom: 50px;
  letter-spacing: 0.25em;
}
main.index section.message div.message_conts div.btn_conts{
  margin: 0 auto;
  text-align: center;
}

main.index section.message div.message_conts div.btn_conts a.btn-line{
  display: flex; 
  width: 290px;
  margin: 0 auto;
}

@media (max-width: 799px) {
main.index section.message {
  width: 95%;
  background-color: #ffffff;
  margin: 0 auto;
  margin-top: 20px;
}

main.index section.message div.about_conts {
  width: 100%;
  display: flex;
  align-items: start;
  /* gap: min(5.6rem, 56px); */
  /* gap: min(4.4rem, 44px); */
  gap: min(4rem, 40px);
}

main.index section.message div.message_conts h2.common_h2 {
  text-align: left;
  line-height: 1.4;
  font-weight: 400;
  font-size: 26px;
}

main.index section.message div.message_conts div.txt_area p.common_txt {
  /* margin-top: min(4rem, 40px); */
  /* margin-top: min(3.2rem, 32px); */
  margin-top: min(2.9rem, 29px);
  text-align: left;
  letter-spacing: -.01em;
  font-weight: 400;
  line-height: 2.5;
  margin-left: unset;
  margin-top: 20px;
  margin-bottom: 50px;
  letter-spacing: 0.25em;
  font-size: 1.4rem;
}
main.index section.message div.message_conts div.btn_conts{
  font-size: 15px;
  letter-spacing: 0.25em;
}

main.index section.message div.message_conts div.btn_conts a.btn-line{
  width: 100%;
}

}


/* ----- business ---- */

main.index section.business {
  margin: 0 auto;
}
.sub-title-area{
  text-align: left;

}
main.index section.business p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  color: #83C3E4;
}
main.index section.business h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: left;
  color: #3A3A3A;
}
main.index section.business p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
}
main.index section.business .img__wrap{
  display: inline-block;
}
main.index section.business img {
  width: auto;
  height: auto;
}
main.index section.business .col-2{
  padding: 20px 0; 
  display: grid;
  grid-template-columns: 1fr 1fr; /* 左テキスト / 右画像 */
  gap: 10px;
  align-items: center;
      justify-content: center;
}

main.index section.business .col-2__inner{
  max-width: none;
  margin: 0;
  padding: 0;
  display: block;
}

main.index section.business .col-2__title{
  margin: 10px 0 12px;
  font-size: 22px;
  line-height: 1.3;

  position: relative;          /* beforeの基準 */
  padding-left: 20px;
  padding-bottom: 5px;
  margin-bottom: 15px;
  margin-top: 40px;
}

main.index section.business .col-2__title::before{
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);

  width: 10px;                  /* 縦棒の太さ */
  height: 1.5em;               /* 文字に合わせた高さ */
  background-color: #F8D05D;   /* お好みの色 */
}

main.index section.business .col-2__inner p.common_txt{
text-align: left;
margin-bottom: 20px;
}

/* 画像側 */
main.index section.business .col-2__img img{
  width: 100%;
  height: auto;
  display: block;
}

main.index section.business .btn_conts{
  margin-bottom: 15px;
}

@media (max-width: 799px) {
  main.index section.business {
  width: 100%;
}

.sub-title-area{
  text-align: left;

}
main.index section.business h2.common_h2 {
  font-size: 26px;
  margin-bottom: 20px;
}
main.index section.business p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
  margin-bottom: 25px;
}
main.index section.business .col-2{
  grid-template-columns: 1fr; /* 1列 */
  gap: 18px;
}

  /* 並び順を入れ替え */
.col-2__img{ order: 1; }  /* 画像を先に */
.col-2__inner{ order: 2; }  /* テキストを後に */

main.index section.business .col-2__inner{
  padding: 0;
}

}

/* ----- Quality & Trust ---- */

main.index section.quality {
  margin: 0 auto;
}

.sub-title-area{
  text-align: left;

}
main.index section.quality p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  text-align: center;
  color: #83C3E4;
}
main.index section.quality h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: center;
  color: #3A3A3A;
}
main.index section.quality p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
}
main.index section.quality .img__wrap{
  display: flex;
}
main.index section.quality img {
  width: auto;
  height: auto;
}
main.index section.quality .col-2{
  padding: 20px 0; 
  display: grid;
  grid-template-columns: 1fr 3fr; /* 左画像 / 右テキスト */
  gap:60px;
  align-items: start;
      justify-content: center;
}

main.index section.quality .col-2__inner{
  max-width: none;
  margin: 0;
  padding: 0;
  display: block;
}

main.index section.quality .col-2__title{
  margin: 10px 0 12px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.3;

  position: relative;   
  /*padding-left: 20px;*/
  padding-bottom: 5px;
  margin-bottom: 15px;
  margin-top: 25px;
}

main.index section.quality .setsumei{
  background-color: #EDF6FB;
  padding: 30px 20px;

}
main.index section.quality .setsumei__title{
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;

  position: relative;   
  padding-left: 15px;
  padding-bottom: 4px;
  margin-bottom: 15px;
}

main.index section.quality .setsumei__title::before{
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);

  width: 7px;                 
  height: 1.3em;              
  background-color: #83C3E4;  
}
main.index section.quality .setsumei__txt{
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
}

main.index section.quality .col-2__inner p.common_txt{
text-align: left;
margin-bottom: 20px;
}

/* 画像側 */
main.index section.quality .col-2__img img{
  width: 100%;
  height: auto;
  display: block;
  margin-top: 35px;
}

@media (max-width: 799px) {
  main.index section.quality {
  width: 100%;
  background-color: #EDF6FB;
}

.sub-title-area{
  text-align: left;

}
main.index section.quality h2.common_h2 {
  font-size: 26px;
  margin-bottom: 20px;
}
main.index section.quality p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
  margin-bottom: 25px;
}
main.index section.quality .col-2{
  grid-template-columns: 1fr; /* 1列 */
  gap: 18px;
}
main.index section.quality .col-2__img img{
  width: 100%;
  max-width: 250px;
  background-color: #fff;
  padding: 30px 50px;
}

main.index section.quality .setsumei{
  background-color: #fff;
  padding: 30px 20px;

}

  /* 並び順を入れ替え */
main.index section.quality .col-2__img{ order: 2; }  /* 画像を先に */
main.index section.quality .col-2__inner{ order: 1; }  /* テキストを後に */

main.index section.quality .col-2__inner{
  padding: 0;
}

}



/* ----- recruit ---- */

main.index section.recruit {
  margin: 0 auto;
  background-image: url(img/saiyo-bg.png);
  background-position: center;
  background-size: cover;
}
.sub-title-area{
  text-align: left;
}
main.index section.recruit p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  text-align: center;
  color: #fff;
}
main.index section.recruit h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: center;
  color: #231815;
}
main.index section.recruit p.common__txt {
  margin-top: min(2.8rem, 28px);
  text-align: center;
  color: #231815;
  font-size: 18px;
  line-height: 2;
  margin-bottom: 20px;
}
main.index section.recruit .btn_conts {
text-align: center;
margin: 0 auto;
}
main.index section.recruit div.btn_conts a.btn-line{
  display: flex; 
  width: 290px;
  margin: 0 auto;
}

/* ----- For Enployees ---- */
main.index section.employees {
  margin: 0 auto;
}
main.index section.employees p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  color: #83C3E4;
}
main.index section.employees h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: left;
  color: #3A3A3A;
}
main.index section.employees p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
}
main.index section.employees .img__wrap{
  display: inline-block;
}
main.index section.employees img {
  width: auto;
  height: auto;
}
main.index section.employees .col-2{
  padding: 20px 0; 
  display: grid;
  grid-template-columns: 1fr 1fr; /* 左テキスト / 右画像 */
  gap: 30px;
  align-items: center;
      justify-content: center;
}
main.index section.employees .col-2__1{
  max-width: none;
  margin: 0;
  padding: 0;
  display: block;
}
main.index section.employees .col-2__1 p.common_txt{
text-align: left;
margin-bottom: 20px;
}
main.index section.employees .col-2__1 img, 
main.index section.employees .col-2__2 img {
  width: 54px;
  height: 54px;
  display: block;
}
main.index section.employees .btn_conts{
  margin-bottom: 15px;
}
main.index section.employees .btn_conts .btn-line{
  border: 1px solid #83C3E4;
  width: 100%;
  text-align: left;
  padding: 15px 30px;

  display: flex; 
  align-items: center;  
  gap: 14px;
}
main.index section.employees .btn_conts .btn-line__arrow{
  width: 54px;
  height: 54px;
  flex: 0 0 54px; 
  display: block;
  object-fit: contain; 
}
main.index section.employees .btn_conts .btn-line__text{
  flex: 1 1 auto; 
  margin-left: 14px;
}
@media (max-width: 799px) {
  main.index section.employees {
  width: 100%;
}

.sub-title-area{
  text-align: left;
}
main.index section.employees h2.common_h2 {
  font-size: 26px;
  margin-bottom: 20px;
}
main.index section.employees p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
  margin-bottom: 25px;
}
main.index section.employees .col-2{
  grid-template-columns: 1fr; /* 1列 */
  gap: 0;
}

  /* 並び順を入れ替え */
.col-2__1{ order: 1; }  /* 画像を先に */
.col-2__2{ order: 2; }  /* テキストを後に */

main.index section.employees .col-2__inner{
  padding: 0;
}

}

/* ----- NEWS ---- */
main.index section.news {
  margin: 0 auto;
}

main.index section.news .sub-title-area{
  text-align: left;

}
main.index section.news p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  text-align: center;
  color: #83C3E4;
}
main.index section.news h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: center;
  color: #3A3A3A;
}
main.index section.news .img__wrap{
  display: flex;
}
main.index section.news img {
  width: auto;
  height: auto;
}
@media (max-width: 799px) {
  main.index section.news {
  width: 100%;
}
	main.index section.news-archive {
    margin: 0 auto;
    padding-top: 0px !important;
		        padding-bottom: 60px;
}
main.index section.news h2.common_h2 {
  font-size: 26px;
  margin-bottom: 20px;
}
main.index section.news p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
  margin-bottom: 25px;
}
}

/* ---- Company Profile ---- */
main.index section.page-title {
  margin: 0 auto;
  padding-top: 80px;
}

.sub-title-area{
  text-align: left;

}
main.index section.page-title p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  text-align: center;
  color: #83C3E4;
}
main.index section.page-title h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: center;
  color: #3A3A3A;
}
main.index section.page-title p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
}
main.index section.comprof table{
  width: 900px;
  margin: 0 auto;
  font-size: 20px;
  text-align: left;
}
main.index section.comprof table tr{
border-bottom: 1px solid #83C3E4;
}
main.index section.comprof table th{
width: 230px;
padding: 20px 10px 20px 30px;
vertical-align:top;
}
main.index section.comprof table td{
width: 570px;
padding: 20px 30px 20px 10px;
}
main.index section.comprof .col-2{
  padding: 20px 0; 
  display: grid;
  grid-template-columns: 1fr 3fr; /* 左画像 / 右テキスト */
  gap:60px;
  align-items: start;
      justify-content: center;
}
main.index section.page-title .img__wrap{
  display: flex;
  margin-bottom: 50px;
}
main.index section.page-title img {
  width: auto;
  height: auto;
}
main.index section.page-title .kiyaku-text {
  font-size: 16px;
}
main.index section.page-title .kiyaku-text p{
  line-height: 1.6 !important;
}


main.index section.comprof .col-2__inner p.common_txt{
text-align: left;
margin-bottom: 20px;
}
.zyou{
 font-weight: bold;
    padding: 5px !important;
    margin-bottom: 5px !important;
    background-color: #f7f7f7;

}
.zyou-text{
    margin-bottom: 5px !important;
    padding: 5px !important;
}

@media (max-width: 799px) {
  main.index section.comprof {
  width: 100%;
}

.sub-title-area{
  text-align: left;

}
main.index section.comprof h2.common_h2 {
  font-size: 26px;
  margin-bottom: 20px;
}
main.index section.comprof p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
  margin-bottom: 25px;
}

main.index section.comprof table{
  width: 100%;
  margin: 0 auto;
  font-size: 12px;
  text-align: left;
}
main.index section.comprof table tr{
border-bottom: 1px solid #83C3E4;
}
main.index section.comprof table th{
width: 20%;
padding: 20px 0px 20px 5px;
vertical-align:top;
}
main.index section.comprof table td{
width: 80%;
padding: 20px 5px 20px 10px;
}



}


/* ----- mid_career ----- */

section.mid_career_announcement {
  width: 100%;
  background-color: #F8F8F8;
}

section.mid_career_announcement h2.mid_career_h2 {
  /* font-size: min(4rem, 40px); */
  /* font-size: min(3.2rem, 32px); */
  font-size: min(3rem, 30px);
  font-weight: 500;
  text-align: center;
}

section.mid_career_announcement dl.mid_career_conts {
  /* margin: min(3.4rem, 34px) auto 0; */
  /* margin: min(2.8rem, 28px) auto 0; */
  margin: min(2.6rem, 26px) auto 0;
  max-width: 1240px;
  /* padding:  0 min(3.2rem, 32px) min(4rem, 40px); */
  /* padding:  0 min(2.6rem, 26px) min(3.2rem, 32px); */
  padding:  0 min(2.4rem, 24px) min(3rem, 30px);
  background-color: #fff;
}

section.mid_career_announcement dl.mid_career_conts div.mid_career_item {
  border-bottom: 1px solid #707070;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
}

section.mid_career_announcement dl.mid_career_conts div.mid_career_item:not(:nth-of-type(1)) {
  display: flex;
  align-items: center;
}

section.mid_career_announcement dl.mid_career_conts div.mid_career_item h3.mid_career_h3 {
  /* padding: min(3.2rem, 32px); */
  /* padding: min(2.6rem, 26px); */
  padding: min(2.4rem, 24px);
}

section.mid_career_announcement dl.mid_career_conts div.mid_career_item dt.mid_career_dt {
  /* padding: min(3.2rem, 32px); */
  /* padding: min(2.6rem, 26px); */
  padding: min(2.4rem, 24px);
}

section.mid_career_announcement dl.mid_career_conts div.mid_career_item dd.mid_career_dd {
  /* padding: min(3.2rem, 32px); */
  /* padding: min(2.6rem, 26px); */
  padding: min(2.4rem, 24px);
}

section.mid_career_announcement dl.mid_career_conts p.mid_career_note {
  margin-top: min(1.4rem, 14px);
  font-size: min(1.4rem, 14px);
  font-weight: 500;
  text-align: right;
}

@media (max-width: 799px) {
  
  section.mid_career_announcement div.container {
    padding: 3.2rem 1.5rem;
  }

  section.mid_career_announcement h2.mid_career_h2 {
    font-size: 2.0rem;
    line-height: 1.4;
  }
  
  section.mid_career_announcement dl.mid_career_conts {
    margin: 2.4rem auto 0;
    max-width: 100%;
    padding:  0 2.0rem 3.2rem;
    background-color: #fff;
  }
  
  section.mid_career_announcement dl.mid_career_conts div.mid_career_item {
    border-bottom: .1rem solid #707070;
    font-size: 1.6rem;
    font-weight: 500;
  }
  
  section.mid_career_announcement dl.mid_career_conts div.mid_career_item:not(:nth-of-type(1)) {
    justify-content: space-between;
  }
  
  section.mid_career_announcement dl.mid_career_conts div.mid_career_item h3.mid_career_h3 {
    padding: 1.6rem;
    font-size: 1.8rem;
  }
  
  section.mid_career_announcement dl.mid_career_conts div.mid_career_item dt.mid_career_dt {
    padding: 1.6rem;
  }
  
  section.mid_career_announcement dl.mid_career_conts div.mid_career_item dd.mid_career_dd {
    padding: 1.6rem;
  }
  
  section.mid_career_announcement dl.mid_career_conts p.mid_career_note {
    margin-top: .8rem;
    font-size: 1.4rem;
  }
}
/* ----- footer ---- */

footer {
  width: 100%;
  box-shadow: 0 -2px 2px rgba(62 110 43 / .15);
  background-color: #ECECEC;
}

footer div.container {
  
  /*padding-bottom: min(6.4rem, 64px);*/
  padding-bottom: 0;
}

footer h1 {
  font-size: 0;
  /* width: min(42rem, 420px); */
  /* width: min(36rem, 360px); */
  width: min(33rem, 330px);
  margin: 0 auto;
}

footer div.info_wrap {
  /* margin-top: min(8rem, 80px); */
  /* margin-top: min(6.4rem, 64px); */
  margin-top: min(5.8rem, 58px);
  width: 100%;
  display: flex;
  /* gap: min(27rem, 270px); */
  /* gap: min(22rem, 220px); */
  grid-template-columns: 2fr 1fr 1fr; /* 会社名 / リンク / リンク */
  gap: min(20rem, 100px);
  justify-content: space-around;
  align-items: start;
  text-align: left;
}

footer div.info_wrap div.info_item {
  width: fit-content;
}
footer div.info_wrap div.bar-1,
footer div.info_wrap div.bar-2 {
  border-left: #797777 1px solid;
  padding: 20px 0 20px 30px;
}

footer .info_item img{
  display: block;
  margin: 0;           /* ★autoが入ってたら潰す */
  margin-bottom: 30px;
  margin-top: 20px;
}

footer div.info_wrap div.info_item li {
  padding: 10px;
  font-size: 16px;
}
footer div.info_wrap div.info_item li a{
  color: #4B4B4B;
}

footer div.info_wrap div.info_item p.footer_txt {
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  line-height: 1.5;
}

footer div.info_wrap div.info_item p.footer_txt02 {
  margin-top: min(3.2rem, 32px);
  font-size: min(1.4rem, 14px);
  font-weight: 500;
  line-height: 2;
}
footer div.info_wrap div.info_item p.footer_txt02 a {
	color: #4B4B4B;
}

footer div.info_wrap div.info_item p.footer_txt02 + p.footer_txt02 {
  margin-top: min(2rem, 20px);
}

footer div.info_wrap02 {
  /* margin: min(7.2rem, 72px) auto 0; */
  /* margin: min(5.8rem, 58px) auto 0; */
  margin: min(5.3rem, 53px) auto 0;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 0;
  padding: min(1.6rem, 16px) 0;
	color:#4B4B4B;
}

footer div.info_wrap02 a:last-of-type {
  border-right: 1px solid #fff;
}

@media (max-width: 799px) {
  
    footer div.info_wrap{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

  footer div.info_wrap div.info_item:first-child{
    grid-column: 1 / -1;
  }
  footer h1 {
    width: 14.5rem;
  }
  
  footer div.info_wrap {
    margin-top: 0;
    flex-direction: column;
    gap: 0;
  }
  
  footer div.info_wrap div.info_item {
    width: 100%;
  }
  footer div.info_wrap div.bar-1{
  border-left: #797777 0px solid;
  padding: 20px 0 20px 10px;
}
  footer div.info_wrap div.bar-2{
  padding: 20px 0 20px 10px;
}
footer div.info_wrap div.info_item li {
  padding: 10px;
  font-size: 12px;
}
  footer div.info_wrap div.info_item p.footer_txt {
    font-size: 1.4rem;
    margin-bottom: 30px;
  }
  
  footer div.info_wrap div.info_item p.footer_txt02 {
    font-size: 1.3rem;
    line-height: 1.6;
  }
  
  footer div.info_wrap div.info_item p.footer_txt02 + p.footer_txt02 {
    margin-top: .8rem;
  }
  
  footer div.footer_sns {
    width: 100%;
    margin: 3.2rem auto 0;
    gap: 2.0rem;
    padding-top: 3.2rem;
    border-top: .2rem solid #E8E8E8;
  }
  
  footer div.footer_sns a.sns_item {
    width: 3.4rem;
  }
  
  footer div.info_wrap02 {
    margin: 3.2rem auto 0;
    padding: 1.3rem 0;
  }
  
  footer div.info_wrap02 a {
    font-size: .9rem;
    padding: 0 1.4rem;
    border-left: .1rem solid #fff;
  }
  
  footer div.info_wrap02 a:last-of-type {
    border-right: .1rem solid #fff;
  }
}

/* ----- inner_header ----- */

header.inner_header {
  width: 100%;
  background-color: #fff;
  position: fixed;
  z-index: 99;
}

header.inner_header div.header_container {
  /* padding: 0 0 0 min(2rem, 20px); */
  padding: 0 0 0 min(1.6rem, 16px);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

header.inner_header div.header_container h1 {
  font-size: 0;
}

header.inner_header div.header_container h1 a {
  color: #6CC04A;
  /* font-size: min(1.4rem, 14px); */
  font-size: min(1.3rem, 13px);
  font-weight: 500;
  display: flex;
  align-items: center;
  /* gap: min(1.6rem, 16px); */
  gap: min(1.2rem, 12px);
}

header.inner_header div.header_container h1 a::before {
  display: block;
  content: '';
  background-image: url(img/logo_h1_green.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(19rem, 190px); */
  width: min(16rem, 160px);
  /* height: min(6rem, 60px); */
  height: min(4.8rem, 48px);
}

header.inner_header div.header_container ul.gnav_ul {
  display: flex;
  align-items: center;
  gap: 0;
}

header.inner_header div.header_container ul.gnav_ul li.gnav_li a {
  display: block;
  /* font-size: min(1.5rem, 15px); */
  font-size: min(1.3rem, 13px);
  font-weight: 500;
  color: #4B4B4B;
  /* padding: min(4rem, 40px) min(1.6rem, 16px); */
  padding: min(4rem, 40px) min(1.0rem, 10px);
}

header.inner_header div.header_container ul.gnav_ul li.gnav_li:last-of-type a {
  color: #fff;
  padding: min(4rem, 40px) min(3.2rem, 32px);
  background-color: #6CC04A;
}

@media (max-width: 799px) {
  header.inner_header div.header_container {
    width: 100%;
    padding: 1.6rem 1.5rem;
  }
  
  header.inner_header div.header_container h1 a {
    font-size: 1.0rem;
    line-height: 1.2;
    gap: .8rem;
  }

  header.inner_header div.header_container h1 a::before {
    width: 13.0rem;
    height: 4.0rem;
  }

  #open02 {
    width: 2.7rem;
    margin-left: auto;
  }

  div.inner_overlay {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #6CC04A;
    color: #fff;
    padding: 6.662rem 4.6rem 24.0rem;
    overflow-y: scroll;
    opacity: 0;
    pointer-events: none;
    transition: all .8s;
    z-index: 99;
  }

  div.inner_overlay.show {
    opacity: 1;
    pointer-events: auto;
  }

  #close02 {
    position: absolute;
    width: 2.7rem;
    height: 1.8rem;
    top: 2.4rem;
    right: 1.5rem;
  }

  div.inner_overlay h1 {
    font-size: 0;
    width: 45%;
    margin: 0 auto;
  }

  div.inner_overlay ul.overlay_ul {
    margin-top: 4.0rem;
  }

  div.inner_overlay ul.overlay_ul li.overlay_li + li.overlay_li {
    margin-top: 3.2rem;
  }

  div.inner_overlay ul.overlay_ul li.overlay_li a {
    font-size: 2.0rem;
    font-weight: 500;
    color: #fff;
    padding-left: .8rem;
    border-left: .1rem solid #fff;
  }

  div.inner_overlay a.overlay_link {
    margin: 4.8rem auto 0;
    width: 100%;
    background-color: #fff;
    border-radius: 99px;
    font-size: 2.0rem;
    font-weight: 500;
    color: #6CC04A;
    padding: 1.6rem 2.4rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  div.inner_overlay a.overlay_link02 {
    background-color: #FFF84E;
    color: #343434;
    padding: 1.6rem 2.4rem;
  }
  
  div.inner_overlay a.overlay_link + a.overlay_link {
    margin-top: 1.6rem;
  }
  
  div.inner_overlay a.overlay_link::after {
    display: block;
    content: '';
    background-image: url(img/icon_circleArrow_green.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
  }

  div.inner_overlay a.overlay_link02::after {
    background-image: url(img/icon_circleArrow_black.png);
  }
  
  div.inner_overlay div.sns {
    margin: 6.4rem auto 0;
    width: 22.0rem;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 2.2rem;
  }
}


/* ----- news archive ---- */

main.index section.news-archive {
  margin: 0 auto;
  padding-top: 70px;
}
.sub-title-area{
  text-align: left;

}
section.news-archive p.title-eng {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 12px;
  color: #83C3E4;
}
section.news-archive h2.common_h2 {
  font-size: 32px;
  font-weight: 500;
  margin-bottom: 25px;
  text-align: left;
  color: #3A3A3A;
}
section.news-archive p.common_txt {
  margin-top: min(2.8rem, 28px);
  text-align: left;
}
section.news-archive .img__wrap{
  display: inline-block;
}
section.news-archive img {
  width: auto;
  height: auto;
}
section.news-archive ul.news-list{
  font-size: 16px;
  margin-top: 20px;
}
section.news-archive ul.news-list li.news-item{
  font-size: 18px;
  line-height: 2.5;
}
section.news-archive ul.news-list li.news-item a{
  text-decoration: none;
  color: #3A3A3A;
}
/* ----- news archive ---- */
main.index section.news-single {
  margin: 0 auto;
  padding-top: 120px;
  width: 1080px;
  font-size: 18px;
  font-weight: 400;
  line-height: 2;
}
main.index section.news-single h1{
font-size: 20px;
font-weight: 500;
margin-bottom: 30px;
}
main.index section.news-single div.news-content p{
font-size: 16px;
font-weight: normal;
margin-bottom: 30px;
line-height: 2;
}
main.index section.news-single p.news-back{
  text-align: right;
  margin: 30px;
}
main.index section.news-single p.news-back a{
    padding: 9px 15px;
    background-color: #dadada;
    color: #231815;
    font-size: 14px;
}
@media (max-width: 799px) {
  section.news-archive ul.news-list li.news-item p{
  font-size: 12px;
  line-height: 2.5;
}
main.index section.news-single {
    width: 90%;
  margin: 0 auto;
  padding-top: 90px;
}
main.index section.news-single h1{
font-size: 18px;
}
main.index section.news-single div.news-content p{
font-size: 14px;
}
main.index section.news-single p.news-back{
  text-align: right;
  margin: 30px 0;
}
main.index section.news-single p.news-back a{

    font-size: 12px;
}
}
/* ----- inner_common ---- */

main.inner {
  padding-top: min(9.3rem, 93px);
}

main.inner div.treatment_wrap {
  /* margin: min(4rem, 40px) auto 0; */
  /* margin: min(3.2rem, 32px) auto 0; */
  margin: min(3rem, 30px) auto 0;
  width: min(78rem, 780px);
  display: flex;
  justify-content: center;
  gap: min(1.2rem, 12px);
}

main.inner.okayama div.treatment_wrap {
  width: min(92.5rem, 925px);
}

main.inner div.treatment_wrap div.treatment_item {
  width: calc((100% - min(1.2rem, 12px) * 4) / 5);
  padding: min(1.2rem, 12px) 0 0;
  background-color: #fff;
  box-shadow: min(.4rem, 4px) min(.4rem, 4px) 0 rgba(0 0 0 / .2);
}

main.inner div.treatment_wrap div.treatment_item div.icon {
  width: min(2.8rem, 28px);
  margin: 0 auto;
}
main.inner div.treatment_wrap div.treatment_item p.treatment_txt {
  /* margin-top: min(1.4rem, 14px); */
  margin-top: min(1.2rem, 12px);
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 700;
  text-align: center;
}

main.inner div.treatment_wrap div.treatment_item p.treatment_txt span {
  /* font-size: min(4.5rem, 45px); */
  /* font-size: min(3.6rem, 36px); */
  font-size: min(3.2rem, 32px);
  font-weight: 500;
  font-family: 'Oswald', sans-serif;  
  color: #6CC04A;
  line-height: 1.8;
}

main.inner div.treatment_wrap div.treatment_item:nth-of-type(1) p.treatment_txt span, 
main.inner div.treatment_wrap div.treatment_item:nth-of-type(2) p.treatment_txt span {
  letter-spacing: -.08em;
}


main.inner section.mv div.mv_conts p.entry {
  /* width: min(26rem, 260px); */
  width: min(20rem, 200px);
  /* margin: min(6rem, 60px) auto 0; */
  /* margin: min(4.8rem, 48px) auto 0; */
  margin: min(4.4rem, 44px) auto 0;
  padding: min(.8rem, 8px) 0;
  text-align: center;
  /* font-size: min(3.2rem, 32px); */
  font-size: min(2.6rem, 26px);
  font-weight: 500;
  position: relative;
  background-color: #6CC04A;
  border-radius: 99px;
  color: #fff;
}

main.inner section.mv div.mv_conts p.entry::after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/_fujisawa/icon_arrow_mv_green.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  width: min(1.5rem, 15px);
  height: min(1.6rem, 16px);
  right: 0;
  left: 0;
  margin: auto;
  bottom: 0;
  transform: translateY(100%);
}

@media (max-width: 799px) {
  main.inner {
    padding-top: 7.2rem;
  }

  main.inner div.treatment_wrap {
    margin: .4rem auto 0;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
  }

  main.inner.okayama div.treatment_wrap {
    width: 100%;
  }
  
  main.inner div.treatment_wrap div.treatment_item {
    width: calc((100% - .8rem * 2) / 3);
    padding: .8rem 0 0;
    background-color: #fff;
    box-shadow: .4rem .4rem 0 rgba(0 0 0 / .2);
  }
  
  main.inner div.treatment_wrap div.treatment_item div.icon {
    width: 2.4rem;
    margin: 0 auto;
  }

  main.inner div.treatment_wrap div.treatment_item p.treatment_txt {
    margin-top: .4rem;
    font-size: 1rem;
  }
  
  main.inner div.treatment_wrap div.treatment_item p.treatment_txt span {
    font-size: 2.2rem;
  }

  footer.inner_footer div.entry_area_wrap {
    position: fixed;
    width: 100%;
    padding: .8rem 1.6rem;
    background-color: #63B442;
    display: flex;
    justify-content: space-between;
    align-items: center;
    bottom: 0;
    z-index: 2;
  }

  footer.inner_footer div.entry_area_wrap p.entry_txt {
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.4;
    color: #fff;
  }

  footer.inner_footer div.entry_area_wrap p.entry_txt span {
    font-size: 1.4rem;
  }

  footer.inner_footer div.entry_area_wrap a.link_entry {
    display: block;
    width: 14.6rem;
    background-color: #FFF84E;
    padding: 1.2rem 0;
    font-size: 1.6rem;
    font-weight: 500;
    text-align: center;
    color: #343434;
  }

  footer.inner_footer {
    padding-bottom: 5.6rem;
  }
}

main.inner a.link_apply {
  display: block;
  /* margin: min(1.6rem, 16px) auto 0; */
  margin: min(1.2rem, 12px) auto 0;
  /* width: min(57.6rem, 576px); */
  width: min(46rem, 460px);
  background-color: #FFF84E;
  border: 2px solid #FFF84E;
  border-radius: 99px;
  /* font-size: min(3rem, 30px); */
  font-size: min(2.4rem, 24px);
  font-weight: 500;
  color: #343434;
  text-align: center;
  /* padding: min(1.8rem, 18px) 0; */
  padding: min(1.4rem, 14px) 0;
  box-shadow: 0 min(.5rem, 5px) 0 #807C2D;
  position: relative;
  transition: all .4s;
}

main.inner a.link_apply::after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/icon_circleArrow_black.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  width: min(3.2rem, 32px);
  height: min(3.2rem, 32px);
  top: 0;
  bottom: 0;
  margin: auto;
  right: min(3.2rem, 32px);
  transition: all .4s;
}

@media (hover: hover) {

  main.inner a.link_apply:hover {
    background-color: #D6D6D6;
    border: 2px solid #fff;
    color: #fff;
    box-shadow: 0 0 0;
    opacity: 1;
  }

  main.inner a.link_apply:hover::after {
    background-image: url(img/icon_circleArrow_white.png);
  }
}

@media (max-width: 799px) {
  main.fujisawa section.mv {
    background-image: url(img/_fujisawa/bg_fujisawa_mv_sp.jpg);
    z-index: 1;
  }

  main.fujisawa section.mv::before {
    background-image: url(img/_fujisawa/bg_fujisawa_mv02_sp.png);
    max-width: 100%;
    height: 60.3rem;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    z-index: -1;
  }

  main.fujisawa section.mv::after {
    position: absolute;
    display: block;
    content: '';
    background-image: url(img/_fujisawa/bg_mv_circle_sp.png);
    width: 100%;
    height: 60.3rem;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    z-index: -2;
  }

  main.fujisawa section.mv p.office {
    width: 18.0rem;
    font-size: 2.0rem;
    padding: 1.0rem 0;
    box-shadow: .4rem .4rem .0rem rgba(0 0 0 / .16);
    top: 2.8rem;
    left: 0;
  }

  main.fujisawa section.mv div.mv_conts {
    padding: 18.0rem 4.8rem 9.0rem;
    width: 100%;
  }

  main.fujisawa section.mv div.mv_conts p.mv_txt {
    margin-top: 0;
    font-size: 1.3rem;
  }

  main.fujisawa section.mv div.mv_conts p.mv_txt02 {
    margin: 1rem auto 0;
    width: 20.0rem;
    font-size: 1.7rem;
    padding: .8rem 0;
    border: .2rem solid #343434;
  }

  main.fujisawa section.mv div.mv_conts div.txt_image {
    width: 27.0rem;
    margin: 1.0rem auto 0;
  }

  main.inner a.link_apply {
    margin: 0 auto;
    width: 90%;
    font-size: 2.0rem;
    font-weight: 500;
    text-align: left;
    padding: 2.0rem 2.4rem;
    box-shadow: unset;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  main.inner a.link_apply::after {
    width: 3.0rem;
    height: 3.0rem;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 2.4rem;
  }
}

/* ---- menu ----- */

main.inner section.menu {
  width: 100%;
  background-color: #6CC04A;
  /* padding: min(12rem, 120px) 0; */
  /* padding: min(9.6rem, 96px) 0; */
  padding: min(8.8rem, 99px) 0;
}

main.inner section.menu div.menu_h2_area {
  width: 100%;
  position: relative;
  padding: 0 0 min(.8rem, 8px);
}

main.inner section.menu div.menu_h2_area div.lines {
  margin-left: calc((100vw - min(130rem, 1300px)) / 2 + min(23rem, 230px));
}

main.inner section.menu div.menu_h2_area div.lines span {
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
}

main.inner section.menu div.menu_h2_area div.lines span + span {
  margin-top: min(.8rem, 8px);
}

main.inner section.menu div.menu_h2_area h2.menu_h2  {
  position: absolute;
  height: min(6rem, 60px);
  /* max-width: 1300px; */
  max-width: 1180px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  padding: 0 min(1.6rem, 16px);
}

main.inner section.menu div.menu_h2_area h2.menu_h2 span {
  display: inline-block;
  /* font-size: min(6.4rem, 64px); */
  font-size: min(5.2rem, 52px);
  font-weight: 700;
  font-family: 'Montserrat', sans-serif;
  color: #fff;
  background-color: #6CC04A;
  padding-right: min(2.4rem, 24px);
}

main.inner section.menu div.menu_container {
  /* max-width: 1340px; */
  /* max-width: 1080px; */
  max-width: 1000px;
  /* padding: 0 min(2rem, 20px); */
  /* padding: 0 min(1.6rem, 16px); */
  padding: 0 min(1.4rem, 14px);
  /* margin: min(4.2rem, 42px) auto 0; */
  /* margin: min(3.6rem, 36px) auto 0; */
  margin: min(3.3rem, 33px) auto 0;
}

main.inner section.menu div.menu_wrap {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  /* gap: min(4rem, 40px); */
  /* gap: min(3.2rem, 32px); */
  gap: min(3rem, 30px);
}

main.inner section.menu div.menu_wrap div.menu_item {
  background-color: #fff;
  /* padding: min(3.2rem, 32px); */
  /* padding: min(2.6rem, 26px); */
  padding: min(2.4rem, 24px);
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s {
  display: flex;
  flex-direction: column;
  /* gap: min(2rem, 20px); */
  /* gap: min(1.6rem, 16px); */
  gap: min(1.4rem, 14px);
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.icon_area {
  /* width: min(7.2rem, 72px); */
  /* width: min(5.8rem, 58px); */
  width: min(5.3rem, 53px);
  margin: 0 auto;
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area {
  width: 100%;
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt01 {
  width: 100%;
  /* height: min(10rem, 100px); */
  /* height: min(8rem, 80px); */
  height: min(7.2rem, 72px);
  background-color: #FFF84E;
  display: flex;
  justify-content: center;
  align-items: center;
  /* font-size: min(2.4rem, 24px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  line-height: 1.2;
  font-weight: 700;
  text-align: center;
}

main.inner section.menu div.menu_wrap div.menu_item:last-of-type div.menu_wrap_s div.txt_area p.menu_txt01 {
  letter-spacing: -.08em;
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt01 small {
  /* font-size: min(3.2rem, 32px); */
  /* font-size: min(2.6rem, 26px); */
  font-size: min(2.4rem, 24px);
  display: inline;
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt02 {
  /* margin-top: min(3.2rem, 32px); */
  /* margin-top: min(2.6rem, 26px); */
  margin-top: min(2.4rem, 24px);
  /* font-size: min(3.2rem, 32px); */
  /* font-size: min(2.6rem, 26px); */
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  text-align: center;
  color: #194B04;
}

main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt02 span {
  margin-top: min(.8rem, 8px);
  /* font-size: min(1.6rem, 16px); */
  font-size: min(1.4rem, 14px);
  font-weight: 500;
  text-align: center;
  color: #6CC04A;
}

main.inner section.menu div.menu_wrap div.menu_item a.menu_link {
  /* margin-top: min(3.2rem, 32px); */
  /* margin-top: min(2.6rem, 26px); */
  margin-top: min(2.4rem, 24px);
  margin-left: auto;
  /* width: min(16rem, 160px); */
  /* width: min(14rem, 140px); */
  width: min(13rem, 130px);
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  padding-bottom: min(.4rem, 4px);
  border-bottom: 1px solid #194B04;
  color: #194B04;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

main.inner section.menu div.menu_wrap div.menu_item a.menu_link:after {
  display: block;
  content: '';
  background-image: url(img/_fujisawa/icon_circleArrow_darkgreen.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(2rem, 20px); */
  /* width: min(1.8rem, 18px); */
  width: min(1.6rem, 16px);
  /* height: min(2rem, 20px); */
  /* height: min(1.8rem, 18px); */
  height: min(1.6rem, 16px);
}

main.inner section.menu a.link_apply {
  /* margin-top: min(6.8rem, 68px); */
  /* margin-top: min(5.4rem, 54px); */
  margin-top: min(5rem, 50px);
  box-shadow: unset;
}

@media (max-width: 799px) {
  main.inner section.menu {
    padding: 6.4rem 0;
  }
  
  /* ----- */

  main.inner section.menu div.menu_h2_area {
  padding: 1.6rem 0;
}

main.inner section.menu div.menu_h2_area div.lines {
  margin-left: 12.0rem;
}

main.inner section.menu div.menu_h2_area div.lines span {
  display: block;
  width: 100%;
  height: .1rem;
  background-color: #fff;
}

main.inner section.menu div.menu_h2_area div.lines span + span {
  margin-top: .4rem;
}

main.inner section.menu div.menu_h2_area h2.menu_h2  {
  height: 4.0rem;
  max-width: none;
  width: 95%;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  padding: 0;
  /* background-color: navy; */
}

main.inner section.menu div.menu_h2_area h2.menu_h2 span {
  font-size: 4.0rem;
  padding-right: 1.6rem;
}
  
  /* ----- */

  main.inner section.menu div.menu_container {
    max-width: 95%;
    padding: 0;
    margin: 3.2rem auto 0;
  }
  
  main.inner section.menu div.menu_wrap {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item {
    background-color: #fff;
    padding: 1.2rem 2.0rem 2.0rem;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s {
    flex-direction: row;
    gap: 1.6rem;
    align-items: center;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.icon_area {
    width: 4.8rem;
    margin: auto;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area {
    flex: 1;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt01 {
    width: fit-content;
    height: auto;
    display: block;
    font-size: 1.4rem;
    line-height: 1.2;
    text-align: center;
    border-radius: 99px;
    padding: .8rem 1.6rem;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item:last-of-type div.menu_wrap_s div.txt_area p.menu_txt01 {
    letter-spacing: .1em;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt01 small {
    font-size: 1.4rem;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt02 {
    margin-top: 1.6rem;
    font-size: 2.0rem;
    text-align: justify;
    padding-left: 1.6rem;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item div.menu_wrap_s div.txt_area p.menu_txt02 span {
    margin-top: .4rem;
    font-size: 1.0rem;
    text-align: justify;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item a.menu_link {
    margin-top: 1.0rem;
    width: 10.0rem;
    font-size: 1.2rem;
    padding-bottom: 0;
    border-bottom: none;
  }
  
  main.inner section.menu div.menu_wrap div.menu_item a.menu_link:after {
    width: 2.0rem;
    height: 2.0rem;
  }
  
  main.inner section.menu a.link_apply {
    margin-top: 3.6rem;
    box-shadow: unset;
  }
}

/* ----- okayama.html ----- */

main.okayama section.mv {
  width: 100%;
  background-image: url(img/_okayama/bg_okayama_mv_pc.jpg);
  background-size: cover;
  background-position: center center;
  position: relative;
  z-index: 1;
}

main.okayama section.mv::after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/_okayama/bg_okayama_mv02_pc.png);
  background-size: cover;
  background-position: center center;
  /* max-width: 1600px; */
  /* max-width: 1280px; */
  /* max-width: 1180px; */
  max-width: 100%;
  /* height: min(31.5rem, 315px); */
  /* height: min(25.2rem, 252px); */
  /* height: min(22.5rem, 225px); */
  height: min(33rem, 330px);
  left: 0;
  right: 0;
  margin: auto;
  bottom: 0;
  z-index: -1;
  mix-blend-mode: multiply;
}

main.okayama section.mv div.mv_txt_wrap {
  position: absolute;
  /* width: min(66rem, 660px); */
  width: min(53rem, 530px);
  /* padding: min(3.2rem, 32px) 0; */
  padding: min(2.6rem, 26px) 0;
  background-color: rgba(56 70 34 / .75);
  top: min(4rem, 40px);
  left: 0;
}

main.okayama section.mv div.mv_txt_wrap p.mv_txt {
  /* font-size: min(4rem, 40px); */
  /* font-size: min(3.2rem, 32px); */
  font-size: min(3rem, 30px);
  font-weight: 700;
  text-align: center;
  color: #fff;
}

main.okayama section.mv div.mv_txt_wrap p.mv_txt02 {
  /* width: min(56rem, 560px); */
  /* width: min(45rem, 450px); */
  width: min(42rem, 420px);
  margin: min(1.6rem, 16px) auto 0;
  /* font-size: min(5rem, 50px); */
  /* font-size: min(4rem, 40px); */
  font-size: min(3.6rem, 36px);
  font-weight: 700;
  color: #fff;
  /* padding: min(2rem, 20px) 0; */
  /* padding: min(1.6rem, 16px) 0; */
  padding: min(1.4rem, 14px) 0;
  border: 2px solid #fff;
  text-align: center;
  letter-spacing: .4em;
}

main.okayama section.mv p.office {
  /* width: min(36.8rem, 368px); */
  /* width: min(32rem, 320px); */
  width: min(30rem, 300px);
  position: absolute;
  background-color: rgba(108 192 74 / .8);
  /* font-size: min(4rem, 40px); */
  /* font-size: min(3.2rem, 32px); */
  font-size: min(3rem, 30px);
  color: #fff;
  font-weight: 500;
  text-align: center;
  /* padding: min(1.6rem, 16px) 0; */
  padding: min(1.2rem, 12px) 0;
  top: min(24rem, 240px);
  left: 0;
  letter-spacing: .4em;
}

main.okayama section.mv div.mv_conts {
  width: fit-content;
  margin: 0 auto;
  /* padding: min(61.4rem, 614px) 0 min(4rem, 40px); */
  /* padding: min(48rem, 480px) 0 min(3.2rem, 32px); */
  padding: min(44rem, 440px) 0 min(3rem, 30px);
}

main.okayama section.mv div.mv_conts div.treatment_wrap {
  margin-top: 0;
}

main.okayama div.treatment_wrap div.treatment_item:nth-of-type(2) p.treatment_txt span {
  letter-spacing: .1em;
}

main.okayama section.mv div.mv_conts div.entry_area {
  /* max-width: 1300px; */
  /* max-width: 1040px; */
  /* margin: min(4.2rem, 42px) auto 0; */
  width: 90%;
  margin: min(3.6rem, 36px) auto 0;
  display: flex;
  align-items: start;
  /* gap: min(3.8rem, 38px); */
  /* gap: min(3rem, 30px); */
  gap: min(2.7rem, 27px);
}

main.okayama section.mv div.mv_conts div.entry_area div.image_area {
  /* width: min(39rem, 390px); */
  /* width: min(32rem, 320px); */
  width: min(30rem, 300px);
}

main.okayama section.mv div.mv_conts div.entry_area div.entry_txt {
  flex: 1;
}

main.okayama section.mv div.mv_conts div.entry_area div.entry_txt p.entry {
  margin-top: 0;
}

@media (max-width: 799px) {
  main.okayama section.mv {
    background-image: url(img/_okayama/bg_okayama_mv_sp.jpg);
    z-index: 1;
  }
  
  main.okayama section.mv::after {
    background-image: url(img/_okayama/bg_okayama_mv02_sp.png);
    background-size: contain;
    width: 32.0rem;
    height: 32.0rem;
    top: 15.5rem;
    left: 0;
    right: 0;
    margin: auto;
    bottom: auto;
    z-index: -1;
  }
  
  main.okayama section.mv p.office {
    width: 18.3rem;
    font-size: 2.0rem;
    padding: 1.0rem 0;
    top: 3.5rem;
    left: 0;
  }
  
  main.okayama section.mv div.mv_conts {
    width: 100%;
    margin: 0 auto;
    padding: 17.8rem 4.8rem 7.4rem;
  }
  
  main.okayama section.mv div.mv_conts p.mv_txt {
    font-size: 1.3rem;
    font-weight: 700;
    color: #fff;
    text-align: center;
  }
  
  main.okayama section.mv div.mv_conts p.mv_txt02 {
    width: 19.5rem;
    margin: .6rem auto 0;
    border: .2rem solid #fff;
    padding: .8rem 0;
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: .4em;
    color: #fff;
    text-align: center;
  }
  
  main.okayama section.mv div.mv_conts div.txt_image{
    margin: .8rem auto 0;
    width: 100%;
  }
  
  main.okayama section.mv div.mv_conts div.treatment_wrap {
    margin-top: 0;
  }
  
  main.okayama section.mv div.mv_conts div.entry_area {
    max-width: 130.0rem;
    margin: 4.2rem auto 0;
    display: flex;
    align-items: start;
    gap: 3.8rem;
  }
  
  main.okayama section.mv div.mv_conts div.entry_area div.image_area {
    width: 39.0rem;
  }
  
  main.okayama section.mv div.mv_conts div.entry_area div.entry_txt {
    flex: 1;
  }
  
  main.okayama section.mv div.mv_conts div.entry_area div.entry_txt p.entry {
    margin-top: 0;
  }
}

/* ----- welfare.html ----- */

section.welfare h2.common_h2_02::after {
  content: 'Welfare';
}

section.welfare div.welfare_wrap01 {
  /* margin-top: min(16.8rem, 168px); */
  /* margin-top: min(13.4rem, 134px); */
  margin-top: min(12rem, 120px);
  width: 100%;
  position: relative;
}

section.welfare div.welfare_wrap01 div.image_area {
  width: 70%;
}

@media (max-width: 1199px) {
  section.welfare div.welfare_wrap01 div.image_area {
    width: 78%;
  }
}

section.welfare div.welfare_wrap01 div.welfare_item01 {
  position: absolute;
  /* width: min(57rem, 570px); */
  /* width: min(46rem, 460px); */
  width: min(42rem, 420px);
  /* padding: min(3.6rem, 36px) min(3.2rem, 32px); */
  /* padding: min(2.8rem, 28px) min(2.6rem, 26px); */
  padding: min(2.6rem, 26px) min(2.4rem, 24px);
  background-color: #6CC04A;
  /* top: min(3.8rem, 38px); */
  /* top: min(3rem, 30px); */
  top: min(2.8rem, 28px);
  right: 0;
}

section.welfare div.welfare_wrap01 div.welfare_item01 h3.h3_ttl {
  /* font-size: min(3.2rem, 32px); */
  /* font-size: min(2.6rem, 26px); */
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  /* padding-bottom: min(2rem, 20px); */
  /* padding-bottom: min(1.8rem, 18px); */
  padding-bottom: min(1.6rem, 16px);
  border-bottom: 2px solid #fff;
  text-align: center;
  color: #fff;
  letter-spacing: .4em;
}

section.welfare div.welfare_wrap01 div.welfare_item01 p.welfare_txt {
  /* font-size: min(3rem, 30px); */
  /* font-size: min(2.4rem, 24px); */
  font-size: min(2.2rem, 22px);
  font-weight: 500;
  /* margin-top: min(2rem, 20px); */
  /* margin-top: min(1.8rem, 18px); */
  margin-top: min(1.6rem, 16px);
  text-align: center;
  color: #fff;
}

section.welfare div.welfare_wrap01 div.welfare_item01 p.welfare_txt span {
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  margin-top: min(.8rem, 8px);
  line-height: 1.4;
}

section.welfare div.welfare_wrap01 div.welfare_item01 ul.welfare_ul {
  /* margin-top: min(1.6rem, 16px); */
  margin-top: min(1.2rem, 12px);
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(.2rem, 2px);
}

section.welfare div.welfare_wrap01 div.welfare_item01 ul.welfare_ul li.welfare_li {
  /* padding: min(1.6rem, 16px) 0; */
  padding: min(1.2rem, 12px) 0;
  background-color: #fff;
  /* font-size: min(2.4rem, 24px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 500;
  color: #4B4B4B;
  text-align: center;
}

section.welfare div.welfare_wrap01 div.welfare_item01 ul.welfare_ul li.welfare_li {
  /* padding: min(1.6rem, 16px) 0; */
  padding: min(1.2rem, 12px) 0;
  background-color: #fff;
  /* font-size: min(2.4rem, 24px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  color: #4B4B4B;
  text-align: center;
}

section.welfare div.welfare_wrap01 p.common_txt {
  margin-top: min(1.6rem, 16px);
  text-align: left;
}

section.welfare div.welfare_wrap02 {
  /* margin-top: min(9.6rem, 96px); */
  /* margin-top: min(7.6rem, 76px); */
  margin-top: min(7rem, 70px);
  /* padding: min(6rem, 60px) min(6.4rem, 64px) min(4rem, 40px); */
  /* padding: min(4.8rem, 48px) min(5.2rem, 52px) min(3.2rem, 32px); */
  padding: min(4.4rem, 44px) min(3.2rem, 3240px) min(3rem, 30px);
  border: 2px solid #6CC04A;
  position: relative;
}

section.welfare div.welfare_wrap02 h3.h3_ttl {
  /* width: min(80rem, 800px); */
  /* width: min(64rem, 640px); */
  width: min(60rem, 600px);
  position: absolute;
  /* padding: min(1.6rem, 16px) 0; */
  padding: min(1.2rem, 12px) 0;
  border: 2px solid #6CC04A;
  text-align: center;
  /* font-size: min(3rem, 30px); */
  /* font-size: min(2.4rem, 24px); */
  font-size: min(2.2rem, 22px);
  font-weight: 700;
  right: 0;
  left: 0;
  margin: auto;
  top: 0;
  transform: translateY(-50%);
  background-color: #fff;
  color: #6CC04A;
}

section.welfare div.welfare_wrap02 li.day_off_li {
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  /* font-size: min(1.6rem, 16px); */
  font-size: min(1.4rem, 14px);
  font-weight: 500;
  display: flex;
  align-items: center;
  /* gap: min(1.2rem, 12px); */
  gap: min(.8rem, 8px);
}

section.welfare div.welfare_wrap02 li.day_off_li::before {
  display: block;
  content: '';
  background-image: url(img/_fujisawa_welfare/icon_check.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(2.4rem, 24px); */
  /* width: min(2rem, 20px); */
  width: min(1.8rem, 18px);
  /* height: min(2.4rem, 24px); */
  height: min(1.8rem, 18px);
}

section.welfare div.welfare_wrap02 li.day_off_li + li.day_off_li {
  /* margin-top: min(1.6rem, 16px); */
  margin-top: min(1.2rem, 12px);
}

section.welfare:nth-of-type(2) {
  width: 100%;
  background-color: #F8F8F8;
}

section.welfare:nth-of-type(2) div.welfare_wrap01 {
  margin-top: 0;
}

section.welfare:nth-of-type(2) div.welfare_wrap01 div.image_area {
  margin-left: auto;
}

section.welfare:nth-of-type(2) div.welfare_wrap01 div.welfare_item01 {
  left: 0;
}
.okayama_welfare section.welfare:nth-of-type(2) div.welfare_wrap01 div.welfare_item01 {
  /* margin-top: min(2rem, 40px); */
}

section.welfare div.welfare_wrap03 {
  /* margin-top: min(6.4rem, 64px); */
  /* margin-top: min(5.2rem, 52px); */
  margin-top: min(4.8rem, 48px);
}

main.fujisawa_welfarea section.welfare div.welfare_wrap03 {
  /* margin-top: min(6.4rem, 64px); */
  /* margin-top: min(5.2rem, 52px); */
  margin-top: min(9rem, 90px);
}

section.welfare div.welfare_wrap03 h3.h3_ttl {
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  text-align: center;
  color: #6CC04A;
  /* padding-bottom: min(1.6rem, 16px); */
  padding-bottom: min(1.2rem, 12px);
  border-bottom: 1px solid #ADB2AA;
}

section.welfare div.welfare_wrap03 ul.point_ul {
  /* margin-top: min(11rem, 110px); */
  /* margin-top: min(8.8rem, 88px); */
  margin-top: min(8rem, 80px);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  /* gap: min(2.4rem, 24px); */
  /* gap: min(2rem, 20px); */
  gap: min(1.8rem, 18px);
}

section.welfare div.welfare_wrap03 ul.point_ul li.point_li {
  padding: min(2rem, 20px) 0;
  border: min(.2rem, 2px) solid #6CC04A;
  background-color: #fff;
  /* font-size: min(2.4rem, 24px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 500;
  text-align: center;
  position: relative;
  letter-spacing: -.04em;
}

section.welfare div.welfare_wrap03 ul.point_ul li.point_li::before {
  position: absolute;
  display: block;
  content: '';
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(7rem, 70px); */
  /* width: min(5.6rem, 56px); */
  width: min(5.2rem, 52px);
  /* height: min(6rem, 60px); */
  /* height: min(4.8rem, 48px); */
  height: min(4.4rem, 44px);
  left: 0;
  top: 0;
  transform: translateY(-100%);
}

section.welfare div.welfare_wrap03 ul.point_ul li.point_li:nth-of-type(1):before {
  background-image: url(img/_fujisawa_welfare/num_01.png);
}

section.welfare div.welfare_wrap03 ul.point_ul li.point_li:nth-of-type(2):before {
  background-image: url(img/_fujisawa_welfare/num_02.png);
}

section.welfare div.welfare_wrap03 ul.point_ul li.point_li:nth-of-type(3):before {
  background-image: url(img/_fujisawa_welfare/num_03.png);
}

section.welfare div.welfare_wrap04 {
  width: 100%;
  background-color: #6CC04A;
  /* padding: min(5.6rem, 56px) min(7.5rem, 75px); */
  /* padding: min(4.4rem, 44px) min(6rem, 60px); */
  padding: min(4rem, 40px) min(5.4rem, 54px);
  box-shadow: 4px 4px 0 rgba(0 0 0 / .2);
}

section.welfare div.welfare_wrap04 h3.h3_ttl {
  /* font-size: min(4rem, 40px); */
  /* font-size: min(3.2rem, 32px); */
  font-size: min(3rem, 30px);
  text-align: center;
  font-weight: 700;
  /* padding-bottom: min(2rem, 20px); */
  /* padding-bottom: min(1.6rem, 16px); */
  padding-bottom: min(1.4rem, 14px);
  border-bottom: 2px solid #fff;
  color: #fff;
  letter-spacing: .4em;
}

section.welfare div.welfare_wrap04 ul.other_ul {
  /* margin-top: min(2rem, 20px); */
  /* margin-top: min(1.6rem, 16px); */
  margin-top: min(1.4rem, 14px);
}

section.welfare div.welfare_wrap04 ul.other_ul li.other_li {
  width: 100%;
  background-color: #fff;
  /* padding: min(1.6rem, 16px) 0; */
  padding: min(1.4rem, 14px) 0;
  text-align: center;
  /* font-size: min(2.4rem, 24px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 500;
}

section.welfare div.welfare_wrap04 ul.other_ul li.other_li + li.other_li {
  margin-top: min(.2rem, 2px);
}

@media (max-width: 799px) {
  
  section.welfare div.container {
    padding-right: 0;
    padding-left: 0;
  }

  section.welfare div.welfare_wrap01 {
    margin-top: 5.8rem;
  }

  section.welfare div.welfare_wrap01 p.common_txt {
    width: 80%;
    margin: 0 auto 2.4rem;
    text-align: left;
  }
  
  section.welfare div.welfare_wrap01 div.image_area {
    width: 100%;
  }
  
  section.welfare div.welfare_wrap01 div.welfare_item01 {
    width: 90%;
    padding: 2.0rem 1.6rem;
    top: 17.0rem;
    right: 0;
    left: 0;
    margin: auto;
  }
  
  main.okayama_welfare section.welfare div.welfare_wrap01 div.welfare_item01 {
    top: 27.0rem;
  }
	
	  main.okayama_welfare section.welfare div.welfare_wrap01 div.welfare_item01.welfare_item02 {
    top: 17.0rem;
  }
  
  section.welfare div.welfare_wrap01 div.welfare_item01 h3.h3_ttl {
    font-size: 2.0rem;
    padding-bottom: 1.0rem;
    border-bottom: .1rem solid #fff;
  }
  
  section.welfare div.welfare_wrap01 div.welfare_item01 p.welfare_txt {
    font-size: 2.4rem;
    margin-top: 1.0rem;
  }
  
  section.welfare div.welfare_wrap01 div.welfare_item01 p.welfare_txt span {
    font-size: 1.2rem;
    margin-top: .4rem;
  }
  
  section.welfare div.welfare_wrap01 div.welfare_item01 ul.welfare_ul {
    margin-top: 1.0rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .2rem;
  }
  
  section.welfare div.welfare_wrap01 div.welfare_item01 ul.welfare_ul li.welfare_li {
    padding: .8rem 0;
    font-size: 1.2rem;
  }
  
  section.welfare div.welfare_wrap02 {
    margin: 23.2rem auto 0;
    width: 90%;
    padding: 4.6rem 2.0rem 2.4rem;
    border: .2rem solid #6CC04A;
  }
  
  section.welfare div.welfare_wrap02 h3.h3_ttl {
    width: 25.0rem;
    padding: 1.0rem 0;
    border: .2rem solid #6CC04A;
    font-size: 1.8rem;
  }
  
  section.welfare div.welfare_wrap02 li.day_off_li {
    font-size: 1.6rem;
    display: flex;
    align-items: start;
    gap: 1.2rem;
    line-height: 1.4;
  }
  
  section.welfare div.welfare_wrap02 li.day_off_li span {
    flex: 1;
  }
  
  section.welfare div.welfare_wrap02 li.day_off_li::before {
    width: 2.0rem;
    height: 2.0rem;
    margin-top: .3rem;
  }
  
  section.welfare div.welfare_wrap02 li.day_off_li + li.day_off_li {
    margin-top: .8rem;
  }
  
  main.fujisawa_welfarea section.welfare div.welfare_wrap03 {
    margin-top: 30rem;
  }

	main.okayama_welfare section.welfare div.welfare_wrap03 {
    margin-top: 13.2rem;
  }
  
  section.welfare div.welfare_wrap03 h3.h3_ttl {
    width: 90%;
    margin: 0 auto;
    font-size: 1.8rem;
    padding-bottom: .8rem;
    border-bottom: .1rem solid #ADB2AA;
  }
  
  section.welfare div.welfare_wrap03 ul.point_ul {
    margin: 3.2rem auto 0;
    width: 90%;
    display: grid;
    grid-template-columns: 1fr;
    gap: 3.2rem;
  }
  
  section.welfare div.welfare_wrap03 ul.point_ul li.point_li {
    padding: 1.2rem 0;
    border: .2rem solid #6CC04A;
    font-size: 1.4rem;
    letter-spacing: .1em;
    text-align: left;
    text-indent: 5.5em;
  }
  
  section.welfare div.welfare_wrap03 ul.point_ul li.point_li::before {
    background-color: #fff;
    width: 6.6rem;
    height: 5.0rem;
    left: 1%;
    top: auto;
    bottom: 8%;
    transform: none;
  }
  
  section.welfare div.welfare_wrap04 {
    width: 90%;
    margin: 0 auto;
    padding: 1.6rem 2.0rem;
  }
  
  section.welfare div.welfare_wrap04 h3.h3_ttl {
    font-size: 2.0rem;
    padding-bottom: 1.0rem;
    border-bottom: .2rem solid #fff;
  }
  
  section.welfare div.welfare_wrap04 ul.other_ul {
    margin-top: 1.6rem;
  }
  
  section.welfare div.welfare_wrap04 ul.other_ul li.other_li {
    padding: .8rem 0;
    font-size: 1.4rem;
  }
  
  section.welfare div.welfare_wrap04 ul.other_ul li.other_li + li.other_li {
    margin-top: .2rem;
  }
}

/* ----- fujisawa_recruit ----- */

main.fujisawa_recruit section.recruit h2.common_h2_02::after {
  content: 'Recruitment';
}

main.inner section.recruit div.container {
  /* max-width: 1240px; */
  /* max-width: 1040px; */
  max-width: 960px;
}

main.inner section.recruit h3.recruit_h3 {
  /* font-size: min(3.2rem, 32px); */
  font-size: min(2.8rem, 28px);
  font-weight: 700;
  color: #6CC04A;
}

main.inner section.recruit h3.recruit_h3:first-of-type {
  /* margin-top: min(12rem, 120px); */
  margin-top: min(10.8rem, 108px);
}

main.inner section.recruit h3.recruit_h3:not(:first-of-type) {
  /* margin-top: min(4.8rem, 48px); */
  margin-top: min(4.4rem, 44px);
  /* padding-top: min(2rem, 20px); */
  padding-top: min(1.8rem, 18px);
  border-top: 2px solid #E8E8E8;
}

main.inner section.recruit p.common_txt {
  text-align: justify;
  /* margin-top: min(2rem, 20px); */
  margin-top: min(1.8rem, 18px);
}

main.inner section.recruit p.common_txt span {
  color: #E25555;
}

main.inner section.recruit a.recruit_txt {
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 500;
  color: #0093FF;
  display: flex;
  align-items: center;
  /* gap: min(1.2rem, 12px); */
  gap: min(1rem, 10px);
  cursor: pointer;
}

main.inner section.recruit a.recruit_txt::before {
  display: block;
  content: '';
  background-image: url(img/_fujisawa_recruit/icon_marker.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(2.4rem, 24px); */
  width: min(2.2rem, 22px);
  height: min(2.8rem, 28px);
}

main.inner section.flow {
  background-color: #6CC04A;
}

main.inner section.flow h2.common_h2_02 {
  color: #fff;
  border-color: #fff;
}

main.inner section.flow h2.common_h2_02::after {
  color: #fff;
  content: 'Recruitment flow';
}

main.inner section.flow div.flow_wrap {
  /* margin: min(10rem, 100px) auto 0; */
  margin: min(9rem, 90px) auto 0;
  /* width: min(108rem, 1080px); */
  /* width: min(88rem, 880px); */
  width: min(80rem, 800px);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  /* gap: min(8.4rem, 84px); */
  gap: min(7.8rem, 78px);
}

main.inner section.flow div.flow_wrap div.flow_item {
  border: 4px solid #fff;
  /* padding: 0 0 min(3.2rem, 32px); */
  /* padding: 0 0 min(2.6rem, 26px); */
  padding: 0 0 min(2.4rem, 24px);
  position: relative;
}

main.inner section.flow div.flow_wrap div.flow_item:not(:last-of-type):after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/_fujisawa_recruit/icon_arrow_recruit.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(6rem, 60px); */
  /* width: min(4.8rem, 48px); */
  width: min(4.4rem, 44px);
  /* height: min(6rem, 60px); */
  /* height: min(4.8rem, 48px); */
  height: min(4.4rem, 44px);
  top: 0;
  bottom: 0;
  margin: auto;
  right: 0;
  transform: translateX(min(6.4rem, 64px));
}

main.inner section.flow div.flow_wrap div.flow_item h3.flow_h3 {
  font-family: 'Montserrat', sans-serif;
  color: #fff;
  /* font-size: min(3rem, 30px); */
  /* font-size: min(2.4rem, 24px); */
  font-size: min(2.2rem, 22px);
  font-weight: 500;
  color: #6CC04A;
  text-align: center;
  background-color: #fff;
  /* padding: min(2.4rem, 24px) 0; */
  /* padding: min(2rem, 20px) 0; */
  padding: min(1.8rem, 18px) 0;
}

main.inner section.flow div.flow_wrap div.flow_item div.icon {
  /* margin: min(3.2rem, 32px) auto 0; */
  /* margin: min(2.6rem, 26px) auto 0; */
  margin: min(2.4rem, 24px) auto 0;
  /* width: min(10rem, 100px); */
  /* width: min(8rem, 80px); */
  width: min(7.2rem, 72px);
}

main.inner section.flow div.flow_wrap div.flow_item p.flow_txt {
  /* margin: min(1.6rem, 16px) auto 0; */
  /* margin: min(1.2rem, 12px) auto 0; */
  margin: min(1.1rem, 11px) auto 0;
  /* font-size: min(2.4rem, 24px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 500;
  color: #fff;
  text-align: center;
}

main.inner section.flow a.link_apply {
  /* margin-top: min(7.6rem, 76px); */
  /* margin-top: min(6rem, 60px); */
  margin-top: min(5.4rem, 54px);
  box-shadow: unset;
}

main.inner section.flow a.privacypolicy {
  display: block;
  color: #fff;
  /* margin-top: min(4.4rem, 44px); */
  /* margin-top: min(3.6rem, 36px); */
  margin-top: min(3.3rem, 33px);
  text-align: center;
  /* font-size: min(2.2rem, 22px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  text-align: center;
}

@media (max-width: 799px) {
  
  main.inner section.recruit div.container {
    max-width: 100%;
  }
  
  main.inner section.recruit h3.recruit_h3 {
    font-size: 2.2rem;
  }
  
  main.inner section.recruit h3.recruit_h3:first-of-type {
    margin-top: 8.6rem;
  }
  
  main.inner section.recruit h3.recruit_h3:not(:first-of-type) {
    margin-top: 3.2rem;
    padding-top: 1.2rem;
    border-top: .2rem solid #E8E8E8;
  }
  
  main.inner section.recruit p.common_txt {
    margin-top: 1.2rem;
    letter-spacing: 0em;
  }
  
  main.inner section.recruit a.recruit_txt {
    margin-top: .8rem;
    font-size: 1.4rem;
    gap: .8rem;
  }
  
  main.inner section.recruit a.recruit_txt::before {
    width: 1.6rem;
    height: 2.0rem;
  }
  
  main.inner section.flow div.flow_wrap {
    margin: 5.2rem auto 0;
    width: 18.0rem;
    grid-template-columns: 1fr;
    gap: 4.8rem;
  }
  
  main.inner section.flow div.flow_wrap div.flow_item {
    border: .4rem solid #fff;
    padding: 0 0 2.0rem;
  }
  
  main.inner section.flow div.flow_wrap div.flow_item:not(:last-of-type):after {
    background-image: url(img/_fujisawa_recruit/icon_arrow_down_flow_sp.png);
    width: 2.6rem;
    height: 2.6rem;
    top: auto;
    bottom: -2.4rem;
    margin: auto;
    right: 0;
    left: 0;
    transform: translateX(0);
    transform: translateY(50%);
  }
  
  main.inner section.flow div.flow_wrap div.flow_item h3.flow_h3 {
    font-size: 1.7rem;
    padding: 1.4rem 0;
  }
  
  main.inner section.flow div.flow_wrap div.flow_item div.icon {
    margin: 2.0rem auto 0;
    width: 4.0rem;
  }
  
  main.inner section.flow div.flow_wrap div.flow_item p.flow_txt {
    margin: 1.0rem auto 0;
    font-size: 1.6rem;
  }
  
  main.inner section.flow a.link_apply {
    margin-top: 4.0rem;
    width: 100%;
  }
  
  main.inner section.flow a.privacypolicy {
    display: block;
    color: #fff;
    margin-top: 4.4rem;
    text-align: center;
    font-size: 2.2rem;
    font-weight: 500;
    text-align: center;
  }
}

/* ----- okayama_recruit ----- */

main.okayama_recruit section.recruit h2.common_h2_02::after {
  content: 'Recruitment';
}

/* ----- fujisawa_salary_html ----- */
/* ----- okayama_salary_html ----- */

main.inner section.salary div.container {
  /* max-width: 1190px; */
  /* max-width: 1040px; */
  max-width: 960px;
}

main.inner section.salary h2.common_h2_02::after {
  content: 'Salary・Allowance';
}

main.inner section.salary h3.salary_h3 {
  /* font-size: min(4rem, 40px); */
  /* font-size: min(3.2rem, 32px); */
  font-size: min(3rem, 30px);
  font-weight: 700;
  text-align: center;
  color: #194B04;
  /* padding-bottom: min(1.6rem, 16px); */
  /* padding-bottom: min(1.6rem, 16px); */
  padding-bottom: min(1.4rem, 14px);
  border-bottom: 2px solid #E8E8E8;
}

main.inner section.salary h3.salary_h3:first-of-type {
  /* margin-top: min(12.8rem, 128px); */
  margin-top: min(11.8rem, 118px);
}

main.inner section.salary h3.salary_h3:last-of-type {
  /* margin-top: min(9.6rem, 96px); */
  margin-top: min(8.8rem, 88px);
}

main.inner section.salary h4.salary_h4 {
  /* margin-top: min(4rem, 40px); */
  /* margin-top: min(3.2rem, 32px); */
  margin-top: min(3rem, 30px);
  /* font-size: min(2.6rem, 26px); */
  /* font-size: min(2rem, 20px); */
  font-size: min(1.8rem, 18px);
  font-weight: 500;
  text-align: center;
  color: #fff;
  background-color: #6CC04A;
  padding: min(1.2rem, 12px) 0;
}

main.inner section.salary p.salary_txt {
  /* font-size: min(3rem, 30px); */
  /* font-size: min(2.4rem, 24px); */
  font-size: min(2.2rem, 22px);
  font-weight: 500;
  text-align: center;
  margin-top: min(2.4rem, 24px);
  line-height: 1.4;
}

main.inner section.salary p.salary_txt02 {
  font-family: 'Oswald', sans-serif;
}

main.inner section.salary p.salary_txt span {
  /* font-size: min(6rem, 60px); */
  /* font-size: min(4.8rem, 48px); */
  font-size: min(4.4rem, 44px);
}

main.inner section.salary p.salary_txt small {
  display: block;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.6rem, 16px); */
  font-size: min(1.4rem, 14px);
  /* margin-top: min(3.2rem, 32px); */
  /* margin-top: min(2.6rem, 26px); */
  margin-top: min(2rem, 20px);
}

main.inner section.salary p.salary_txt small small {
  display: inline-block;
  font-size: min(1.1rem, 11px);
  margin-top: 0;
}

main.inner section.salary table.salary_table {
  width: 100%;
  border: min(0.2rem, 2px) solid #fff;
}

main.inner section.salary table.salary_table th {
  width: 40%;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  color: #fff;
  text-align: center;
  padding: min(1.2rem, 12px) 0;
  background-color: #85D963;
  border: 2px solid #fff;
}

main.inner section.salary table.salary_table td {
  width: 60%;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  text-align: center;
  padding: min(1.2rem, 12px) 0;
  background-color: #F2F2F2;
  border: 2px solid #fff;
}

@media (max-width: 799px) {
  main.inner section.salary div.container {
    max-width: 100%;
  }
  
  main.inner section.salary h3.salary_h3 {
    font-size: 2.2rem;
    color: #6CC04A;
    padding-bottom: .8rem;
    border-bottom: .2rem solid #E8E8E8;
  }
  
  main.inner section.salary h3.salary_h3:first-of-type {
    margin-top: 8.6rem;
  }
  
  main.inner section.salary h3.salary_h3:last-of-type {
    margin-top: 6.4rem;
  }
  
  main.inner section.salary h4.salary_h4 {
    margin-top: 1.6rem;
    font-size: 1.6rem;
    padding: .8rem 0;
  }
  
  main.inner section.salary p.salary_txt {
    font-size: 1.6rem;
    margin-top: 1.2rem;
  }
  
  main.inner section.salary p.salary_txt span {
    font-size: 3.2rem;
  }
  
  main.inner section.salary p.salary_txt small {
    display: block;
    font-size: 1.2rem;
    margin-top: 1.6rem;
    line-height: 1.4;
  }
  
  main.inner section.salary p.salary_txt small small {
    font-size: 1.1rem;
  }
  
  main.inner section.salary table.salary_table {
    width: 100%;
    border: .2rem solid #fff;
  }
  
  main.inner section.salary table.salary_table th {
    width: 65%;
    font-size: 1.6rem;
    text-align: left;
    padding: .8rem .4rem;
    border: .2rem solid #fff;
    letter-spacing: -.04em;
  }
  
  main.inner section.salary table.salary_table td {
    width: 35%;
    font-size: 1.6rem;
    text-align: left;
    padding: .8rem .4rem;
    border: .2rem solid #fff;
    letter-spacing: -.04em;
  }
}

/* ----- fujisawa_job ----- */

main.inner section.job {
  width: 100%;
  position: relative;
}

main.inner section.job::after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/_fujisawa_job/bg_job_pc.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  /* max-width: 1720px; */
  /* max-width: 1380px; */
  max-width: 1240px;
  /* height: min(305rem, 3050px); */
  /* height: min(244rem, 2440px); */
  height: min(220rem, 2200px);
  right: 0;
  left: 0;
  margin: auto;
  top: auto;
  bottom: min(6rem, 60px);
  z-index: -1;
}

main.inner section.job h2.common_h2_02::after {
  content: 'Job description';
}

main.inner section.job h3.job_h3 {
  /* margin-top: min(10.4rem, 104px); */
  /* margin-top: min(9.3rem, 83px); */
  margin-top: min(7.6rem, 76px);
  /* font-size: min(4rem, 40px); */
  /* font-size: min(3.2rem, 32px); */
  font-size: min(3.0rem, 30px);
  font-weight: 500;
  text-align: center;
  color: #fff;
  background-color: #6CC04A;
  /* padding: min(2rem, 20px) 0; */
  padding: min(1.6rem, 16px) 0;
}

main.inner section.job ul.job_ul {
  /* margin-top: min(9.5rem, 95px); */
  /* margin-top: min(7.6rem, 76px); */
  margin-top: min(7rem, 70px);
  border: 2px solid #6CC04A;
  /* padding: min(6rem, 60px) min(6rem, 60px) min(3.6rem, 36px); */
  /* padding: min(4.8rem, 48px) min(4.8rem, 48px) min(2.8rem, 28px); */
  padding: min(4rem, 40px) min(4rem, 40px) min(2.6rem, 26px);
  position: relative;
  background-color: #fff;
}

main.inner section.job ul.job_ul h4.job_h4 {
  position: absolute;
  /* width: min(80rem, 800px); */
  /* width: min(64rem, 640px); */
  width: min(60rem, 600px);
  /* font-size: min(3.2rem, 32px); */
  /* font-size: min(2.6rem, 26px); */
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  text-align: center;
  padding: min(1.2rem, 12px) 0;
  background-color: #fff;
  border: 2px solid #6CC04A;
  color: #6CC04A;
  right: 0;
  left: 0;
  margin: auto;
  top: 0;
  transform: translateY(-50%);
}

main.inner section.job ul.job_ul li.job_li {
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
}

main.inner section.job ul.job_ul li.job_li + li.job_li {
  /* margin-top: min(2rem, 20px); */
  margin-top: min(1.6rem, 16px);
}

main.inner section.job h5.job_h5 {
  margin-top: min(6.4rem, 64px);
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  color: #194B04;
  padding-bottom: min(1.6rem, 16px);
  border-bottom: 3px solid #6CC04A;
}

main.inner section.job p.job_h5_sttl {
  margin-top: min(1.6rem, 16px);
  font-size: min(1.6rem, 16px);
  font-weight: 500;
}

main.inner section.job div.job_item {
  /* margin-top: min(6.4rem, 64px); */
  /* margin-top: min(4.8rem, 48px); */
  margin-top: min(4.4rem, 44px);
  display: flex;
  align-items: center;
  /* gap: min(5.6rem, 56px); */
  /* gap: min(4.4rem, 44px); */
  gap: min(4rem, 40px);
}

main.inner section.job div.job_item div.image_area {
  /* width: min(70rem, 700px); */
  /* width: min(56rem, 560px); */
  width: min(52rem, 520px);
}

main.inner section.job div.job_item div.txt_area {
  flex: 1;
}

main.inner section.job div.job_item div.txt_area p.job_ttl {
  /* font-size: min(3.2rem, 32px); */
  /* font-size: min(2.6rem, 26px); */
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  color: #194B04;
}

main.inner section.job div.job_item:first-of-type div.txt_area p.job_ttl {
  letter-spacing: -.04em;
}

main.inner section.job div.job_item div.txt_area p.job_ttl span {
  display: inline-block;
  /* font-size: min(8.3rem, 83px); */
  /* font-size: min(6.6rem, 66px); */
  font-size: min(5.6rem, 56px);
  font-weight: 500;
  color: #6CC04A;
  margin-right: min(0.8rem, 8px);
}

main.inner section.job div.job_item div.txt_area p.job_txt {
  /* margin-top: min(2.4rem, 24px); */
  /* margin-top: min(2rem, 20px); */
  margin-top: min(1.8rem, 18px);
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  line-height: 2;
}

main.inner section.job_welcome {
  width: 100%;
  background-image: url(img/_fujisawa_job/bg_job_welcome_pc.jpg);
  background-size: cover;
  background-position: center center;
  /* margin-bottom: min(12rem, 120px); */
  /* margin-bottom: min(9.6rem, 96px); */
  margin-bottom: min(8.8rem, 88px);
}

main.inner section.job_welcome p.job_welcome_ttl {
  /* font-size: min(4.8rem, 48px); */
  /* font-size: min(3.8rem, 38px); */
  font-size: min(3.4rem, 34px);
  font-weight: 700;
  text-align: center;
  color: #fff;
}

main.inner section.job_welcome p.job_welcome_txt {
  /* margin-top: min(3.7rem, 37px); */
  /* margin-top: min(3rem, 30px); */
  margin-top: min(2.7rem, 27px);
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  line-height: 2;
  text-align: center;
  color: #fff;
}

main.inner section.job_welcome div.job_welcome_wrap {
  /* width: min(102rem, 1020px); */
  /* width: min(82rem, 820px); */
  width: min(76rem, 760px);
  display: flex;
  /* margin: min(5.6rem, 56px) auto 0; */
  /* margin: min(4.4rem, 44px) auto 0; */
  margin: min(4rem, 40px) auto 0;
  /* gap: min(7.2rem, 72px); */
  /* gap: min(5.6rem, 56px); */
  gap: min(5rem, 50px);
}

main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item {
  width: calc((100% - min(5rem, 50px)) / 2);
  background-color: #fff;
  /* padding: min(4rem, 40px) 0; */
  /* padding: min(3.2rem, 32px) 0; */
  padding: min(3rem, 30px) 0;
}

main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item div.icon {
  /* width: min(6.4rem, 64px); */
  /* width: min(5.2rem, 52px); */
  width: min(4.8rem, 48px);
  margin: 0 auto;
}

main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item p.job_welcome_ttl {
  /* font-size: min(3.2rem, 32px); */
  /* font-size: min(2.6rem, 26px); */
  font-size: min(2.4rem, 24px);
  text-align: center;
  /* margin-top: min(3.2rem, 32px); */
  /* margin-top: min(2.6rem, 26px); */
  margin-top: min(2.4rem, 24px);
  font-weight: 700;
  color: #6CC04A;
}

main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item p.job_welcome_txt {
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  text-align: center;
  /* margin: min(3.2rem, 32px) auto 0; */
  /* margin: min(2.6rem, 26px) auto 0; */
  margin: min(2.4rem, 24px) auto 0;
  width: 80%;
  font-weight: 500;
  color: #4B4B4B;
  text-align: justify;
}

@media (max-width: 799px) {
  
  main.inner section.job::after {
    position: absolute;
    display: block;
    content: '';
    background-image: url(img/_fujisawa_job/bg_job_pc.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    max-width: 95%;
    height: 406.6rem;
    right: 0;
    left: 0;
    margin: auto;
    top: auto;
    bottom: 6.0rem;
    z-index: -1;
  }
  
  main.inner section.job div.container {
    padding-bottom: 9.6rem;
  }

  main.inner section.job h3.job_h3 {
    margin-top: 5.4rem;
    font-size: 2.0rem;
    padding: 1.0rem 0;
  }
  
  main.inner section.job ul.job_ul {
    margin-top: 5.0rem;
    border: .2rem solid #6CC04A;
    padding: 3.6rem 2.0rem 3.2rem;
  }
  
  main.inner section.job ul.job_ul h4.job_h4 {
    width: 25.6rem;
    font-size: 1.7rem;
    padding: .8rem 0;
    background-color: #fff;
    border: .2rem solid #6CC04A;
  }
  
  main.inner section.job ul.job_ul li.job_li {
    font-size: 1.6rem;
    line-height: 1.6;
  }
  
  main.inner section.job ul.job_ul li.job_li + li.job_li {
    margin-top: 0;
  }

  main.inner section.job h5.job_h5 {
    margin-top: 4.8rem;
    font-size: 2.4rem;
    padding-bottom: .8rem;
    border-bottom: .3rem solid #6CC04A;
  }
  
  main.inner section.job p.job_h5_sttl {
    margin-top: .8rem;
    font-size: 1.4rem;
    line-height: 1.4;
  }
  
  main.inner section.job div.job_item:first-of-type, 
  main.inner section.job div.job_item:nth-of-type(3) {
    margin-top: 0.8rem;
  }

  main.inner section.job div.job_item {
    margin-top: 4.8rem;
    flex-direction: column;
    align-items: start;
    gap: 2.4rem;
  }
  
  main.inner section.job div.job_item p.job_ttl {
    font-size: 2.4rem;
    font-weight: 700;
    text-align: left;
    line-height: 1.6;
  }
  
  main.inner section.job div.job_item p.job_ttl span {
    font-family: 'Oswald', sans-serif;
    font-size: 5.6rem;
    font-weight: 500;
    color: #6CC04A;
  }
  
  main.inner section.job div.job_item div.image_area {
    width: 100%;
  }
  
  main.inner section.job div.job_item div.txt_area {
    width: 100%;
  }
  
  main.inner section.job div.job_item div.txt_area p.job_ttl {
    font-size: 3.2rem;
    font-weight: 700;
    color: #194B04;
  }
  
  main.inner section.job div.job_item div.txt_area p.job_ttl span {
    display: inline-block;
    font-size: 8.3rem;
    font-weight: 500;
    color: #6CC04A;
    margin-right: .8rem;
  }
  
  main.inner section.job div.job_item div.txt_area p.job_txt {
    margin-top: 2.4rem;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 2;
  }
  
  main.inner section.job_welcome {
    width: 100%;
    background-image: url(img/_fujisawa_job/bg_job_welcome_sp.jpg);
    background-size: cover;
    background-position: center center;
    margin-bottom: 6.4rem;
  }
  
  main.inner section.job_welcome p.job_welcome_ttl {
    font-size: 2.4rem;
    line-height: 1.4;
  }
  
  main.inner section.job_welcome p.job_welcome_txt {
    margin-top: 1.6rem;
    font-size: 1.6rem;
    line-height: 1.6;
    text-align: justify;
  }
  
  main.inner section.job_welcome div.job_welcome_wrap {
    width: 100%;
    flex-direction: column;
    margin: 3.2rem auto 0;
    gap: 3.2rem;
  }
  
  main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item {
    width: 100%;
    padding: 3.2rem 0;
    box-shadow: .4rem .4rem 1.0rem rgba(25 75 4 / .2);
  }
  
  main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item div.icon {
    width: 4.8rem;
    margin: 0 auto;
  }
  
  main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item p.job_welcome_ttl {
    font-size: 2.4rem;
    margin-top: 1.6rem;
  }
  
  main.inner section.job_welcome div.job_welcome_wrap div.job_welcome_item p.job_welcome_txt {
    font-size: 1.6rem;
    text-align: justify;
    margin: 1.6rem auto 0;
    width: 90%;
  }
}

/* ----- okayama_job.html ----- */

main.okayama_job section.job h3.job_h3 {
  line-height: 1.2;
}

@media (max-width: 799px) {
  
  main.okayama_job section.job h3.job_h3 {
    text-align: justify;
    padding: 1rem .8rem;
    line-height: 1.6;
  }
}

/* ----- fujisawa_form.html ---- */

main.index section.form div.container, 
main.index section.confirm div.container {
  /* max-width: 860px; */
  max-width: 800px;
}

main.index section.form p.common_txt {
  font-size: min(1.4rem, 14px);
}

main.index section.form h2.common_h2_02::after {
  content: 'Apply form';
}

main.index section.form p.common_txt, 
main.index section.confirm p.common_txt {
  /* margin-top: min(10.4rem, 104px); */
  /* margin-top: min(8rem, 80px); */
  margin-top: min(7.2rem, 72px);
}

main.index form {
  width: 100%;
  /* margin-top: min(8rem, 80px); */
  /* margin-top: min(6.4rem, 64px); */
  margin-top: min(5.8rem, 58px);
}

main.index div.form_item {
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
} 

main.index div.form_item + div.form_item {
  /* margin-top: min(4rem, 40px); */
  /* margin-top: min(3.2rem, 32px); */
  margin-top: min(3rem, 30px);
}

main.index div.form_item label {
  display: block;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 700;
} 

main.index div.form_item label span {
  color: #FF3100;
}
main.index div.form_item label span.mwform-radio-field-text {
  color: #4B4B4B;
}

main.index div.form_item input,
main.index div.form_item select,
main.index div.form_item textarea{
  display: block;
  width: 100%;
  margin-top: min(1.2rem, 12px);
  background-color: #F2F2F2;
  border: 1px solid #E8E8E8;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 15px);
  font-weight: 500;
  /* padding: min(2.4rem, 24px); */
  /* padding: min(2rem, 20px); */
  padding: min(1.2rem, 12px) min(1.6rem, 16px);
	-moz-appearance: none;
-webkit-appearance: none;/need for safari/
appearance: none;
	border-radius: 0px;
}
main.index div.form_item p {
  display: block;
  width: 100%;
  /* margin-top: min(1.2rem, 12px); */
  margin-top: min(1rem, 10px);
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
  font-weight: 500;
  /* padding: min(2.4rem, 24px); */
  /* padding: min(2rem, 20px); */
  padding: min(1.2rem, 12px) min(1.6rem, 16px);
}

.mwform-tel-field {
	display: flex;
	align-items: center;
	gap:min(1.5rem, 15px);
	/* font-size: min(1.8rem, 18px); */
	font-size: min(1.6rem, 16px);
}

main.index input.form_btn {
  /* margin: min(8rem, 80px) auto 0; */
  /* margin: min(6.4rem, 64px) auto 0; */
  margin: min(5.8rem, 58px) auto 0;
  /* width: min(67rem, 670px); */
  /* width: min(54rem, 540px); */
  width: min(50rem, 500px);
  background-color: #6CC04A;
  color: #fff;
  /* padding: min(2.8rem, 28px) 0; */
  /* padding: min(2.2rem, 22px) 0; */
  padding: min(2rem, 20px) 0;
  border-radius: 99px;
  text-align: center;
  /* font-size: min(3rem, 30px); */
  /* font-size: min(2.4rem, 24px); */
  font-size: min(2.2rem, 22px);
  font-weight: 700;
  position: relative;
  box-shadow: min(.6rem, 6px) min(.6rem, 6px) 0 rgba(0 0 0 / .2);
  cursor: pointer;
  transition: all .4s;
	border: none;
	display: block;
	
}

main.index input.form_btn::after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/icon_arrow_white.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(2rem, 20px); */
  /* width: min(1.6rem, 16px); */
  width: min(1.4rem, 14px);
  /* height: min(3.5rem, 35px); */
  height: min(2.8rem, 28px);
  height: min(2.6rem, 26px);
  /* right: min(5rem, 50px); */
  right: min(4rem, 40px);
  top: 0;
  bottom: 0;
  margin: auto;
  transition: all .4s;
}
.privacy {
	margin-top: min(3.2rem, 32px);
}
.privacy h3 {
	margin-bottom: min(2rem, 30px);
}
.privacy p {
	margin-bottom: min(2rem, 30px);
		line-height: 2em;
  /* font-size: min(2rem, 20px); */
  /* font-size: min(1.8rem, 18px); */
  font-size: min(1.6rem, 16px);
}
.privacy .privacypolicy {
	height: min(30rem, 300px);
	overflow-y: scroll;
	background-color: #F2F2F2;
padding: min(3.2rem, 32px);
}
@media (hover: hover) {
  main.index input.form_btn:hover {
    background-color: #fff;
    color: #6CC04A;
    opacity: 1;
  }
  
  main.index input.form_btn:hover:after {
    background-image: url(img/icon_arrow_green.png);
  }
}

@media (max-width: 799px) {
  main.index section.form div.container, 
  main.index section.confirm div.container {
    max-width: 100%;
  }
  
  main.index section.form h2.common_h2_02, 
  main.index section.confirm h2.common_h2_02 {
    width: 100%;
  }
  
  main.index section.form p.common_txt, 
  main.index section.confirm p.common_txt {
    margin-top: 5.2rem;
    text-align: justify;
  }
  
  main.index form {
    margin-top: 2.4rem;
  }
  
  main.index div.form_item + div.form_item {
    margin-top: 2.4rem;
  }
  
  main.index div.form_item label,
	main.index div.form_item label p{
    font-size: 1.6rem;
  }
  
main.index div.form_item input,
main.index div.form_item select,
main.index div.form_item textarea{
    margin-top: .8rem;
    border: .1rem solid #E8E8E8;
    font-size: 1.6rem;
    padding: .8rem 1.2rem;
  }
	
	main.index div.form_item p {
    margin-top: .8rem;
    font-size: 1.6rem;
    padding: .8rem 1.2rem;
  }
  
  main.index input.form_btn {
    margin: 4.0rem auto 0;
    width: 100%;
    padding: 1.4rem 0;
    font-size: 1.4rem;
    box-shadow: .2rem .2rem 0 rgba(0 0 0 / .2);
  }
  
  main.index input.form_btn::after {
    width: 1.0rem;
    height: 1.7rem;
    right: 1.6rem;
  }
	.privacy .privacypolicy {
padding: min(1.6rem, 16px);
}
}

/* ----- confirm.html ----- */

main.index section.confirm h2.common_h2_02::after {
  content: 'Apply confirmation form';
}

main.index section.confirm div.btn_area {
  /* margin: min(8rem, 80px) auto 0; */
  margin: min(6.4rem, 64px) auto 0;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  /* gap: min(14rem, 140px); */
  gap: min(11.2rem, 112px);
}

main.index section.confirm div.btn_area input.form_btn {
  margin-top: 0;
  width: 100%;
}

main.index section.confirm div.btn_area input.form_btn02 {
  background-color: #4B4B4B;
  border-radius: 99px;
  margin: 0 auto;
  width: 100%;
  color: #fff;
  /* padding: min(2.8rem, 28px) 0; */
  padding: min(2.2rem, 22px) 0;
  text-align: center;
  /* font-size: min(3rem, 30px); */
  font-size: min(2.4rem, 24px);
  font-weight: 700;
  position: relative;
  box-shadow: min(.6rem, 6px) min(.6rem, 6px) 0 rgba(0 0 0 / .2);
  cursor: pointer;
  transition: all .4s;
	border:none;
}

main.index section.confirm div.btn_area input.form_btn02::after {
  position: absolute;
  display: block;
  content: '';
  background-image: url(img/icon_arrow_white.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  /* width: min(2rem, 20px); */
  width: min(1.6rem, 16px);
  /* height: min(3.5rem, 35px); */
  height: min(2.8rem, 28px);
  /* right: min(5rem, 50px); */
  right: min(4rem, 40px);
  top: 0;
  bottom: 0;
  margin: auto;
  transition: all .4s;
}

@media (hover: hover) {
  main.index section.confirm div.btn_area input.form_btn02:hover {
    color: #4B4B4B;
    background-color: #fff;
    opacity: 1;
  }
  
  main.index section.confirm div.btn_area input.form_btn02:hover::after {
    background-image: url(img/icon_arrow_black.png);
  }
}

@media (max-width: 799px) {
  
  main.index section.confirm div.btn_area {
    margin: 4.0rem auto 0;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.0rem;
  }
  
  main.index section.confirm div.btn_area input.form_btn {
    margin-top: 0;
    width: 100%;
  }
  
  main.index section.confirm div.btn_area input.form_btn02 {
    width: 100%;
    padding: 1.4rem 0;
    font-size: 1.4rem;
    box-shadow: .2rem .2rem 0 rgba(0 0 0 / .2);
  }
  
  main.index section.confirm div.btn_area input.form_btn02::after {
    width: 1.0rem;
    height: 1.7rem;
    right: 1.6rem;
  }
}

/* ----- thanks_html ----- */

main.inner section.thanks div.thanks_icon {
  /* width: min(15rem, 150px); */
  width: min(12rem, 120px);
  margin: 0 auto;
}

main.inner section.thanks p.common_txt {
  /* margin-top: min(12rem, 120px); */
  margin-top: min(9.6rem, 96px);
}

@media (max-width: 799px) {
  main.inner section.thanks div.thanks_icon {
    width: 7.5rem;
    margin: 0 auto;
  }
  
  main.inner section.thanks p.common_txt {
    margin-top: 8.0rem;
  }
}

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









