@charset "UTF-8";
/**
	* clamp関数の文字列を返す
	*
	* @param {Number} $size-at-min-width - 最小画面幅での要素のサイズ (px|rem|emなど)
	* @param {Number} $size-at-max-width - 最大画面幅での要素のサイズ (px|rem|emなど)
	* @param {Number} $min-width [optional] - 最小画面幅 (デフォルト: $min-width-default)
	* @param {Number} $max-width [optional] - 最大画面幅 (デフォルト: $max-width-default)
	* @return {String} CSS clamp関数を含む計算式
	*
	* @description
	* 画面幅に応じて値が滑らかに変化するレスポンシブな値を生成します。
	* 例えば、フォントサイズやマージン、パディングなどの値を画面幅に応じて
	* 自動的に調整することができます。
	*
	* @example
	*   // フォントサイズを16pxから24pxまで可変させる
	*   font-size: clamp-calc(16px, 24px);
	*
	*   // マージンを2remから4remまで可変させる（画面幅768px～1200px）
	*   margin: clamp-calc(2rem, 4rem, 768px, 1200px);
	*
	* @note
	* - 引数の単位は一貫している必要はありません（px, rem等が混在可能）
	* - 内部で全ての値をpxに変換して計算を行います
	* - 返り値は入力された$size-at-min-widthと同じ単位で返されます
	* - 負の値（マイナスマージンなど）にも対応しています
	*
	* @implementation
	* 1. 入力値を全てpxに変換
	* 2. 線形の傾きを計算
	* 3. y軸との交点を計算
	* 4. 必要に応じて最小値と最大値を入れ替え
	* 5. 元の単位に変換して最終的なclamp関数を構築
*/
/**
	* 与えられた値をピクセル(px)単位に変換する関数
	*
	* @param {Number} $value - 変換したい値（rem または px）
	* @return {Number} 変換後のピクセル値
	*
	* @example
	*   convert-to-px(1.5rem)  // 24px ($base-font-size が 16px の場合)
	*   convert-to-px(20px)    // 20px (そのまま返される)
	*   convert-to-px(2em)     // 2em (非対応の単位はそのまま返される)
	*
	* @description
	* - rem単位の場合: $base-font-sizeを基準にしてpxに変換
	* - px単位の場合: 値をそのまま返す
	* - その他の単位: 変換せずそのまま返す
	*
	* @throws {Error} $base-font-size が定義されていない場合にエラー
 */
/**
	* ピクセル(px)単位の値をrem単位に変換する関数
	*
	* @param {Number} $px-value - 変換したい値（px または rem）
	* @return {Number} 変換後のrem値
	*
	* @example
	*   convert-to-rem(16px)   // 1rem ($base-font-size が 16px の場合)
	*   convert-to-rem(24px)   // 1.5rem ($base-font-size が 16px の場合)
	*   convert-to-rem(1.5rem) // 1.5rem (そのまま返される)
	*   convert-to-rem(2em)    // 2em (非対応の単位はそのまま返される)
	*
	* @description
	* - px単位の場合: $base-font-sizeを基準にしてremに変換
	* - rem単位の場合: 値をそのまま返す
	* - その他の単位: 変換せずそのまま返す
	*
	* @note
	* - レスポンシブデザインに適したrem単位への変換に使用
	* - $base-font-size はグローバルで定義されている必要がある
	*
	* @throws {Error} $base-font-size が定義されていない場合にエラー
 */
/*
	* 補助関数：小数点以下の指定した桁数で四捨五入する関数
*/
/*
	* 補助関数：累乗を計算する関数
	* 引数：$number 底となる数
	*      $exponent 指数（正の整数のみ対応）
 */
@media (max-width: 768px) {
  .sp_none {
    display: none;
  }
}

@media (min-width: 768px) {
  .pc_none {
    display: none;
  }
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 145%;
  letter-spacing: 0.05em;
  font-weight: 400;
  color: #000;
}
@media (max-width: 768px) {
  body {
    font-size: 14px;
  }
}

:target {
  scroll-margin-top: 100px;
}
@media (max-width: 1300px) {
  :target {
    scroll-margin-top: 70px;
  }
}

a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

img {
  display: block;
  width: 100%;
}

a[href*="tel:"] {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
}
@media (max-width: 768px) {
  a[href*="tel:"] {
    pointer-events: auto;
    cursor: pointer;
  }
}

@media (max-width: 768px) {
  a.fax[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

.wrapper {
  position: relative;
  width: 100%;
  max-width: 1300px;
  padding: 0 25px;
  margin: auto;
}
@media (max-width: 768px) {
  .wrapper {
    max-width: 600px;
    padding: 0 5%;
  }
}

.btn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 231px;
  color: #fff;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.04em;
  text-align: left;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: clamp(12px, 8.746px + 1.017vw, 24px);
  background-color: #003E08;
}
@media (max-width: 768px) {
  .btn {
    font-size: 13px;
    padding: 16px;
  }
}

.btn span {
  position: relative;
  z-index: 1;
}

.btn_center .btn {
  margin: 0 auto;
}

.btn::after {
  content: "";
  position: relative;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6.5px 0 6.5px 10px;
  border-color: transparent transparent transparent #FFFFFF;
  -webkit-transition: 0.35s;
  transition: 0.35s;
  right: 0;
}

@media (min-width: 768px) {
  .btn:hover {
    background-color: #009A08;
  }
}

@media (min-width: 768px) {
  .btn:hover::after {
    right: -5px;
  }
}

.text_link {
  display: inline-block;
}

.text_link::after {
  content: "";
  display: block;
  width: 0;
  -webkit-transition: width 0.3s;
  transition: width 0.3s;
  border-bottom: 1px solid #000;
  margin: auto;
}

@media (min-width: 768px) {
  .text_link:hover::after {
    width: 100%;
  }
}

@media (min-width: 768px) {
  .text_link.tel_link {
    vertical-align: top;
  }
}

.text_link.tel_link span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.text_link.tel_link span::before {
  content: "";
  position: relative;
  display: block;
  width: 25px;
  height: 25px;
  background: url(../images/common/icon_tollfreeBrown.svg) no-repeat center center/contain;
}

.body.is_open {
  overflow: hidden;
}

/* loading
----------------------------------------------- */
@-webkit-keyframes scale-zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@keyframes scale-zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.loading {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 500;
  width: 100%;
  height: 100vh;
  background: #fff;
}

.loading figure {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.loading img {
  width: 15rem;
  -webkit-animation: scale-zoom 3s 0s forwards;
          animation: scale-zoom 3s 0s forwards;
}

/* scroll
----------------------------------------------- */
/* Header
------------------------------ */
.header {
  position: fixed;
  width: 100%;
  height: 116px;
  top: 0;
  left: 0;
  z-index: 100;
}
@media (max-width: 1300px) {
  .header {
    height: 100px;
  }
}
@media (max-width: 768px) {
  .header {
    height: 60px;
    padding: 0;
    background-color: #fff;
    z-index: 110;
  }
}

.header_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: inherit;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.customize-support .header {
  top: 32px;
}
@media (max-width: 768px) {
  .customize-support .header {
    top: 46px;
  }
}

@media (max-width: 768px) {
  .customize-support .header.header_fixed {
    top: 0;
  }
}

.header_logo {
  position: relative;
  max-width: clamp(300px, 251.186px + 15.254vw, 480px);
  width: 100%;
  line-height: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  top: 16px;
  left: 16px;
  z-index: 1;
}
@media (max-width: 768px) {
  .header_logo {
    max-width: unset;
    height: 60px;
    margin-top: 0;
    top: 0;
    left: 0;
  }
}

.header_logo a {
  position: relative;
  display: block;
  width: 100%;
}

@media (min-width: 768px) {
  .header_logo a:hover {
    opacity: 0.7;
  }
}

@media (max-width: 768px) {
  .header_logo a img {
    position: relative;
    width: auto;
    height: 47px;
    top: 7px;
    left: clamp(1px, -1.441px + 0.763vw, 10px);
  }
}

.header_menu_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 280px;
  width: 100%;
  gap: 20px;
  padding: 16px 16px 0 0;
}
@media (max-width: 768px) {
  .header_menu_wrapper {
    max-width: 60px;
    padding: 0;
  }
}

.header_entry_btn {
  position: relative;
  max-width: 160px;
  width: 100%;
}
@media (max-width: 768px) {
  .header_entry_btn {
    display: none;
  }
}

.header_entry_btn .btn {
  position: relative;
  display: block;
  max-width: unset;
  font-size: clamp(16px, 14.915px + 0.339vw, 20px);
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  line-height: 120%;
  letter-spacing: 0.08em;
  text-align: center;
  padding: 30px clamp(16px, 13.831px + 0.678vw, 24px);
}

.header_entry_btn .btn::after {
  display: none;
}

.header_hamburger {
  position: relative;
  display: block;
  z-index: 999;
  width: 84px;
  height: 84px;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background-color: #009A08;
}
@media (max-width: 1300px) {
  .header_hamburger {
    display: block;
  }
}
@media (max-width: 768px) {
  .header_hamburger {
    display: block;
    width: 60px;
    height: 60px;
  }
}

.header_hamburger.is_open {
  background-color: #F0F2E4;
}

.header_hamburger_bar {
  position: relative;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: block;
  width: 34px;
  height: 2px;
  background-color: #fff;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

.header_hamburger_bar:nth-of-type(1) {
  top: -10px;
}
.header_hamburger_bar:nth-of-type(2) {
  top: 0;
}
.header_hamburger_bar:nth-of-type(3) {
  top: 10px;
}
.header_hamburger.is_open .header_hamburger_bar:nth-of-type(1) {
  top: 0;
  -webkit-transform: translateX(-50%) rotate(45deg);
          transform: translateX(-50%) rotate(45deg);
  background-color: #000;
}

.header_hamburger.is_open .header_hamburger_bar:nth-of-type(2) {
  opacity: 0;
}

.header_hamburger.is_open .header_hamburger_bar:nth-of-type(3) {
  top: -4px;
  -webkit-transform: translateX(-50%) rotate(-45deg);
          transform: translateX(-50%) rotate(-45deg);
  background-color: #000;
}

.header_drawer {
  display: none;
  position: absolute;
  z-index: 900;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow-y: scroll;
  scrollbar-width: none;
  padding: clamp(90px, 66.678px + 7.288vw, 176px) clamp(20px, 1.559px + 5.763vw, 88px) 100px;
  background-color: #F0F2E4;
}
@media (min-width: 768px) {
  .header_drawer {
    max-width: 660px;
    left: auto;
  }
}
@media (max-width: 768px) {
  .header_drawer {
    padding: clamp(40px, 29.153px + 3.39vw, 80px) clamp(20px, 1.559px + 5.763vw, 88px) 100px;
  }
}

.header_drawer::-webkit-scrollbar {
  display: none;
}

.header_drawer_nav {
  height: auto;
  overflow-y: scroll;
}

.header_drawer_list_link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 100%;
  padding: 24px 0;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 15px;
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .header_drawer_list_link {
    padding: 16px 0;
  }
}

@media (min-width: 768px) {
  .header_drawer_list_link:hover {
    color: #009A08;
  }
}

.header_drawer_list_link::after {
  content: "";
  position: absolute;
  display: block;
  width: 52px;
  height: 7px;
  background: url(../images/common/arrowBlack.svg) no-repeat center center/contain;
  top: 0;
  right: clamp(9px, 6.559px + 0.763vw, 18px);
  bottom: 0;
  margin: auto 0;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .header_drawer_list_link:hover::after {
    background-image: url(../images/common/arrowGreen.svg);
    right: 0;
  }
}

.header_drawer_list_menus {
  padding-bottom: 10px;
}

.header_drawer_list_menu a {
  display: inline-block;
  font-weight: 700;
  line-height: 1;
  padding: 12px 10px;
}

.header_drawer_btn {
  position: relative;
  margin-top: 64px;
}
@media (max-width: 768px) {
  .header_drawer_btn {
    margin-top: 24px;
  }
}

.header_drawer_btn .btn {
  max-width: unset;
  color: #000;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.03em;
  text-align: center;
  padding: 24px clamp(15px, 10.661px + 1.356vw, 31px);
  background-color: #fff;
  border: 1px solid #000;
}
@media (max-width: 768px) {
  .header_drawer_btn .btn {
    padding: 24px clamp(10px, 6.203px + 1.186vw, 24px);
  }
}

@media (min-width: 768px) {
  .header_drawer_btn .btn:hover {
    color: #fff;
    background-color: #009A08;
    border-color: #009A08;
  }
}

.header_drawer_btn .btn::after {
  display: none;
}

/* top - top_mw
------------------------------ */
.top_mw_bg_slide {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100vh;
  background: url(../images/top/top_mw_bg.jpg) repeat-x center center/cover;
  opacity: 0;
  -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
  transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-animation: top_mw_slide_bg 60s linear infinite;
          animation: top_mw_slide_bg 60s linear infinite;
}
@media (max-width: 768px) {
  .top_mw_bg_slide {
    background-image: url(../images/top/top_mw_bgSP.jpg);
  }
}

.top_mw_bg_slide.is-loaded_top {
  opacity: 1;
}

@-webkit-keyframes top_mw_slide_bg {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -3000px 0;
  }
}

@keyframes top_mw_slide_bg {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -3000px 0;
  }
}
.top_mw_contents .wrapper {
  max-width: unset;
  padding: 0 8%;
}
@media (max-width: 768px) {
  .top_mw_contents .wrapper {
    padding: 0 5%;
  }
}

.top_mw_wrapper {
  position: relative;
  display: block;
  width: 100%;
  height: 100vh;
  -webkit-animation: fade cubic-bezier(0.215, 0.61, 0.355, 1) 1.5s forwards;
          animation: fade cubic-bezier(0.215, 0.61, 0.355, 1) 1.5s forwards;
  padding: 25vh 0 17vh;
}
@media (max-width: 768px) {
  .top_mw_wrapper {
    padding: 15vh 0;
  }
}

.top_mw_group {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.top_mw_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media (max-width: 768px) {
  .top_mw_title {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    max-width: 85%;
  }
}

.top_mw_title_inner {
  position: relative;
  padding: 0 8px 0 14px;
}

.top_mw_title_inner::after {
  content: "";
  position: absolute;
  display: block;
  height: 100%;
  background-color: #fff;
  -webkit-animation: topMwflow 0.8s 4.4s forwards;
          animation: topMwflow 0.8s 4.4s forwards;
  top: 0.8vw;
  left: 0;
}
@media (max-width: 768px) {
  .top_mw_title_inner::after {
    height: 100%;
    top: 2px;
  }
}

.top_mw_title_ja {
  position: relative;
  display: inline-block;
  color: #009A08;
  font-size: 4vw;
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.08em;
  overflow: hidden;
  opacity: 0;
  -webkit-animation: topMwBlur 1.2s forwards;
          animation: topMwBlur 1.2s forwards;
  z-index: 1;
}
@media (max-width: 768px) {
  .top_mw_title_ja {
    font-size: 8vw;
    line-height: 150%;
    letter-spacing: 0.08em;
  }
}

@-webkit-keyframes topMwBlur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}

@keyframes topMwBlur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
.top_mw_title_animation01 {
  font-size: 6vw;
  -webkit-animation-delay: 0.8s;
          animation-delay: 0.8s;
  margin: 0 -3vw 0 -4vw;
  top: 1vh;
}
@media (max-width: 1300px) {
  .top_mw_title_animation01 {
    font-size: 8vw;
  }
}
@media (max-width: 768px) {
  .top_mw_title_animation01 {
    font-size: 10vw;
    line-height: 150%;
    letter-spacing: 0.08em;
  }
}

.top_mw_title_animation02 {
  -webkit-animation-delay: 1.6s;
          animation-delay: 1.6s;
}

.top_mw_title_animation03 {
  -webkit-animation-delay: 2.4s;
          animation-delay: 2.4s;
}

.top_mw_contents_img {
  position: relative;
  max-width: 670px;
  width: 100%;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin: 32px calc(50% - 48vw) 0 auto;
}

.top_mw_text {
  position: relative;
  font-size: 1.5vw;
  font-weight: 700;
  line-height: 210%;
  letter-spacing: 0.04em;
  margin-top: 5vh;
  opacity: 0;
  -webkit-animation: topMwBlur 1.2s 3.4s forwards;
          animation: topMwBlur 1.2s 3.4s forwards;
}
@media (max-width: 1300px) {
  .top_mw_text {
    font-size: 2.5vw;
  }
}
@media (max-width: 768px) {
  .top_mw_text {
    font-size: 4vw;
    margin-top: 6vh;
  }
}

@media (max-width: 768px) {
  .top_mw_text > br {
    display: none;
  }
}

.top_mw_text span {
  position: relative;
  padding: 5px 0 5px 12px;
}
@media (max-width: 768px) {
  .top_mw_text span {
    display: block;
  }
}

@media (max-width: 768px) {
  .top_mw_text span:not(:first-child) {
    margin-top: 8px;
  }
}

.top_mw_text span::after {
  content: "";
  position: absolute;
  display: block;
  height: 100%;
  background-color: #fff;
  -webkit-animation: topMwflow 0.8s 4.4s forwards;
          animation: topMwflow 0.8s 4.4s forwards;
  top: 0;
  left: 0;
  z-index: -1;
}

@-webkit-keyframes topMwflow {
  0% {
    width: 0;
    opacity: 0;
  }
  100% {
    width: 100%;
    opacity: 1;
  }
}

@keyframes topMwflow {
  0% {
    width: 0;
    opacity: 0;
  }
  100% {
    width: 100%;
    opacity: 1;
  }
}
.top_mw_btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(8px, 5.831px + 0.678vw, 16px);
  margin-top: 57px;
  opacity: 0;
  -webkit-transition: 1s cubic-bezier(0.26, 1, 0.22, 1);
  transition: 1s cubic-bezier(0.26, 1, 0.22, 1);
}
@media (max-width: 768px) {
  .top_mw_btns {
    position: fixed;
    width: 90%;
    margin-top: 0;
    bottom: 16px;
    z-index: 100;
  }
}

.top_mw_btns.is-loaded_top {
  opacity: 1;
}

.top_mw_btn {
  position: relative;
  max-width: 231px;
  width: 100%;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

/* top - common
------------------------------ */
.top_section_title {
  position: relative;
  text-align: center;
}

.top_section_title_en {
  position: relative;
  color: #E7F5E8;
  font-size: clamp(60px, 43.729px + 5.085vw, 120px);
  font-weight: 700;
  font-family: "Montserrat", sans-serif;
  line-height: 100%;
  letter-spacing: 0.05em;
  font-style: italic;
  opacity: 0;
}
@media (max-width: 768px) {
  .top_section_title_en {
    font-size: clamp(32px, 27.661px + 1.356vw, 48px);
  }
}

section:has(.is-visible) .top_section_title_en {
  -webkit-animation: topMwBlur 1.2s forwards;
          animation: topMwBlur 1.2s forwards;
}

.top_section_title_ja {
  position: relative;
  display: block;
  color: #009A08;
  font-size: clamp(24px, 19.661px + 1.356vw, 40px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.04em;
  margin-top: -44px;
}
@media (max-width: 768px) {
  .top_section_title_ja {
    font-size: clamp(20px, 18.915px + 0.339vw, 24px);
    letter-spacing: 0.08em;
    margin-top: 19px;
  }
}

.top_section_main_title {
  position: relative;
  background-repeat: no-repeat;
  background-position: center right;
  background-size: cover;
  padding: 64px 0 129px;
}
@media (max-width: 768px) {
  .top_section_main_title {
    padding: clamp(34px, 29.661px + 1.356vw, 50px) 0 clamp(60px, 53.492px + 2.034vw, 84px);
    background-position: center left 65%;
  }
}

.top_section_main_title .wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .top_section_main_title .wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 8px;
  }
}

.top_section_main_title_en {
  position: relative;
  color: #fff;
  font-size: clamp(60px, 43.729px + 5.085vw, 120px);
  font-weight: 700;
  font-family: "Montserrat", sans-serif;
  line-height: 100%;
  letter-spacing: 0.06em;
  font-style: italic;
  opacity: 0;
  margin-left: -40px;
}
@media (max-width: 768px) {
  .top_section_main_title_en {
    font-size: clamp(48px, 45.831px + 0.678vw, 56px);
    margin-left: 0;
  }
}

section:has(.is-visible) .top_section_main_title_en {
  -webkit-animation: topSectionMainTitleBlur 1.2s forwards;
          animation: topSectionMainTitleBlur 1.2s forwards;
}

@-webkit-keyframes topSectionMainTitleBlur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 0.7;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}

@keyframes topSectionMainTitleBlur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 0.7;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
.top_section_main_title_ja {
  position: relative;
  color: #fff;
  font-size: clamp(22px, 19.831px + 0.678vw, 30px);
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .top_section_main_title_ja {
    font-size: clamp(18px, 16.915px + 0.339vw, 22px);
  }
}

/* top - top_message
------------------------------ */
.top_message {
  position: relative;
  display: block;
  margin-top: 90px;
}
@media (max-width: 768px) {
  .top_message {
    margin-top: 40px;
  }
}

@media (max-width: 768px) {
  .top_message_title_en {
    color: #B4E8B8;
  }
}

@media (max-width: 768px) {
  .top_message_title_ja {
    text-align: left;
  }
}

.top_message_wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  gap: 20px;
}
@media (max-width: 1300px) {
  .top_message_wrapper {
    max-width: 1300px;
    width: 100%;
    padding: 0 25px;
    margin: auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 768px) {
  .top_message_wrapper {
    max-width: 600px;
    padding: 0 5%;
  }
}

@media (max-width: 768px) {
  .top_message_pict {
    display: none;
  }
}

.top_message_pict_right {
  position: absolute;
  width: 18vw;
  top: -3vh;
  right: 0;
  opacity: 0;
  -webkit-transform: translateY(2rem);
          transform: translateY(2rem);
  -webkit-transition: all 1.5s ease-out;
  transition: all 1.5s ease-out;
}
@media (max-width: 1300px) {
  .top_message_pict_right {
    position: relative;
    width: 50vw;
    margin: 0 auto;
    top: auto;
  }
}

.top_message_pict_left {
  position: absolute;
  width: 17vw;
  left: 0;
  bottom: 48px;
  opacity: 0;
  -webkit-transform: translateY(2rem);
          transform: translateY(2rem);
  -webkit-transition: all 0.5s ease-out;
  transition: all 0.5s ease-out;
}
@media (max-width: 1300px) {
  .top_message_pict_left {
    position: relative;
    width: 50vw;
    margin: 0 auto;
    bottom: auto;
  }
}

.top_message_wrapper:has(.is-visible) .top_message_pict_right,
.top_message_wrapper:has(.is-visible) .top_message_pict_left {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

.sentinel {
  width: 1px;
  height: 1px;
  visibility: hidden;
}

.top_message_outline {
  position: relative;
  margin: 56px auto 0;
}
@media (min-width: 768px) {
  .top_message_outline {
    max-width: clamp(600px, 524.068px + 23.729vw, 880px);
  }
}
@media (max-width: 1300px) {
  .top_message_outline {
    margin: 0 auto;
  }
}

.top_message_outline p {
  position: relative;
  line-height: 200%;
  letter-spacing: 0.05em;
}
@media (max-width: 768px) {
  .top_message_outline p {
    line-height: 180%;
    letter-spacing: 0.06em;
  }
}

.top_message_outline p + p {
  margin-top: 16px;
}

/* top - top_services
------------------------------ */
.top_services {
  position: relative;
  background-color: #F0F2E4;
  margin-top: 107px;
  padding-bottom: 152px;
}
@media (max-width: 768px) {
  .top_services {
    margin-top: 64px;
    padding-bottom: 64px;
  }
}

.top_services_inner {
  position: relative;
  display: block;
  overflow-x: hidden;
}

.top_services_title {
  background-image: url(../images/top/top_service_title_bg.jpg);
}

.top_services_subtitle {
  position: relative;
  display: block;
  margin-top: clamp(-88px, -32.068px + -3.729vw, -44px);
  padding: clamp(32px, 23.322px + 2.712vw, 64px) clamp(44px, 36.407px + 2.373vw, 72px);
}
@media (max-width: 768px) {
  .top_services_subtitle {
    margin-top: clamp(-43px, -17.576px + -1.695vw, -23px);
    padding: clamp(24px, 21.831px + 0.678vw, 32px) clamp(24px, 19.661px + 1.356vw, 40px);
  }
}

.top_services_subtitle::after {
  content: "";
  position: absolute;
  display: block;
  width: 150%;
  height: 100%;
  background-color: #009A08;
  opacity: 0.8;
  top: 0;
  left: 0;
}

.top_services_subtitle_ja {
  position: relative;
  display: block;
  color: #fff;
  font-size: clamp(20px, 17.831px + 0.678vw, 28px);
  font-weight: 700;
  font-style: italic;
  line-height: 150%;
  letter-spacing: 0.1em;
  z-index: 1;
}
@media (max-width: 768px) {
  .top_services_subtitle_ja {
    font-size: clamp(14px, 12.915px + 0.339vw, 18px);
  }
}

.top_services_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: clamp(30px, 18.881px + 3.475vw, 71px);
  margin-top: -56px;
}
@media (max-width: 1300px) {
  .top_services_wrapper {
    gap: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 768px) {
  .top_services_wrapper {
    margin-top: 24px;
  }
}

.top_services_pict {
  position: relative;
  max-width: 640px;
  width: 100vw;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-right: calc(50% - 50vw);
  opacity: 0;
  -webkit-transform: translateY(2rem);
          transform: translateY(2rem);
  -webkit-transition: all 0.5s ease-out;
  transition: all 0.5s ease-out;
}
@media (max-width: 768px) {
  .top_services_pict {
    width: 100%;
    margin: 0 auto;
  }
}

.top_services_wrapper:has(.is-visible) .top_services_pict {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

.top_services_outline {
  position: relative;
  max-width: 625px;
  width: 100%;
  padding-bottom: 23px;
}
@media (max-width: 1300px) {
  .top_services_outline {
    max-width: unset;
    margin-top: 30px;
    padding-bottom: 0;
  }
}
@media (max-width: 768px) {
  .top_services_outline {
    margin-top: 24px;
  }
}

.top_service_outline_title {
  position: relative;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 170%;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .top_service_outline_title {
    font-size: 18px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }
}

@media (max-width: 1300px) {
  .top_service_outline_title br {
    display: none;
  }
}

.top_service_outline_text {
  position: relative;
  line-height: 180%;
  letter-spacing: 0.08em;
  margin-top: 32px;
}
@media (max-width: 768px) {
  .top_service_outline_text {
    letter-spacing: 0.04em;
    margin-top: 16px;
  }
}

.top_services_slick {
  position: relative;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .top_services_slick {
    margin-top: 24px;
  }
}

/* 中央以外のスライド */
.top_services_items .top_services_slick_img img {
  width: 100%;
  height: auto;
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, transform 0.5s;
  transition: opacity 0.5s, transform 0.5s, -webkit-transform 0.5s;
}

/* 中央のスライド */
.top_services_items .slick-center .top_services_slick_img img {
  -webkit-transform: scale(1);
          transform: scale(1);
}

.top_services_items .slick-arrow {
  width: 25px;
  height: 51px;
  background: url(../images/common/arrowWhiteR.svg) no-repeat center center/contain;
}
@media (max-width: 768px) {
  .top_services_items .slick-arrow {
    width: 16px;
    height: 28px;
  }
}

.top_services_items .slick-next {
  right: 56px;
}
@media (max-width: 768px) {
  .top_services_items .slick-next {
    right: 8px;
  }
}

@media (min-width: 768px) {
  .top_services_items .slick-next:hover {
    right: 48px;
  }
}

.top_services_items .slick-prev {
  left: 56px;
}
@media (max-width: 768px) {
  .top_services_items .slick-prev {
    left: 8px;
  }
}

@media (min-width: 768px) {
  .top_services_items .slick-prev:hover {
    left: 48px;
  }
}

.top_services_cards {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  margin-top: 80px;
  gap: 25px;
}
@media (max-width: 1300px) {
  .top_services_cards {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 768px) {
  .top_services_cards {
    grid-template-columns: 1fr;
    margin-top: 40px;
    gap: 16px;
  }
}

.top_services_card {
  position: relative;
  max-width: clamp(240px, 196.61px + 13.559vw, 400px);
  width: 100%;
  padding: 40px clamp(24px, 21.831px + 0.678vw, 32px);
  background-color: #fff;
  -webkit-box-shadow: 0 0 15px rgba(214, 218, 197, 0.8);
          box-shadow: 0 0 15px rgba(214, 218, 197, 0.8);
}
@media (max-width: 1300px) {
  .top_services_card {
    max-width: unset;
  }
}
@media (max-width: 768px) {
  .top_services_card {
    padding: 24px;
  }
}

.top_services_card_title {
  position: relative;
  font-size: clamp(24px, 21.831px + 0.678vw, 32px);
  font-weight: 700;
  text-align: center;
  line-height: 150%;
  letter-spacing: 0.1em;
  padding-bottom: 16px;
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .top_services_card_title {
    font-size: 24px;
    padding-bottom: 10px;
  }
}

.top_services_card_text {
  position: relative;
  line-height: 180%;
  letter-spacing: 0.04em;
  margin-top: 40px;
}
@media (max-width: 768px) {
  .top_services_card_text {
    letter-spacing: 0.05em;
    margin-top: 16px;
  }
}

/* top - top_interview
------------------------------ */
.top_interview {
  position: relative;
  padding: 120px 0 152px;
  background: url(../images/top/top_interview_bg.jpg) no-repeat top left/cover;
}
@media (max-width: 768px) {
  .top_interview {
    padding: 64px 0;
    background-position: top right 20%;
  }
}

.top_interview_title_en {
  color: rgba(255, 255, 255, 0.5);
}
@media (max-width: 768px) {
  .top_interview_title_en {
    color: rgba(255, 255, 255, 0.7);
    text-align: left;
  }
}

.top_interview_title_ja {
  color: #fff;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  margin-top: 17px;
}
@media (max-width: 768px) {
  .top_interview_title_ja {
    margin-top: 10px;
    text-align: left;
  }
}

.top_interview_items {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 80px;
  gap: clamp(20px, 14.576px + 1.695vw, 40px);
}
@media (max-width: 1300px) {
  .top_interview_items {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 768px) {
  .top_interview_items {
    margin-top: 40px;
  }
}

.top_interview_item_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.top_interview_item {
  position: relative;
  max-width: 605px;
  width: 100%;
}

.top_interview_item a {
  position: relative;
  display: block;
  -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
          box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
  background-color: #fff;
}

@media (min-width: 768px) {
  .top_interview_item a:hover {
    -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
  }
}

.top_interview_item_img {
  position: relative;
  max-width: clamp(124px, 90.373px + 10.508vw, 248px);
  width: 100%;
  height: 248px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media (max-width: 1300px) {
  .top_interview_item_img {
    max-width: unset;
    width: 40%;
  }
}
@media (max-width: 768px) {
  .top_interview_item_img {
    height: auto;
  }
}

.top_interview_item_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 248/248;
}

.top_interview_item_info {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1.5;
      -ms-flex: 1.5;
          flex: 1.5;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background-color: rgba(0, 62, 8, 0.85);
  gap: 20px;
}
@media (max-width: 768px) {
  .top_interview_item_info {
    padding: 5%;
  }
}

.top_interview_item_name {
  position: relative;
  max-width: 275px;
  width: 100%;
  color: #fff;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .top_interview_item_name {
    max-width: unset;
    letter-spacing: 0;
  }
}

.top_interview_item_jobtitle {
  position: relative;
  max-width: 275px;
  width: 100%;
  color: #fff;
  line-height: 100%;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .top_interview_item_jobtitle {
    max-width: unset;
    line-height: 130%;
    letter-spacing: 0.04em;
  }
}

.top_interview_item_comment {
  position: relative;
  padding: clamp(20px, 14.576px + 1.695vw, 40px) clamp(20px, 14.576px + 1.695vw, 40px) 0;
}

.top_interview_item_comment p {
  position: relative;
  font-weight: 400;
  line-height: 180%;
  letter-spacing: 0.05em;
}

@media (min-width: 768px) {
  .top_interview_item_comment p br {
    display: none;
  }
}

.top_interview_item_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 180%;
  letter-spacing: 0.08em;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: clamp(6px, 4.373px + 0.508vw, 12px);
  margin-top: 26px;
  padding: 0 clamp(20px, 14.576px + 1.695vw, 40px) clamp(12px, 8.746px + 1.017vw, 24px);
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .top_interview_item a:hover .top_interview_item_link {
    color: #009A08;
  }
}

.top_interview_item_link::after {
  content: "";
  position: relative;
  display: block;
  width: 52px;
  height: 7px;
  background: url(../images/common/arrowBlack.svg) no-repeat center center/contain;
  right: 0;
  bottom: 9px;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .top_interview_item a:hover .top_interview_item_link::after {
    background-image: url(../images/common/arrowGreen.svg);
    right: -5px;
  }
}

/* top - top_workplace
------------------------------ */
.top_workplace {
  position: relative;
  margin-top: 152px;
}
@media (max-width: 768px) {
  .top_workplace {
    margin-top: 64px;
  }
}

@media (max-width: 768px) {
  .top_workplace_title_en {
    color: #B4E8B8;
    text-align: left;
  }
}

.top_workplace_title_ja {
  color: #000;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  line-height: 100%;
  margin-top: 17px;
}
@media (max-width: 768px) {
  .top_workplace_title_ja {
    font-size: 16px;
    margin-top: 10px;
    text-align: left;
  }
}

.top_workplace_cards {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: clamp(12px, 8.475px + 1.102vw, 25px);
  margin-top: 88px;
}
@media (max-width: 1300px) {
  .top_workplace_cards {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 50px clamp(12px, 8.475px + 1.102vw, 25px);
  }
}
@media (max-width: 768px) {
  .top_workplace_cards {
    margin-top: 50px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.top_workplace_card {
  position: relative;
  max-width: clamp(300px, 272.881px + 8.475vw, 400px);
  width: 100%;
  background-color: #F0F2E4;
}
@media (max-width: 768px) {
  .top_workplace_card {
    margin: 0 auto;
  }
}

.top_workplace_card_subtitle {
  position: relative;
  padding: 40px 0 24px;
  background-color: #009A08;
}
@media (max-width: 768px) {
  .top_workplace_card_subtitle {
    padding: 32px 0 16px;
  }
}

.top_workplace_card_subtitle::before {
  content: "";
  position: absolute;
  display: block;
  width: clamp(30px, 25.39px + 1.441vw, 47px);
  height: clamp(36px, 31.39px + 1.441vw, 53px);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: contain;
  top: clamp(-36px, -14.39px + -1.441vw, -19px);
  left: 0;
  right: 0;
  margin: 0 auto;
}

.top_workplace_card:first-child .top_workplace_card_subtitle::before {
  background-image: url(../images/common/number01White.svg);
}

.top_workplace_card:nth-child(2) .top_workplace_card_subtitle::before {
  background-image: url(../images/common/number02White.svg);
}

.top_workplace_card:nth-child(3) .top_workplace_card_subtitle::before {
  background-image: url(../images/common/number03White.svg);
}

.top_workplace_card_subtitle_ja {
  position: relative;
  color: #fff;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.04em;
  text-align: center;
}
@media (max-width: 768px) {
  .top_workplace_card_subtitle_ja {
    font-size: 18px;
  }
}

.top_workplace_card_contents {
  position: relative;
  padding: clamp(12px, 8.746px + 1.017vw, 24px);
}

.top_workplace_card_contents p {
  position: relative;
  font-weight: 400;
  line-height: 160%;
  letter-spacing: 0.04em;
}

/* top - top_benefits
------------------------------ */
.top_benefits {
  position: relative;
  margin-top: 152px;
  padding-bottom: 152px;
  background-color: #F0F2E4;
}
@media (max-width: 768px) {
  .top_benefits {
    margin-top: 64px;
    padding-bottom: 64px;
  }
}

.top_benefits_title {
  padding: 97px 0;
  background-image: url(../images/top/top_benefits_title_bg.jpg);
}
@media (max-width: 768px) {
  .top_benefits_title {
    padding: clamp(34px, 29.661px + 1.356vw, 50px) 0;
  }
}

.top_benefits_title .wrapper {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
@media (max-width: 768px) {
  .top_benefits_title .wrapper {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}

.top_benefits_cards {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: clamp(12px, 8.475px + 1.102vw, 25px);
  margin-top: 120px;
}
@media (max-width: 768px) {
  .top_benefits_cards {
    grid-template-columns: 1fr;
    margin-top: 40px;
  }
}

.top_benefits_card {
  position: relative;
  padding: clamp(24px, 21.831px + 0.678vw, 32px) clamp(24px, 21.831px + 0.678vw, 32px) clamp(56px, 53.831px + 0.678vw, 64px);
  background-color: #fff;
  -webkit-box-shadow: 0 0 15px rgba(214, 218, 197, 0.8);
          box-shadow: 0 0 15px rgba(214, 218, 197, 0.8);
}
@media (max-width: 1300px) {
  .top_benefits_card {
    padding: clamp(16px, 13.831px + 0.678vw, 24px) clamp(16px, 13.831px + 0.678vw, 24px) clamp(44px, 40.746px + 1.017vw, 56px);
  }
}
@media (max-width: 768px) {
  .top_benefits_card {
    padding: clamp(16px, 13.831px + 0.678vw, 24px);
  }
}

.top_benefits_card_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(12px, 8.746px + 1.017vw, 24px);
}

.top_benefits_card_img {
  position: relative;
  max-width: clamp(50px, 36.441px + 4.237vw, 100px);
}
@media (max-width: 1300px) {
  .top_benefits_card_img {
    max-width: clamp(30px, 24.576px + 1.695vw, 50px);
  }
}
@media (max-width: 768px) {
  .top_benefits_card_img {
    max-width: 50px;
    width: 100%;
  }
}

.top_benefits_card_title_ja {
  position: relative;
  color: #009A08;
  font-size: clamp(20px, 17.831px + 0.678vw, 28px);
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.06em;
}
@media (max-width: 1300px) {
  .top_benefits_card_title_ja {
    font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  }
}
@media (max-width: 768px) {
  .top_benefits_card_title_ja {
    font-size: 20px;
  }
}

.top_benefits_card_contents {
  position: relative;
  margin-top: 24px;
}
@media (max-width: 768px) {
  .top_benefits_card_contents {
    margin-top: 16px;
  }
}

.top_benefits_card_contents p {
  position: relative;
  font-weight: 400;
  line-height: 180%;
  letter-spacing: 0.05em;
}

/* top - top_company
------------------------------ */
.top_company {
  position: relative;
  margin-top: 152px;
}
@media (max-width: 768px) {
  .top_company {
    margin-top: 64px;
  }
}

.top_company_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media (max-width: 768px) {
  .top_company_title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.top_company_title_en {
  margin-left: -38px;
}
@media (max-width: 768px) {
  .top_company_title_en {
    color: #B4E8B8;
    margin-left: 0;
  }
}

.top_company_title_ja {
  color: #000;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  margin-top: 0;
}
@media (max-width: 768px) {
  .top_company_title_ja {
    font-size: 14px;
  }
}

.top_company_figure dl {
  display: grid;
  grid-template-columns: 210px 1fr;
  margin-top: 120px;
}
@media (max-width: 768px) {
  .top_company_figure dl {
    margin-top: 24px;
    grid-template-columns: 1fr;
  }
}

.top_company_figure dl dt {
  position: relative;
  line-height: 130%;
  letter-spacing: 0.08em;
  padding: 0 0 clamp(24px, 21.831px + 0.678vw, 32px) clamp(24px, 21.831px + 0.678vw, 32px);
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .top_company_figure dl dt {
    padding: 0 5%;
    border-bottom: 0;
  }
}

.top_company_figure dl dt:not(:first-child) {
  padding-top: clamp(24px, 21.831px + 0.678vw, 32px);
}
@media (max-width: 768px) {
  .top_company_figure dl dt:not(:first-child) {
    padding-top: 16px;
  }
}

.top_company_figure dl dd {
  position: relative;
  line-height: 130%;
  letter-spacing: 0.08em;
  padding: 0 0 clamp(24px, 21.831px + 0.678vw, 32px) clamp(24px, 21.831px + 0.678vw, 32px);
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .top_company_figure dl dd {
    line-height: 145%;
    padding: 8px 5% 16px;
  }
}

.top_company_figure dl dd:not(:first-of-type) {
  padding-top: clamp(24px, 21.831px + 0.678vw, 32px);
}
@media (max-width: 768px) {
  .top_company_figure dl dd:not(:first-of-type) {
    padding-top: 8px;
  }
}

/* top - top_news
------------------------------ */
.top_news {
  position: relative;
  margin-top: 152px;
  padding: 120px 0;
  background-color: #F0F2E4;
}
@media (max-width: 768px) {
  .top_news {
    margin-top: 64px;
    padding: 64px 0;
  }
}

.top_news_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px;
}
@media (max-width: 768px) {
  .top_news_wrapper {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.top_news_group {
  position: relative;
  width: 100%;
}

.top_news_title_en {
  color: #009A08;
  font-size: clamp(56px, 49.492px + 2.034vw, 80px);
  line-height: 100%;
  letter-spacing: 0.06em;
  text-align: left;
}
@media (max-width: 768px) {
  .top_news_title_en {
    font-size: clamp(32px, 27.661px + 1.356vw, 48px);
  }
}

.top_news_title_ja {
  color: #009A08;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  line-height: 100%;
  letter-spacing: 0.08em;
  margin-top: 16px;
  text-align: left;
}
@media (max-width: 768px) {
  .top_news_title_ja {
    color: #000;
    margin-top: 10px;
  }
}

.top_news_lists {
  position: relative;
  max-width: clamp(650px, 603.898px + 14.407vw, 820px);
  width: 100%;
}

.top_news_list + .top_news_list {
  position: relative;
  margin-top: 12px;
}

.top_news_list a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: clamp(16px, 11.661px + 1.356vw, 32px);
  padding: clamp(16px, 11.661px + 1.356vw, 32px);
  background-color: #fff;
}
@media (max-width: 768px) {
  .top_news_list a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 8px;
  }
}

.top_news_list a::after {
  content: "";
  position: absolute;
  display: block;
  width: 52px;
  height: 7px;
  background: url(../images/common/arrowGreen.svg) no-repeat center center/contain;
  top: 0;
  right: clamp(16px, 11.661px + 1.356vw, 32px);
  bottom: 0;
  margin: auto 0;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

.top_news_list_unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(6px, 4.373px + 0.508vw, 12px);
}

.top_news_list_time {
  position: relative;
  color: #009A08;
  font-size: 14px;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.05em;
}

.top_news_list_tag {
  position: relative;
  color: #fff;
  font-size: 13px;
  line-height: 150%;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 3px 10px;
  background-color: #009A08;
}

.top_news_list_title {
  position: relative;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.04em;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .top_news_list a:hover .top_news_list_title {
    color: #009A08;
  }
}

.top_news_btn {
  position: relative;
  margin-top: 56px;
}
@media (max-width: 768px) {
  .top_news_btn {
    max-width: 231px;
    width: 100%;
    margin: 32px auto 0;
  }
}

.top_news_btn .btn {
  margin-left: 0;
}

.top_news_list_not_text {
  position: relative;
  max-width: 820px;
  width: 100%;
  text-align: center;
}

/* top - top_description
------------------------------ */
.top_description {
  position: relative;
  padding: 120px 0;
  background: url(../images/top/top_description_bg.jpg) no-repeat top center/cover;
}
@media (max-width: 768px) {
  .top_description {
    padding: 64px 0;
  }
}

.top_description_title_en {
  color: rgba(255, 255, 255, 0.5);
}
@media (max-width: 768px) {
  .top_description_title_en {
    text-align: left;
    color: rgba(255, 255, 255, 0.7);
  }
}

.top_description_title_ja {
  color: #fff;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  line-height: 100%;
  letter-spacing: 0.08em;
  margin-top: 17px;
}
@media (max-width: 768px) {
  .top_description_title_ja {
    font-size: clamp(14px, 12.915px + 0.339vw, 18px);
    text-align: left;
    margin-top: 10px;
  }
}

.top_description .job_description_related_list {
  max-width: 400px;
}

@media (max-width: 768px) {
  .top_description .job_description_related_list + .job_description_related_list {
    margin-top: 20px;
  }
}

.top_description .job_description_related_content {
  padding: clamp(24px, 21.831px + 0.678vw, 32px);
}

.top_description .job_description_related_title {
  font-size: clamp(16px, 14.915px + 0.339vw, 20px);
  letter-spacing: 0.03em;
}

.top_description .job_description_related_figure dl {
  grid-template-columns: 90px 1fr;
  gap: clamp(6px, 4.373px + 0.508vw, 12px);
}

.top_description .job_description_related_figure dl dt {
  color: #000;
  text-align: left;
  background-color: transparent;
}

.top_description_btn {
  margin-top: 56px;
}
@media (max-width: 768px) {
  .top_description_btn {
    margin-top: 32px;
  }
}

@media (min-width: 768px) {
  .top_description_btn .btn:hover {
    color: #009A08;
    background-color: #fff;
  }
}

@media (min-width: 768px) {
  .top_description_btn .btn:hover::after {
    border-color: transparent transparent transparent #009A08;
  }
}

/* top - top_faq
------------------------------ */
.top_faq {
  position: relative;
  margin-top: 152px;
}
@media (max-width: 768px) {
  .top_faq {
    margin-top: 64px;
  }
}

.top_faq_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .top_faq_title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 8px;
  }
}

.top_faq_title_en {
  margin-left: -61px;
}
@media (max-width: 768px) {
  .top_faq_title_en {
    color: #B4E8B8;
    text-align: left;
    margin-left: 0;
  }
}

.top_faq_title_ja {
  color: #000;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  line-height: 100%;
  letter-spacing: 0.08em;
  margin-top: 0;
}
@media (max-width: 768px) {
  .top_faq_title_ja {
    font-size: clamp(14px, 12.915px + 0.339vw, 18px);
    text-align: left;
  }
}

.top_faq_lists {
  position: relative;
  margin-top: 80px;
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .top_faq_lists {
    margin-top: 42px;
  }
}

.top_faq_q {
  position: relative;
  display: block;
  padding: clamp(24px, 21.831px + 0.678vw, 32px) clamp(20px, 14.576px + 1.695vw, 40px);
  border-top: 1px solid #000;
}
@media (max-width: 1300px) {
  .top_faq_q {
    padding: clamp(24px, 21.831px + 0.678vw, 32px) clamp(56px, 53.831px + 0.678vw, 64px) clamp(24px, 21.831px + 0.678vw, 32px) clamp(20px, 14.576px + 1.695vw, 40px);
  }
}
@media (max-width: 768px) {
  .top_faq_q {
    padding: clamp(24px, 21.831px + 0.678vw, 32px) clamp(56px, 53.831px + 0.678vw, 64px) clamp(24px, 21.831px + 0.678vw, 32px) clamp(15px, 10.932px + 1.271vw, 30px);
  }
}

.top_faq_q::before,
.top_faq_q::after {
  content: "";
  position: absolute;
  display: block;
  width: 19px;
  height: 2px;
  background-color: #009A08;
  top: 0;
  right: clamp(20px, 14.576px + 1.695vw, 40px);
  bottom: 0;
  margin: auto 0;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

.top_faq_q::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}

.top_faq_q.is_open::after {
  -webkit-transform: rotate(0);
          transform: rotate(0);
}

.top_faq_q span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.05em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(12px, 8.746px + 1.017vw, 24px);
  cursor: pointer;
}
@media (max-width: 768px) {
  .top_faq_q span {
    line-height: 150%;
  }
}

.top_faq_q span::before {
  content: "Q";
  color: #009A08;
  font-size: clamp(24px, 21.831px + 0.678vw, 32px);
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.02em;
}

.top_faq_a {
  display: none;
  padding: 0 clamp(85px, 74.695px + 3.22vw, 123px) clamp(24px, 21.831px + 0.678vw, 32px) clamp(44px, 32.068px + 3.729vw, 88px);
}
@media (max-width: 768px) {
  .top_faq_a {
    padding-left: clamp(15px, 10.932px + 1.271vw, 30px);
    padding-right: clamp(20px, 14.576px + 1.695vw, 40px);
  }
}

.top_faq_a_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: clamp(12px, 8.746px + 1.017vw, 24px);
}

.top_faq_a_inner::before {
  content: "A";
  font-size: clamp(24px, 21.831px + 0.678vw, 32px);
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  line-height: 120%;
  letter-spacing: 0.02em;
}

.top_faq_a_inner p {
  position: relative;
  line-height: 180%;
  letter-spacing: 0.04em;
}

.top_faq_a_inner span {
  position: relative;
  display: block;
  padding-left: 1em;
  text-indent: -1em;
}

/* cta
------------------------------ */
.cta {
  position: relative;
  margin-top: 120px;
}
@media (max-width: 768px) {
  .cta {
    margin-top: 60px;
  }
}

.cta_method {
  position: relative;
  background: url(../images/common/cta_bg.jpg) no-repeat center center/cover;
}

.cta_title {
  padding: clamp(13px, 9.475px + 1.102vw, 26px) 0 clamp(13px, 9.475px + 1.102vw, 26px) clamp(32px, 25.492px + 2.034vw, 56px);
  background-color: #009A08;
}
@media (max-width: 1300px) {
  .cta_title {
    padding: clamp(13px, 9.475px + 1.102vw, 26px) clamp(32px, 25.492px + 2.034vw, 56px);
  }
}

.cta_title_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
@media (max-width: 1300px) {
  .cta_title_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.cta_title_ja {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #fff;
  font-size: clamp(24px, 21.831px + 0.678vw, 32px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.05em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(8px, 5.831px + 0.678vw, 16px);
  margin-right: clamp(32px, 25.492px + 2.034vw, 56px);
  padding: 19px clamp(32px, 25.492px + 2.034vw, 56px) 19px 0;
  border-right: 1px solid #fff;
}
@media (max-width: 1300px) {
  .cta_title_ja {
    width: 100%;
    margin-right: 0;
    margin-bottom: clamp(16px, 11.661px + 1.356vw, 32px);
    padding: 19px 0 clamp(16px, 11.661px + 1.356vw, 32px);
    border-right: 0;
    border-bottom: 1px solid #fff;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media (max-width: 768px) {
  .cta_title_ja {
    font-size: 24px;
    margin-bottom: 16px;
    padding: 10px 0 16px;
  }
}

.cta_title_ja::before {
  content: "";
  position: relative;
  display: block;
  width: 54px;
  height: 38px;
  background: url(../images/common/icon_mailWhite.svg) no-repeat center center/contain;
}
@media (max-width: 768px) {
  .cta_title_ja::before {
    width: 32px;
    height: 24px;
    top: 2px;
  }
}

.cta_title_outline {
  color: #fff;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.08em;
}

.cta_method_inner {
  position: relative;
  padding: clamp(20px, 14.576px + 1.695vw, 40px) clamp(32px, 25.492px + 2.034vw, 56px);
}
@media (max-width: 768px) {
  .cta_method_inner {
    padding: 5%;
  }
}

.cta_method_outline {
  position: relative;
  font-size: clamp(14px, 12.915px + 0.339vw, 18px);
  font-weight: 700;
  line-height: 180%;
  letter-spacing: 0.06em;
  text-align: center;
}
@media (max-width: 768px) {
  .cta_method_outline {
    font-size: 16px;
    letter-spacing: 0.03em;
  }
}

.cta_method_contents {
  position: relative;
  margin-top: 40px;
  padding: clamp(13px, 9.475px + 1.102vw, 26px) clamp(32px, 25.492px + 2.034vw, 56px);
  background-color: #fff;
}
@media (max-width: 768px) {
  .cta_method_contents {
    margin-top: 24px;
    padding: 5%;
  }
}

.cta_contact_figure + .cta_contact_figure {
  position: relative;
  margin-top: 26px;
  padding-top: 26px;
  border-top: 1px solid #003E08;
}

.cta_contact_figure dl {
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(20px, 14.576px + 1.695vw, 40px);
  grid-template-columns: clamp(250px, 215.831px + 10.678vw, 376px) 1fr;
}
@media (max-width: 1300px) {
  .cta_contact_figure dl {
    grid-template-columns: 1fr;
    gap: 10px;
  }
}

.cta_contact_figure dl dt {
  position: relative;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  font-weight: 700;
  line-height: 180%;
  letter-spacing: 0.06em;
}
@media (max-width: 1300px) {
  .cta_contact_figure dl dt {
    text-align: center;
  }
}
@media (max-width: 768px) {
  .cta_contact_figure dl dt {
    font-size: 16px;
    line-height: 135%;
  }
}

.cta_contact_figure dl dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(12px, 8.746px + 1.017vw, 24px);
}
@media (max-width: 1300px) {
  .cta_contact_figure dl dd {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media (max-width: 768px) {
  .cta_contact_figure dl dd {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8px;
  }
}

.cta_contact_btn {
  position: relative;
  max-width: 231px;
  width: 100%;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media (max-width: 768px) {
  .cta_contact_btn {
    margin: 0 auto;
  }
}

/* sub
------------------------------ */
.main {
  position: relative;
}
@media (max-width: 768px) {
  .main {
    margin-top: 60px;
  }
}

.top .main {
  padding-top: 0;
}

.section_maintitle {
  position: relative;
  display: block;
  height: 560px;
  overflow: hidden;
}
@media (max-width: 768px) {
  .section_maintitle {
    height: auto;
    padding-bottom: 110px;
  }
}

.section_maintitle_after {
  position: relative;
  display: block;
  width: 115%;
  height: 163px;
  -webkit-transform: rotate(-4deg);
          transform: rotate(-4deg);
  clip-path: polygon(0 10%, 100% 0, 100% 100%, 0 90%);
  background: #27D600;
  background: -webkit-gradient(linear, left top, right top, from(rgb(39, 214, 0)), to(rgba(239, 255, 98, 0.75)));
  background: linear-gradient(90deg, rgb(39, 214, 0) 0%, rgba(239, 255, 98, 0.75) 100%);
  bottom: -50px;
  margin-left: -5%;
}
@media (max-width: 768px) {
  .section_maintitle_after {
    height: 62px;
    bottom: -20px;
  }
}

.section_maintitle_inner {
  position: relative;
  max-height: 406px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
@media (min-width: 768px) {
  .section_maintitle_inner {
    height: 406px;
  }
}

.section_maintitle_box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media (max-width: 768px) {
  .section_maintitle_box {
    height: 110px;
  }
}

.section_maintitle_box .wrapper {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}

.section_maintitle_inner_ja {
  position: relative;
  display: block;
  color: #fff;
  font-size: clamp(32px, 25.492px + 2.034vw, 56px);
  font-weight: 700;
  font-style: italic;
  line-height: 100%;
  letter-spacing: 0.08em;
  -webkit-transform: rotate(-4deg);
          transform: rotate(-4deg);
  z-index: 1;
}
@media (max-width: 768px) {
  .section_maintitle_inner_ja {
    font-size: clamp(24px, 21.831px + 0.678vw, 32px);
  }
}

.sub_section_title {
  position: relative;
  padding-bottom: 24px;
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .sub_section_title {
    padding-bottom: 16px;
  }
}

.sub_section_title_ja {
  position: relative;
  color: #009A08;
  font-size: clamp(24px, 21.831px + 0.678vw, 32px);
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .sub_section_title_ja {
    font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  }
}

/* bread crumb
------------------------------ */
.bread_crumb {
  position: relative;
  width: 100%;
  margin-top: -80px;
}

.breadcrumb_inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 12px;
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 0;
  padding: 24px 25px;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media (max-width: 768px) {
  .breadcrumb_inner {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding: 16px 24px;
  }
}

.breadcrumb_inner br {
  display: none;
}

.breadcrumb_inner > span:not(:last-child)::after {
  content: "";
  position: relative;
  display: inline-block;
  width: 3px;
  height: 6px;
  background: url(../images/common/arrowGreenR.svg) no-repeat center center/contain;
  padding: 0 12px;
}

.breadcrumb_inner .home {
  font-weight: 700;
}

@media (min-width: 768px) {
  .breadcrumb_inner a:hover {
    color: #009A08;
  }
}

/* job_description - archive
------------------------------ */
.job_description_archive_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .job_description_archive_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 30px;
    gap: 50px;
  }
}

.job_description_archive_main {
  position: relative;
  max-width: clamp(750px, 706.068px + 13.729vw, 912px);
  width: 100%;
}

.job_description_archive_item + .job_description_archive_item {
  margin-top: 24px;
}

.job_description_archive_item a {
  position: relative;
  display: block;
  border: 1px solid #000;
}

@media (min-width: 768px) {
  .job_description_archive_item a:hover {
    background-color: #F0F2E4;
  }
}

.job_description_archive_item_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: clamp(24px, 19.661px + 1.356vw, 40px);
  gap: clamp(16px, 11.661px + 1.356vw, 32px);
}
@media (max-width: 768px) {
  .job_description_archive_item_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.job_description_archive_item_img {
  position: relative;
  max-width: clamp(180px, 163.729px + 5.085vw, 240px);
  width: 100%;
}
@media (max-width: 768px) {
  .job_description_archive_item_img {
    margin: 0 auto;
  }
}

.job_description_archive_item_img img {
  width: 100%;
  height: auto;
}

.job_description_unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}

.job_description_unit p {
  position: relative;
  color: #fff;
  line-height: 130%;
  letter-spacing: 0.03em;
  padding: 4px 8px;
  background-color: #009A08;
}

.job_description_archive_item_title {
  position: relative;
  font-size: clamp(16px, 14.915px + 0.339vw, 20px);
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.03em;
  margin-top: 24px;
  padding-bottom: 8px;
  border-bottom: 1px solid #000;
}

.job_description_archive_item_outline {
  position: relative;
  line-height: 180%;
  letter-spacing: 0.05em;
  margin-top: 24px;
}

.job_description_textlink {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 8px;
  margin-top: 20px;
}

.job_description_textlink::after {
  content: "";
  position: relative;
  display: block;
  width: 52px;
  height: 7px;
  background: url(../images/common/arrowBlack.svg) no-repeat center center/contain;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .job_description_archive_item a:hover .job_description_textlink::after {
    background-image: url(../images/common/arrowGreen.svg);
  }
}

.job_description_textlink span {
  position: relative;
  line-height: 150%;
  letter-spacing: 0.05em;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .job_description_archive_item a:hover .job_description_textlink span {
    color: #009A08;
  }
}

/* job_description - single
------------------------------ */
.job_description_maintitle_inner {
  background-image: url(../images/common/maintitle_job_description_bg.jpg);
}

.job_description_single_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .job_description_single_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 30px;
    gap: 50px;
  }
}

.job_description_single_main {
  position: relative;
  max-width: clamp(750px, 706.068px + 13.729vw, 912px);
  width: 100%;
}

.job_description_single_title {
  position: relative;
  padding-bottom: 16px;
  border-bottom: 1px solid #000;
}

.job_description_single_title_ja {
  position: relative;
  font-size: clamp(18px, 16.373px + 0.508vw, 24px);
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.04em;
}

.job_description_single_thumb {
  position: relative;
  max-width: clamp(450px, 376.78px + 22.881vw, 720px);
  width: 100%;
  margin: 56px auto 0;
}
@media (max-width: 768px) {
  .job_description_single_thumb {
    margin-top: 24px;
  }
}

.job_description_single_thumb img {
  width: 100%;
  height: auto;
}

.job_description_single_outline {
  position: relative;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .job_description_single_outline {
    margin-top: 16px;
  }
}

.job_description_single_outline p {
  position: relative;
  line-height: 150%;
  letter-spacing: 0.08em;
}

.job_description_single_outline p + p {
  margin-top: 16px;
}

.job_description_single_figure {
  position: relative;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .job_description_single_figure {
    margin-top: 24px;
  }
}

.job_description_single_figure dl {
  display: grid;
  grid-template-columns: clamp(160px, 146.441px + 4.237vw, 210px) 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  grid-auto-flow: row;
}
@media (max-width: 768px) {
  .job_description_single_figure dl {
    grid-template-columns: 1fr;
  }
}

.job_description_single_figure dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  color: #009A08;
  line-height: 145%;
  letter-spacing: 0.08em;
  padding: 0 0 clamp(24px, 21.831px + 0.678vw, 32px) clamp(24px, 21.831px + 0.678vw, 32px);
  border-bottom: 1px solid #000;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  .job_description_single_figure dl dt {
    padding: 0 5%;
    border-bottom: 0;
  }
}

.job_description_single_figure dl dd {
  padding-bottom: clamp(24px, 21.831px + 0.678vw, 32px);
  border-bottom: 1px solid #000;
}
@media (max-width: 768px) {
  .job_description_single_figure dl dd {
    padding: 0 5% 10px;
  }
}

.job_description_single_figure dl dt:not(:first-child),
.job_description_single_figure dl dd:not(:first-of-type) {
  padding-top: clamp(24px, 21.831px + 0.678vw, 32px);
}
@media (max-width: 768px) {
  .job_description_single_figure dl dt:not(:first-child),
  .job_description_single_figure dl dd:not(:first-of-type) {
    padding-top: 10px;
  }
}

.job_description_entry_btn {
  position: relative;
  max-width: 372px;
  margin: 80px auto 0;
}
@media (max-width: 768px) {
  .job_description_entry_btn {
    margin-top: 32px;
  }
}

.job_description_entry_btn .btn {
  max-width: 372px;
  margin: 0 auto;
  padding: 40px 32px;
}
@media (max-width: 768px) {
  .job_description_entry_btn .btn {
    padding: 24px 16px;
  }
}

.job_description_single_related {
  position: relative;
  margin-top: 152px;
}
@media (max-width: 768px) {
  .job_description_single_related {
    margin-top: 60px;
  }
}

.job_description_single_subtitle_ja {
  position: relative;
  color: #fff;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
  padding: clamp(16px, 13.831px + 0.678vw, 24px);
  background-color: #009A08;
}

.job_description_related_lists {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  margin-top: 40px;
}
@media (max-width: 1300px) {
  .job_description_related_lists {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 768px) {
  .job_description_related_lists {
    grid-template-columns: 1fr;
    margin-top: 20px;
    gap: 20px;
  }
}

.job_description_related_list {
  position: relative;
  max-width: 292px;
  width: 100%;
}
@media (max-width: 768px) {
  .job_description_related_list {
    margin: 0 auto;
  }
}

.job_description_related_list_none {
  text-align: center;
}

.job_description_related_list a {
  position: relative;
  display: block;
  border: 1px solid #000;
  background-color: #fff;
}

@media (min-width: 768px) {
  .job_description_related_list a:hover {
    background-color: #F0F2E4;
  }
}

.job_description_related_thumb {
  position: relative;
  width: 100%;
  height: auto;
}

.job_description_related_thumb img {
  width: 100%;
  height: auto;
}

.job_description_related_content {
  position: relative;
  padding: clamp(8px, 5.831px + 0.678vw, 16px);
}

.job_description_related_title {
  position: relative;
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .job_description_related_list a:hover .job_description_related_title {
    color: #009A08;
  }
}

.job_description_related_figure {
  position: relative;
  margin-top: 16px;
}

.job_description_related_figure dl {
  display: grid;
  grid-template-columns: 85px 1fr;
  gap: 12px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.job_description_related_figure dl dt {
  color: #fff;
  font-size: 14px;
  font-weight: 400;
  line-height: 130%;
  letter-spacing: 0.03em;
  text-align: center;
  padding: 2px 0;
  background-color: #009A08;
}

.job_description_related_figure dl dd {
  font-size: 14px;
  line-height: 130%;
  letter-spacing: 0.03em;
}

/* interview - archive
------------------------------ */
.interview_maintitle_inner {
  background-image: url(../images/common/maintitle_interview_bg.jpg);
}

.interview_archive {
  position: relative;
  margin-top: 125px;
}
@media (max-width: 768px) {
  .interview_archive {
    margin-top: 60px;
  }
}

.interview_archive_title_wrapper {
  display: grid;
  grid-template-columns: 297px 1fr;
}
@media (max-width: 768px) {
  .interview_archive_title_wrapper {
    grid-template-columns: 1fr;
  }
}

.interview_archive_title_numbering {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.5em;
  padding: clamp(24px, 19.661px + 1.356vw, 40px);
  background-color: #003E08;
}

.interview_archive_title_numbering p {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  line-height: 100%;
  letter-spacing: 0.08em;
}

.interview_archive_title_numbering .interview_archive_title_number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: clamp(24px, 19.661px + 1.356vw, 40px);
  line-height: 100%;
  letter-spacing: 0.08em;
  margin-bottom: -5px;
}

.interview_archive_title_numbering .interview_archive_title_number::before {
  content: "0";
}

.interview_archive_title_info {
  padding: clamp(16px, 13.831px + 0.678vw, 24px) clamp(24px, 21.831px + 0.678vw, 32px);
  background-color: #009A08;
}

.interview_archive_title_shop {
  position: relative;
  color: #fff;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .interview_archive_title_shop {
    text-align: center;
  }
}

.interview_archive_title_ja {
  position: relative;
  display: inline-block;
  color: #fff;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.08em;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #fff;
}
@media (max-width: 768px) {
  .interview_archive_title_ja {
    display: block;
    text-align: center;
  }
}

.interview_archive_item + .interview_archive_item {
  margin-top: 120px;
}
@media (max-width: 768px) {
  .interview_archive_item + .interview_archive_item {
    margin-top: 32px;
  }
}

.interview_archive_item_inner {
  position: relative;
  padding: clamp(32px, 23.322px + 2.712vw, 64px) clamp(32px, 23.322px + 2.712vw, 64px) clamp(60px, 43.729px + 5.085vw, 120px);
  background-color: #F0F2E4;
}
@media (max-width: 768px) {
  .interview_archive_item_inner {
    padding: clamp(16px, 13.831px + 0.678vw, 24px);
  }
}

.interview_archive_item_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 20px;
}
@media (max-width: 768px) {
  .interview_archive_item_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.interview_archive_item_pictlists {
  position: relative;
  max-width: clamp(250px, 222.339px + 8.644vw, 352px);
  width: 100%;
}
@media (max-width: 768px) {
  .interview_archive_item_pictlists {
    display: grid;
    max-width: unset;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
}

.interview_archive_item_pictlist + .interview_archive_item_pictlist {
  margin-top: 24px;
}
@media (max-width: 768px) {
  .interview_archive_item_pictlist + .interview_archive_item_pictlist {
    margin-top: 0;
  }
}

.interview_archive_item_contents {
  position: relative;
  max-width: clamp(550px, 509.322px + 12.712vw, 700px);
  width: 100%;
}

.interview_archive_item_title {
  position: relative;
  display: block;
}
@media (max-width: 768px) {
  .interview_archive_item_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 10px;
  }
}

.interview_archive_item_title::before {
  content: "";
  position: absolute;
  display: block;
  width: clamp(21px, 15.305px + 1.78vw, 42px);
  height: 2px;
  background-color: #009A08;
  top: 0;
  left: clamp(-64px, -23.322px + -2.712vw, -32px);
  bottom: 0;
  margin: auto 0;
}
@media (max-width: 768px) {
  .interview_archive_item_title::before {
    position: relative;
    left: 0;
  }
}

.interview_archive_item_title_ja {
  position: relative;
  color: #009A08;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.08em;
}

.interview_archive_item_group {
  position: relative;
  margin-top: 64px;
}
@media (max-width: 768px) {
  .interview_archive_item_group {
    margin-top: 32px;
  }
}

.interview_archive_item_group + .interview_archive_item_group {
  margin-top: 32px;
}
@media (max-width: 768px) {
  .interview_archive_item_group + .interview_archive_item_group {
    margin-top: 24px;
  }
}

.interview_archive_item_group_title {
  position: relative;
  font-size: clamp(16px, 13.831px + 0.678vw, 24px);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.04em;
  padding: 8px 0;
  border-bottom: 1px solid #000;
}

.interview_archive_item_group p {
  position: relative;
  line-height: 180%;
  letter-spacing: 0.04em;
  margin-top: 16px;
}

.interview_archive_item_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 80px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (max-width: 768px) {
  .interview_archive_item_btn {
    margin-top: 24px;
  }
}

/* news - archive
------------------------------ */
.news_maintitle_inner {
  background-image: url(../images/common/maintitle_news_bg.jpg);
}

.news_archive_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0 20px;
  margin-top: 80px;
}
@media (max-width: 1300px) {
  .news_archive_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 50px;
    margin-top: 40px;
  }
}

.news_archive_group {
  position: relative;
  max-width: clamp(750px, 706.068px + 13.729vw, 912px);
  width: 100%;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (max-width: 1300px) {
  .news_archive_group {
    max-width: unset;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
  }
}

.news_archive_item_wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: clamp(16px, 11.661px + 1.356vw, 32px);
  padding: clamp(16px, 11.661px + 1.356vw, 32px);
  border-top: 1px solid #000;
}
@media (max-width: 768px) {
  .news_archive_item_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 16px;
  }
}

.news_archive_item:last-child {
  border-bottom: 1px solid #000;
}

.news_archive_item_wrapper::after {
  content: "";
  position: absolute;
  display: block;
  width: 52px;
  height: 7px;
  background: url(../images/common/arrowGreen.svg) no-repeat center center/contain;
  right: clamp(16px, 11.661px + 1.356vw, 32px);
  bottom: clamp(16px, 11.661px + 1.356vw, 32px);
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .news_archive_item_wrapper:hover {
    background-color: #F0F2E4;
  }
}

.news_archive_item_img {
  position: relative;
  max-width: clamp(180px, 163.729px + 5.085vw, 240px);
  width: 100%;
  max-height: 180px;
  overflow: hidden;
}
@media (max-width: 768px) {
  .news_archive_item_img {
    margin: 0 auto;
  }
}

.news_archive_item_img img {
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 240/180;
}

.news_archive_item_content {
  position: relative;
  max-width: clamp(450px, 415.831px + 10.678vw, 576px);
  width: 100%;
  font-weight: 500;
  line-height: 190%;
  letter-spacing: 0;
}
.news_article_unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 12px;
}

.news_article_date {
  position: relative;
  display: block;
  color: #009A08;
  font-size: 14px;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.05em;
}

.news_article_cat {
  position: relative;
  min-width: 74px;
  width: auto;
  color: #fff;
  font-size: 13px;
  text-align: center;
  line-height: 150%;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 3px 10px;
  background-color: #009A08;
}

.news_archive_item_title {
  position: relative;
  font-size: clamp(16px, 14.915px + 0.339vw, 20px);
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.04em;
  margin-top: 16px;
}
@media (max-width: 768px) {
  .news_archive_item_title {
    margin-top: 10px;
  }
}

.news_archive_content {
  position: relative;
  line-height: 150%;
  letter-spacing: 0.05em;
  margin-top: 16px;
}

/* pagenavi */
.pagenavi {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  margin-top: 50px;
}

.pagenavi span {
  position: relative;
  width: 30px;
  height: 30px;
  color: #fff;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0;
  text-align: center;
  padding-top: 7px;
}

.pagenavi a {
  position: relative;
  display: block;
  width: 30px;
  height: 30px;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0;
  text-align: center;
  padding-top: 7px;
  background-color: rgba(77, 139, 240, 0.2);
}

@media (min-width: 768px) {
  .pagenavi a:hover {
    color: #fff;
  }
}

/* news - single
------------------------------ */
.news_single {
  position: relative;
  padding-top: 48px;
}

.news_single_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0 clamp(20px, 11.864px + 2.542vw, 50px);
}
@media (max-width: 1300px) {
  .news_single_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 50px;
  }
}

.news_single_main {
  position: relative;
  max-width: clamp(750px, 706.068px + 13.729vw, 912px);
  width: 100%;
  background-color: #fff;
}
@media (max-width: 1300px) {
  .news_single_main {
    max-width: unset;
  }
}
.news_article_img {
  position: relative;
  max-width: clamp(350px, 249.661px + 31.356vw, 720px);
  width: 100%;
  height: auto;
  margin: 56px auto 0;
  -webkit-box-shadow: 0 0 14px rgba(0, 0, 0, 0.12);
          box-shadow: 0 0 14px rgba(0, 0, 0, 0.12);
}

.news_single_article .news_article_unit {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 0 clamp(6px, 4.373px + 0.508vw, 12px);
}
.news_article_title_ja {
  position: relative;
  color: #000;
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 0.04em;
  margin-top: 24px;
}

.news_single_content {
  position: relative;
  max-width: clamp(650px, 631.017px + 5.932vw, 720px);
  font-weight: 400;
  line-height: 180%;
  letter-spacing: 0.05em;
  margin: 40px auto 0;
}
@media (max-width: 768px) {
  .news_single_content {
    margin-top: 16px;
  }
}

.news_single_content p + p {
  margin-top: 1em;
}

.news_article_buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 120px;
  gap: clamp(7px, 5.102px + 0.593vw, 14px);
}
@media (max-width: 768px) {
  .news_article_buttons {
    gap: 10px;
    margin-top: 30px;
  }
}

.news_article_button {
  position: relative;
  max-width: 231px;
  width: 100%;
}

.news_article_button a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  color: #fff;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.04em;
  text-align: left;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: clamp(16px, 13.831px + 0.678vw, 24px);
  background-color: #003E08;
}
@media (max-width: 768px) {
  .news_article_button a {
    font-size: 13px;
    padding: 16px;
  }
}

@media (min-width: 768px) {
  .news_article_button a:hover {
    background-color: #009A08;
  }
}

.news_article_button a::after {
  content: "";
  position: relative;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6.5px 0 6.5px 10px;
  border-color: transparent transparent transparent #FFFFFF;
  -webkit-transition: 0.35s;
  transition: 0.35s;
  right: 0;
}

.news_article_button_previous a {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.news_article_button_previous a::after {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.news_article_button_all a {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.news_article_button_all a::after {
  display: none;
}

/* aside
------------------------------ */
.section_side {
  position: relative;
  max-width: clamp(220px, 205.898px + 4.407vw, 272px);
  width: 100%;
}
@media (max-width: 768px) {
  .section_side {
    margin: 0 auto;
  }
}

.sidebar_group + .sidebar_group {
  position: relative;
  margin-top: 40px;
}

.job_description_section_side .section_side_title {
  text-align: center;
  padding: 10px 0;
  background-color: #003E08;
}

.section_side_title {
  position: relative;
  color: #fff;
  font-size: clamp(14px, 12.373px + 0.508vw, 20px);
  line-height: 120%;
  letter-spacing: 0;
  font-weight: 700;
  padding: 27px clamp(15px, 12.288px + 0.847vw, 25px) 29px;
  background-color: #003E08;
}

.news_section_side_title {
  font-family: "Montserrat", sans-serif;
  text-align: center;
  line-height: 130%;
  letter-spacing: 0.04em;
  padding: 23px clamp(16px, -0.271px + 5.085vw, 76px);
}

.section_side_lists {
  position: relative;
  margin-top: 32px;
}

.section_side_list + .section_side_list {
  margin-top: 24px;
}

.section_side_list_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.04em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(8px, 5.831px + 0.678vw, 16px);
}

.section_side_list_link::before {
  content: "";
  position: relative;
  display: block;
  width: 16px;
  height: 1px;
  background-color: #009A08;
}

@media (min-width: 768px) {
  .section_side_list_link:hover {
    color: #009A08;
  }
}

.section_side_category_list a {
  position: relative;
  display: block;
  color: #000;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.04em;
  padding: 21px 4px 14px;
  border-bottom: 1px solid #000;
}

.all_category_lists .section_side_category_list a {
  padding-top: 0;
}

@media (min-width: 768px) {
  .section_side_category_list a:hover {
    color: #009A08;
  }
}

.section_side_category_list a::after {
  content: "";
  position: absolute;
  display: block;
  width: 26px;
  height: 26px;
  background: url(../images/common/circle_arrowGreen.svg) no-repeat center center/contain;
  right: 4px;
  bottom: 9px;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .section_side_category_list a:hover::after {
    right: 0;
  }
}

/* entry
------------------------------ */
.entry_maintitle_inner {
  background-image: url(../images/common/maintitle_entry_bg.jpg);
}

.entry_flow {
  position: relative;
  margin-top: 105px;
}
@media (max-width: 768px) {
  .entry_flow {
    margin-top: 40px;
  }
}

.entry_flow_items {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: clamp(23px, 16.763px + 1.949vw, 46px);
  margin-top: 56px;
}
@media (max-width: 1300px) {
  .entry_flow_items {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 768px) {
  .entry_flow_items {
    grid-template-columns: 1fr;
    margin-top: 32px;
  }
}

.entry_flow_item {
  position: relative;
  max-width: 278px;
  width: 100%;
}
@media (max-width: 768px) {
  .entry_flow_item {
    margin: 0 auto;
  }
}

@media (max-width: 768px) {
  .entry_flow_pict {
    max-width: 160px;
    width: 100%;
    margin: 0 auto;
  }
}

.entry_flow_outline {
  position: relative;
  display: block;
  max-width: 252px;
  line-height: 150%;
  letter-spacing: 0.04em;
  text-align: center;
  margin: 24px auto 0;
}
@media (max-width: 768px) {
  .entry_flow_outline {
    max-width: unset;
    margin: 16px auto 0;
  }
}

.entry_flow_caution {
  position: relative;
  margin-top: 64px;
  background-color: #009A08;
}
@media (max-width: 768px) {
  .entry_flow_caution {
    margin-top: 32px;
  }
}

.entry_flow_caution_text {
  position: relative;
  color: #fff;
  line-height: 150%;
  letter-spacing: 0.08em;
  text-align: center;
  padding: 8px;
}
@media (max-width: 768px) {
  .entry_flow_caution_text {
    line-height: 180%;
  }
}

.entry_form {
  position: relative;
  margin-top: 152px;
}
@media (max-width: 768px) {
  .entry_form {
    margin-top: 80px;
  }
}

.entry_form_outline {
  position: relative;
  line-height: 170%;
  letter-spacing: 0.05em;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .entry_form_outline {
    margin-top: 24px;
  }
}

.form_row {
  display: grid;
  grid-template-columns: 248px 1fr;
  margin-top: 40px;
  border-bottom: 1px solid #003E08;
}
@media (max-width: 768px) {
  .form_row {
    grid-template-columns: 1fr;
    margin-top: 24px;
  }
}

form#mailformpro {
  padding-top: 0;
}

form#mailformpro dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  font-size: 16px;
  line-height: 170%;
  letter-spacing: 0.05em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: clamp(16px, 13.831px + 0.678vw, 24px) clamp(24px, 21.831px + 0.678vw, 32px);
  background-color: #E7F5E8;
  border-color: #003E08;
}

form#mailformpro dl dt.contact_form_title_textarea {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.contact_form_title_must {
  color: #009A08;
}

form#mailformpro dl dd {
  font-size: 16px;
  padding: clamp(24px, 21.831px + 0.678vw, 32px);
  border-color: #003E08;
}
@media (max-width: 768px) {
  form#mailformpro dl dd {
    font-size: 14px;
  }
}

.form_radio_buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(16px, 13.831px + 0.678vw, 24px);
}
@media (max-width: 768px) {
  .form_radio_buttons {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

form#mailformpro label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 8px;
  line-height: 100%;
  letter-spacing: 0.08em;
  margin: 0;
  cursor: pointer;
}
@media (max-width: 768px) {
  form#mailformpro label {
    text-align: left;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    white-space: normal;
  }
}

.form_radio_button input[type=radio] {
  position: relative;
  display: inline-block;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 26px;
  height: 26px;
  max-width: 100%;
  -webkit-transition: all 0.15s ease-out 0s;
  transition: all 0.15s ease-out 0s;
  cursor: pointer;
  background-color: #F5F5F5 !important;
  outline: none;
  border-radius: 50%;
  padding: 0;
}

.form_radio_button input[type=radio]:before {
  position: absolute;
  content: "";
  width: 14px;
  height: 14px;
  left: 50%;
  top: 50%;
  border-radius: 50%;
  -webkit-transform: scale(0) translate(-50%, -50%);
          transform: scale(0) translate(-50%, -50%);
  -webkit-transition: all ease-out 250ms;
  transition: all ease-out 250ms;
}

.form_radio_button input[type=radio]:checked:before {
  -webkit-transform: scale(1) translate(-50%, -50%);
          transform: scale(1) translate(-50%, -50%);
  background-color: #009A08;
}

textarea {
  max-width: 100%;
  min-width: 100%;
  width: 100%;
  min-height: 240px;
  background-color: #F5F5F5 !important;
  padding: 15px;
}
.contact_form_input input {
  width: 100%;
  height: 40px;
  background-color: #F5F5F5 !important;
  padding: 0 10px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media (max-width: 768px) {
  .contact_form_input input {
    height: 40px;
  }
}

.contact_form_select {
  position: relative;
  display: block;
  max-width: 142px;
}

.contact_form_select::after {
  content: "";
  position: absolute;
  display: block;
  width: 10px;
  height: 5px;
  background: url(../images/common/arrowGrayB.svg) no-repeat center center/contain;
  top: 0;
  right: 9px;
  bottom: 0;
  margin: auto 0;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

.contact_form_input select {
  position: relative;
  width: 100%;
  font-size: 16px;
  line-height: 100%;
  letter-spacing: 0;
  padding: 10px 12px;
  border: 1px solid #CFCFCF;
}
.entry_form_privacy {
  position: relative;
  margin-top: 48px;
}

.entry_form_privacy_title {
  position: relative;
  font-size: clamp(16px, 14.915px + 0.339vw, 20px);
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.05em;
}

.entry_form_privacy_outline {
  position: relative;
  line-height: 200%;
  letter-spacing: 0.05em;
}

.form_privacy {
  position: relative;
  margin-top: 24px;
  padding: clamp(16px, 11.661px + 1.356vw, 32px);
  background-color: #F5F5F5;
}

.form_privacy_title {
  position: relative;
  font-size: 18px;
  font-weight: 700;
  line-height: 180%;
  letter-spacing: 0;
}

.form_privacy_content {
  position: relative;
  margin-top: 1em;
}

.form_privacy_text {
  line-height: 180%;
  letter-spacing: 0;
}

.form_checkbox_title {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #009A08;
  font-size: clamp(16px, 14.915px + 0.339vw, 20px);
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.04em;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 64px;
}
@media (max-width: 768px) {
  .form_checkbox_title {
    margin-top: 16px;
  }
}

.form_checkbox_title span {
  padding: 8px;
  border-bottom: 1px solid #009A08;
}

.form_checkbox_confirmation {
  position: relative;
  text-align: center;
}

.form_checkbox {
  position: relative;
  margin-top: 24px;
}

form#mailformpro .form_checkbox_label.none {
  display: none;
}

.form_checkbox_label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
}

.form_checkbox_parts {
  position: relative;
  display: inline-block;
  line-height: 32px;
  padding-left: 52px;
}
@media (max-width: 768px) {
  .form_checkbox_parts {
    padding-left: 44px;
    line-height: 24px;
  }
}

.form_checkbox_parts::before {
  content: "";
  position: absolute;
  display: block;
  width: 32px;
  height: 32px;
  top: 0;
  left: 0;
  border: none;
  background-color: #E7F5E8;
}
@media (max-width: 768px) {
  .form_checkbox_parts::before {
    width: 24px;
    height: 24px;
  }
}

.form_checkbox_input:checked + .form_checkbox_parts::after {
  content: "";
  position: absolute;
  display: block;
  width: 13px;
  height: 22px;
  top: 2px;
  left: 9px;
  -webkit-transform: rotate(40deg);
          transform: rotate(40deg);
  border-right: 3px solid #009A08;
  border-bottom: 3px solid #009A08;
}
@media (max-width: 768px) {
  .form_checkbox_input:checked + .form_checkbox_parts::after {
    width: 11px;
    height: 17px;
    top: 2px;
    left: 8px;
    border-right-width: 4px;
    border-bottom-width: 4px;
  }
}

.form_checkbox .checkbox_err {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.form_btn {
  position: relative;
  margin-top: 64px;
}
@media (max-width: 768px) {
  .form_btn {
    margin-top: 32px;
  }
}

.form_btn .btn {
  max-width: 372px;
  padding: clamp(32px, 29.831px + 0.678vw, 40px) clamp(24px, 21.831px + 0.678vw, 32px);
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

/* thanks
------------------------------ */
.entry_thanks_contents {
  position: relative;
  margin-top: 40px;
}

.entry_thanks_contents p {
  position: relative;
  text-align: center;
  line-height: 160%;
  letter-spacing: 0.05em;
  margin-top: 30px;
}

.entry_thanks_contents p + p {
  margin-top: 1em;
}

.entry_thanks_caution {
  position: relative;
  display: block;
  font-size: 14px;
}

.entry_thanks_btn {
  margin-top: 50px;
}

/* 404
------------------------------ */
.not_found {
  position: relative;
  padding: 120px 0;
}

.not_found_text {
  position: relative;
  font-size: clamp(16px, 14.373px + 0.508vw, 22px);
  line-height: 180%;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 30px;
}

.not_found_btn {
  margin-top: 30px;
}

/* footer
------------------------------ */
.footer {
  margin-top: 120px;
  padding-bottom: 40px;
}
@media (max-width: 768px) {
  .footer {
    margin-top: 60px;
    padding-bottom: 120px;
  }
}

.footer_nav {
  position: relative;
  display: block;
  padding: 40px 0 36px;
  background-color: #009A08;
}
@media (max-width: 768px) {
  .footer_nav {
    display: none;
  }
}

.footer_lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(16px, 11.661px + 1.356vw, 32px);
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.footer_list a {
  position: relative;
  display: inline-block;
  color: #fff;
  font-weight: 700;
  line-height: 145%;
  letter-spacing: 0.03em;
}

.footer_list a::after {
  content: "";
  position: absolute;
  display: block;
  width: 0;
  height: 1px;
  background-color: #fff;
  left: 0;
  right: 0;
  bottom: -5px;
  margin: 0 auto;
  -webkit-transition: 0.35s;
  transition: 0.35s;
}

@media (min-width: 768px) {
  .footer_list a:hover::after {
    width: 100%;
  }
}

.footer_menu {
  position: relative;
  margin-top: 56px;
}

.footer_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(24px, 17.492px + 2.034vw, 48px);
}
@media (max-width: 768px) {
  .footer_wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 16px;
  }
}

.footer_logo {
  position: relative;
  max-width: 483px;
  width: 100%;
}
@media (max-width: 768px) {
  .footer_logo {
    max-width: 283px;
    margin: 0 auto;
  }
}

.footer_corporate_btn {
  position: relative;
  max-width: 327px;
  width: 100%;
}
@media (max-width: 768px) {
  .footer_corporate_btn {
    max-width: 250px;
  }
}

.footer_corporate_btn .btn {
  max-width: unset;
  color: #000;
  font-weight: 400;
  line-height: 140%;
  letter-spacing: 0.02em;
  text-align: center;
  background-color: #fff;
  border: 1px solid #000;
  padding: 8px clamp(8px, 3.661px + 1.356vw, 24px);
}
@media (max-width: 768px) {
  .footer_corporate_btn .btn {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.footer_corporate_btn .btn::after {
  display: none;
}

@media (min-width: 768px) {
  .footer_corporate_btn .btn:hover {
    color: #fff;
    background-color: #009A08;
    border-color: #009A08;
  }
}

.footer_bnr_lists {
  display: grid;
  gap: clamp(8px, 6.102px + 0.593vw, 15px);
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  margin-top: 56px;
}
@media (max-width: 1300px) {
  .footer_bnr_lists {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media (max-width: 768px) {
  .footer_bnr_lists {
    grid-template-columns: 1fr 1fr;
    margin-top: 32px;
  }
}

.footer_bnr_list a {
  position: relative;
  display: block;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
  .footer_bnr_list a:hover {
    -webkit-box-shadow: 0 0 12px rgba(0, 0, 0, 0.3);
            box-shadow: 0 0 12px rgba(0, 0, 0, 0.3);
  }
}

.footer_copyright {
  position: relative;
  font-weight: 400;
  letter-spacing: 0.03em;
  line-height: 150%;
  text-align: center;
  margin-top: 72px;
}
@media (max-width: 768px) {
  .footer_copyright {
    margin-top: 30px;
  }
}
@media (max-width: 768px) {
  .footer_copyright {
    padding: 0 5%;
  }
}

/* foot_menu
------------------------------ */
.foot_menu {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  -webkit-box-shadow: -5px 0 8px rgba(0, 0, 0, 0.5);
          box-shadow: -5px 0 8px rgba(0, 0, 0, 0.5);
  margin: 0 auto;
  z-index: 10;
}
@media (min-width: 768px) {
  .foot_menu {
    display: none;
  }
}
@media (max-width: 768px) {
  .foot_menu {
    display: block;
  }
}

.foot_menu_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.foot_menu_tel {
  width: 50%;
}

.foot_menu_tel a {
  position: relative;
  display: block;
  font-size: 14px;
  text-align: center;
  line-height: 145%;
  font-weight: 700;
  padding: 10px 0 20px;
  background-color: #E7F5E8;
}

.foot_menu_mail {
  width: 50%;
}

.foot_menu_mail a {
  position: relative;
  display: block;
  color: #fff;
  text-align: center;
  font-weight: 700;
  padding: 10px 0 20px;
  background-color: #003E08;
}

@media (min-width: 768px) {
  .foot_fixed_btns {
    display: none;
  }
}
@media (max-width: 768px) {
  .foot_fixed_btns {
    display: block;
  }
}

/* page_top
------------------------------ */
.page_top {
  position: fixed;
  right: 50px;
  bottom: 50px;
  width: 80px;
  height: 80px;
  background: url(../images/common/pagetop.svg) no-repeat center center/contain;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  z-index: 50;
}
@media (max-width: 768px) {
  .page_top {
    right: 5%;
    bottom: 105px;
  }
}
@media (max-width: 768px) {
  .page_top {
    width: 50px;
    height: 50px;
    bottom: 80px;
  }
}

@media (min-width: 768px) {
  .page_top:hover {
    opacity: 0.7;
  }
}

/* foot_menu
------------------------------ */
.foot_menu_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.foot_menu_tel a {
  position: relative;
}