@charset "UTF-8";
/*
================================================================
 ベースレイアウト
================================================================
*/
html {
  font-size: 16px;
  font-weight: normal;
  line-height: 2;
}
@media print {
  html {
    font-size: 16px;
  }
}

/*
================================================================
 端末ごとの表示変更
================================================================
*/
@media all and (max-width: 1279px) {
  .mb-hide,
  .pc-only {
    /* タブレット、スマートフォン時非表示 */
    display: none !important;
  }
}
@media all and (max-width: 767px) {
  .sp-hide,
  .tb-only {
    /* スマートフォン時非表示 */
    display: none !important;
  }
}
@media all and (min-width: 1280px) {
  .pc-hide,
  .mb-only,
  .tb-only {
    /* PC時非表示 */
    display: none !important;
  }
}
@media all and (min-width: 768px) {
  .sp-only {
    /* PC、タブレット時非表示 */
    display: none !important;
  }
}
@media all and (min-width: 768px) and (max-width: 1279px) {
  .tb-hide {
    /* タブレット時非表示 */
    display: none !important;
  }
}
/*
================================================================
 コンテナ
================================================================
*/
.container {
  display: block;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0 0;
  clear: both;
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
  width: 90%;
  width: calc(100% - 30px);
  max-width: 1000px;
}
@media all and (min-width: 580px) {
  .container {
    width: calc(100% - 50px);
  }
}
@media all and (min-width: 768px) {
  .container {
    width: calc(100% - 100px);
  }
}
@media all and (min-width: 1080px) {
  .container {
    width: calc(100% - 120px);
  }
}
@media all and (min-width: 1280px) {
  .container {
    width: calc(100% - 140px);
  }
}
@media all and (min-width: 1440px) {
  .container {
    width: calc(100% - 160px);
  }
}
.container.container--wide {
  max-width: 1200px;
}
.container.container--exwide {
  max-width: 1400px;
}
.container.container--narrow {
  max-width: 800px;
}

.half-container {
  display: block;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0 0;
  width: 90%;
  max-width: 500px;
  clear: both;
  box-sizing: border-box;
  width: calc(100% - 15px);
}
@media all and (min-width: 580px) {
  .half-container {
    width: calc(100% - 25px);
  }
}
@media all and (min-width: 768px) {
  .half-container {
    width: calc(100% - 50px);
  }
}
@media all and (min-width: 1080px) {
  .half-container {
    width: calc(100% - 60px);
  }
}
@media all and (min-width: 1280px) {
  .half-container {
    width: calc(100% - 70px);
  }
}
@media all and (min-width: 1440px) {
  .half-container {
    width: calc(100% - 80px);
  }
}
.half-container.half-container--left {
  margin-left: auto;
  margin-right: 0;
}
.half-container.half-container--right {
  margin-left: 0;
  margin-right: auto;
}
.half-container.half-container--wide {
  max-width: 600px;
}
.half-container.half-container--exwide {
  max-width: 700px;
}
.half-container.half-container--narrow {
  max-width: 400px;
}

.inner-container {
  display: block;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0 0;
  clear: both;
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
  width: 90%;
  width: calc(100% - 30px);
  max-width: 1000px;
}
@media all and (min-width: 580px) {
  .inner-container {
    width: calc(100% - 50px);
  }
}
@media all and (min-width: 768px) {
  .inner-container {
    width: calc(100% - 100px);
  }
}
@media all and (min-width: 1080px) {
  .inner-container {
    width: calc(100% - 100px);
  }
}
@media all and (min-width: 1280px) {
  .inner-container {
    width: calc(100% - 140px);
  }
}
@media all and (min-width: 1440px) {
  .inner-container {
    width: calc(100% - 140px);
  }
}
.inner-container.inner-container--wide {
  max-width: 1200px;
}
.inner-container.inner-container--exwide {
  max-width: 1400px;
}
.inner-container.inner-container--narrow {
  max-width: 800px;
}

/*
================================================================
 サイトデザインの反映
================================================================
*/
html {
  background: #a7a7a7;
  background-repeat: repeat;
  background-size: auto;
  color: #000;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-align: left;
}

a {
  color: #06b;
  text-decoration: underline;
  opacity: 1;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a:hover {
  opacity: 0.7;
}

a.inherit {
  color: inherit;
  text-decoration: inherit;
}

a.href-box {
  display: block;
}

.set-call-link a {
  color: inherit;
  text-decoration: inherit;
}

ruby rt {
  transform: translateY(0.5em);
}

.twitter-tweet {
  margin-left: auto;
  margin-right: auto;
}

.text-left {
  text-align: left !important;
}

.text-center {
  text-align: center !important;
}

.text-right {
  text-align: right !important;
}

.text-justify {
  text-align: justify !important;
}

.line-break-span span {
  display: inline-block;
}

@media all and (max-width: 1279px) {
  .line-break-span-mb span {
    display: inline-block;
  }

  .line-break-span-mb br:not(.set--force) {
    display: none;
  }
}
/*
================================================================
 表示領域とスクロール領域
================================================================
*/
.display-content {
  position: relative;
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  min-height: 100dvh;
  max-width: 2560px;
  background: #fff;
  color: #000;
}

.display-content-area {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 2560px;
}

/* スクロール領域 */
@media print {
  /* for print color */
  html {
    background: transparent;
  }

  .display-content {
    background: transparent;
    color: #000;
  }
}
/*
================================================================
 エフェクト
================================================================
*/
/*
================================================================
 表示
================================================================
*/
.disp-blend-multiply {
  mix-blend-mode: multiply;
}

.disp-clip-box {
  overflow: hidden;
}

body.agent-prop--SP .is-PC-only {
  display: none !important;
}

body:not(.agent-prop--SP) .is-SP-only {
  display: none !important;
}

/*
================================================================
 操作
================================================================
*/
.jsctrl--disable-events {
  pointer-events: none !important;
}

/*
================================================================
 メイン領域
================================================================
*/
main.main-content {
  min-height: 240px;
}
main.main-content:last-child {
  min-height: 640px;
}

/*
================================================================
 グローバルヘッダー
================================================================
*/
/* スクロール位置 */
/* ヘッダー */
.global-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9000;
  display: block;
  width: 100%;
  height: 70px;
  color: #000;
}
.global-header::before {
  content: "";
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  display: block;
  box-sizing: border-box;
  width: 100%;
  height: 0;
  background: #fff;
  opacity: 0;
  transition: height 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.scroll--scrolled .global-header::before {
  height: 100%;
  opacity: 1;
}

/* タイトル部 */
.global-header-title {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
}
.global-header-title .content-container {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 1400px;
}

.global-header-title__label {
  position: absolute;
  top: 10px;
  left: 25px;
  z-index: 12;
  display: block;
  box-sizing: border-box;
  height: 50px;
  padding: 0 0;
  width: auto;
  width: -moz-max-content;
  /* Firefox */
  width: -webkit-max-content;
  /* Chrome */
  width: max-content;
}
.global-header-title__label img {
  display: block;
  width: auto;
  height: 100%;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.global-header-title__label img.this__white {
  opacity: 1;
}
.global-header-title__label img.this__color {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
.top-hero-initialized .global-header-title__label img.this__white, .scroll--scrolled .global-header-title__label img.this__white {
  opacity: 0;
}
.top-hero-initialized .global-header-title__label img.this__color, .scroll--scrolled .global-header-title__label img.this__color {
  opacity: 1;
}

/* ハンバーガーメニュー ボタン */
.global-header-toggle {
  position: absolute;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
}
.global-header-toggle .content-container {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.global-header-toggle-button {
  position: absolute;
  right: 10px;
  top: 10px;
  z-index: 13;
  display: block;
  margin: 0;
  padding: 0;
  border: 0 none;
  outline: 0 none;
  background-color: #fff;
  width: 50px;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
}
.global-header-toggle-button::before {
  /* auto height */
  content: "";
  display: block;
  box-sizing: content-box;
  width: 100%;
  height: 0;
  margin: 0;
  padding: 100% 0 0;
}
.global-header-toggle-button::before {
  opacity: 0;
  background-image: linear-gradient(60deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.global-header-toggle-button span {
  position: absolute;
  z-index: 2;
  left: 25%;
  display: block;
  box-sizing: content-box;
  width: 50%;
  height: 0;
  margin-top: -1px;
  border-top: 1px solid #2b4a8a;
  opacity: 1;
  transition: border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, top 0.3s cubic-bezier(0, 0, 0.6, 1) 0.3s, opacity 0.3s cubic-bezier(0, 0, 0.6, 1) 0.3s, left 0.3s cubic-bezier(0.4, 0, 1, 1) 0s, width 0.3s cubic-bezier(0.4, 0, 1, 1) 0s, transform 0.3s cubic-bezier(0.4, 0, 1, 1) 0s;
}
.global-header-toggle-button span:nth-child(1) {
  top: 40%;
}
.global-header-toggle-button span:nth-child(2) {
  top: 60%;
}
.top-hero-initialized .global-header-toggle-button::before, .scroll--scrolled .global-header-toggle-button::before {
  opacity: 1;
}
.top-hero-initialized .global-header-toggle-button span, .scroll--scrolled .global-header-toggle-button span {
  border-top-color: #fff;
}
.global-header--green .global-header-toggle-button::before {
  opacity: 1;
  background-image: linear-gradient(60deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
}
.global-header--green .global-header-toggle-button span {
  border-top-color: #fff;
}

/* ハンバーガーメニュー 項目 */
.global-header-content {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
}
.global-header-content .content-container {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.global-header-content__canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.global-header-content__display-height {
  display: none;
  height: 100vh;
  height: 100lvh;
}

.global-header-content__panel {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 100%;
}
.global-header-content__panel .content-container {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

.global-header-nav {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: flex-end;
  box-sizing: border-box;
  margin: 0 0 0;
  padding: 0 0 0;
  width: 100%;
  height: 70px;
}

.global-header-nav-menu {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: flex-start;
  box-sizing: border-box;
  margin: 0 0 0;
  padding: 15px 0 15px;
  height: 70px;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
.global-header-nav-menu > .menu-item {
  position: relative;
  display: block;
  box-sizing: border-box;
  width: auto;
  width: -moz-max-content;
  /* Firefox */
  width: -webkit-max-content;
  /* Chrome */
  width: max-content;
  height: 100%;
  margin: 0;
  padding: 0 5px;
}
.global-header-nav-menu > .menu-item > a, .global-header-nav-menu > .menu-item > .as-link {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  height: 100%;
  margin: 0;
  padding: 4px 20px 0;
  cursor: pointer;
  text-decoration: none;
  opacity: 1;
  text-align: center;
  color: #fff;
  font-size: 0.75rem;
  line-height: 30px;
  transition: color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.top-hero-initialized .global-header-nav-menu > .menu-item > a, .scroll--scrolled .global-header-nav-menu > .menu-item > a, .top-hero-initialized .global-header-nav-menu > .menu-item > .as-link, .scroll--scrolled .global-header-nav-menu > .menu-item > .as-link {
  color: #000;
}
.global-header-nav-menu > .menu-item > a:hover {
  opacity: 0.7;
}
.global-header-nav-menu > .menu-item.menu-item-has-children > a, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link {
  padding-right: 32px;
}
.global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::before, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  display: block;
  margin-top: -4px;
  width: 8px;
  height: 8px;
  background-image: url(../img/common/angle_bottom.svg);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::after, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  display: block;
  margin-top: -4px;
  width: 8px;
  height: 8px;
  background-image: url(../img/common/angle_bottom_white.svg);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  opacity: 1;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.top-hero-initialized .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::before, .scroll--scrolled .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::before, .top-hero-initialized .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::before, .scroll--scrolled .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::before {
  opacity: 1;
}
.top-hero-initialized .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::after, .scroll--scrolled .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::after, .top-hero-initialized .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::after, .scroll--scrolled .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::after {
  opacity: 0;
}
.global-header-nav-menu > .menu-item .sub-menu {
  position: absolute;
  z-index: 11;
  top: 100%;
  left: 50%;
  margin: 0;
  padding: 12px 0;
  opacity: 0;
  visibility: hidden;
  transform: translate(-50%, 0);
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, transform 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, visibility 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
  background: #fff;
  display: block;
  box-sizing: border-box;
  width: 190px;
  border-radius: 5px;
  box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.5);
}
.global-header-nav-menu > .menu-item .sub-menu > .menu-item {
  width: calc(100% - 6px);
  height: auto;
}
.global-header-nav-menu > .menu-item .sub-menu > .menu-item > a, .global-header-nav-menu > .menu-item .sub-menu > .menu-item > .as-link {
  display: block;
  box-sizing: border-box;
  width: 100%;
  padding: 1px 0 3px;
  cursor: pointer;
  color: #000;
  text-decoration: none;
  font-size: 0.75rem;
  line-height: 20px;
  text-align: center;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.global-header-nav-menu > .menu-item .sub-menu > .menu-item > a:hover {
  opacity: 0.7;
}
body:not(.agent-prop--TouchMode):not(.open-global-header-subnav) .global-header-nav-menu > .menu-item.menu-item-has-children:hover > .sub-menu, body.open-global-header-subnav--service .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service > .sub-menu {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, transform 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, visibility 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}

.global-header-nav-btn {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: flex-start;
  box-sizing: border-box;
  margin: 0 0 0;
  padding: 15px 0;
  height: 70px;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
.global-header-nav-btn > .menu-item {
  position: relative;
  display: block;
  box-sizing: border-box;
  height: 100%;
  margin: 0;
  padding: 0 20px;
}
.global-header-nav-btn > .menu-item > a, .global-header-nav-btn > .menu-item > .as-link {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  height: 100%;
  margin: 0;
  padding: 5px 40px 5px;
  border-radius: 20px;
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;
  opacity: 1;
  text-align: center;
  background-color: #fff;
  color: #2b4a8a;
  font-size: 0.75rem;
  line-height: 30px;
  transition: color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.global-header-nav-btn > .menu-item > a::before, .global-header-nav-btn > .menu-item > .as-link::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(60deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.global-header-nav-btn > .menu-item > a .this__title, .global-header-nav-btn > .menu-item > .as-link .this__title {
  position: relative;
  z-index: 2;
}
.top-hero-initialized .global-header-nav-btn > .menu-item > a, .scroll--scrolled .global-header-nav-btn > .menu-item > a, .top-hero-initialized .global-header-nav-btn > .menu-item > .as-link, .scroll--scrolled .global-header-nav-btn > .menu-item > .as-link {
  color: #fff;
}
.top-hero-initialized .global-header-nav-btn > .menu-item > a::before, .scroll--scrolled .global-header-nav-btn > .menu-item > a::before, .top-hero-initialized .global-header-nav-btn > .menu-item > .as-link::before, .scroll--scrolled .global-header-nav-btn > .menu-item > .as-link::before {
  opacity: 1;
}
.global-header--green .global-header-nav-btn > .menu-item > a, .global-header--green .global-header-nav-btn > .menu-item > .as-link {
  color: #fff;
}
.global-header--green .global-header-nav-btn > .menu-item > a::before, .global-header--green .global-header-nav-btn > .menu-item > .as-link::before {
  opacity: 1;
  background-image: linear-gradient(60deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
}
.global-header-nav-btn > .menu-item > a:hover {
  opacity: 0.7;
}

@media all and (max-width: 1079px) {
  .global-header-nav-menu > .menu-item {
    padding: 0 5px;
  }
  .global-header-nav-menu > .menu-item > a, .global-header-nav-menu > .menu-item > .as-link {
    padding: 4px 10px 0;
    font-size: 0.75rem;
    line-height: 30px;
  }
  .global-header-nav-menu > .menu-item.menu-item-has-children > a, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link {
    padding-right: 22px;
  }
  .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::before, .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::after, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::before, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::after {
    right: 8px;
    margin-top: -4px;
    width: 8px;
    height: 8px;
  }
  .global-header-nav-menu > .menu-item .sub-menu {
    top: 100%;
    left: 50%;
    padding: 12px 0;
    width: 190px;
    border-radius: 5px;
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.5);
  }
  .global-header-nav-menu > .menu-item .sub-menu > .menu-item {
    width: calc(100% - 6px);
  }
  .global-header-nav-menu > .menu-item .sub-menu > .menu-item > a, .global-header-nav-menu > .menu-item .sub-menu > .menu-item > .as-link {
    padding: 1px 0 3px;
    font-size: 0.75rem;
    line-height: 20px;
  }

  .global-header-nav-btn > .menu-item {
    padding: 0 20px;
  }
  .global-header-nav-btn > .menu-item > a, .global-header-nav-btn > .menu-item > .as-link {
    padding: 5px 30px 5px;
    border-radius: 20px;
    font-size: 0.75rem;
    line-height: 30px;
  }
}
@media all and (max-width: 767px) {
  .global-header {
    height: 70px;
  }

  .global-header-title__label {
    top: 10px;
    left: 10px;
  }

  .global-header-toggle {
    display: block;
  }

  .global-header-content__canvas {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    min-height: 100vh;
    min-height: 100lvh;
    opacity: 0;
    overflow: hidden;
    visibility: hidden;
    transform: translateY(-100%);
    transition: opacity 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s, transform 0s 0.6s, visibility 0s 0.6s;
    background-color: rgba(255, 255, 255, 0.95);
  }

  .global-header-content__display-height {
    display: block;
  }

  .global-header-content__panel {
    position: absolute;
    top: 70px;
    left: 0;
    height: calc( 100% - 70px );
    width: 100%;
    overflow: auto;
    visibility: hidden;
    opacity: 0;
    transform: translateY(-100%);
    transition: transform 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s, top 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s, visibility 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s;
  }
  .global-header-content__panel .content-container {
    height: auto;
    padding: 0 0 calc(100lvh - 100svh);
  }

  .global-header-nav {
    position: relative;
    display: block;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    height: auto;
  }

  .global-header-nav-menu {
    position: static;
    display: block;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    height: auto;
    padding: 0;
    margin: 0 0;
    background-color: #b3c9e2;
  }
  .global-header-nav-menu > .menu-item {
    width: 100%;
    height: 70px;
    margin: 0;
    padding: 0;
    overflow: hidden;
    transition: height 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
  }
  .global-header-nav-menu > .menu-item:first-child > a, .global-header-nav-menu > .menu-item:first-child > .as-link {
    border-top-color: transparent;
  }
  .global-header-nav-menu > .menu-item.menu-item-has-children > a, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link {
    padding-right: 30px;
  }
  .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title {
    position: relative;
  }
  .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::before, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::before {
    opacity: 1;
    right: -30px;
    width: 10px;
    height: 10px;
    margin-top: -4px;
    transform: rotate(-90deg);
    transition: margin 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
  }
  .global-header-nav-menu > .menu-item.menu-item-has-children > a .this__title::after, .global-header-nav-menu > .menu-item.menu-item-has-children > .as-link .this__title::after {
    display: none;
    opacity: 0;
  }
  .global-header-nav-menu > .menu-item > a, .global-header-nav-menu > .menu-item > .as-link {
    width: 100%;
    height: 70px;
    padding: 18px 30px 21px;
    text-align: center;
    color: #000;
    border-top: 1px solid #fff;
    text-decoration: none;
    font-size: 1rem;
    line-height: 30px;
  }
  .global-header-nav-menu > .menu-item .sub-menu {
    position: static;
    top: 0;
    left: 0;
    padding: 0;
    width: 100%;
    border-radius: 0;
    box-shadow: none;
    background-color: #d2dfee;
    opacity: 1;
    visibility: visible;
    transform: none;
    transition: none;
  }
  .global-header-nav-menu > .menu-item .sub-menu > .menu-item {
    width: 100%;
  }
  .global-header-nav-menu > .menu-item .sub-menu > .menu-item > a, .global-header-nav-menu > .menu-item .sub-menu > .menu-item > .as-link {
    height: 70px;
    padding: 18px 30px 21px;
    font-size: 1rem;
    line-height: 30px;
    color: #6893c6;
    border-top: 1px solid #fff;
  }
  body:not(.agent-prop--TouchMode):not(.open-global-header-subnav) .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service:hover, body.open-global-header-subnav--service .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service {
    height: 350px;
  }
  body:not(.agent-prop--TouchMode):not(.open-global-header-subnav) .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service:hover > a .this__title::before, body:not(.agent-prop--TouchMode):not(.open-global-header-subnav) .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service:hover > .as-link .this__title::before, body.open-global-header-subnav--service .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service > a .this__title::before, body.open-global-header-subnav--service .global-header-nav-menu > .menu-item.menu-item-has-children.global-header-subnav--service > .as-link .this__title::before {
    transform: none;
  }
  .global-header--green .global-header-nav-menu {
    background-color: #99c2ad;
  }
  .global-header--green .global-header-nav-menu > .menu-item .sub-menu {
    background-color: #cce0d6;
  }
  .global-header--green .global-header-nav-menu > .menu-item .sub-menu > .menu-item > a, .global-header--green .global-header-nav-menu > .menu-item .sub-menu > .menu-item > .as-link {
    color: #1eaa39;
  }

  .global-header-nav-btn {
    position: static;
    display: block;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    height: auto;
    padding: 0 0 0;
    margin: 0 0;
    background-color: #2b4a8a;
  }
  .global-header-nav-btn > .menu-item {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }
  .global-header-nav-btn > .menu-item > a, .global-header-nav-btn > .menu-item > .as-link {
    width: 100%;
    padding: 20px 20px 20px;
    text-align: center;
    color: #fff;
    text-decoration: none;
    font-size: 1rem;
    line-height: 30px;
    border-radius: 0;
    transition: none;
  }
  .global-header-nav-btn > .menu-item > a::before, .global-header-nav-btn > .menu-item > .as-link::before {
    opacity: 1;
    transition: none;
  }
  .global-header-nav-btn > .menu-item > a .this__title, .global-header-nav-btn > .menu-item > .as-link .this__title {
    display: inline-block;
    vertical-align: middle;
  }
  .global-header-nav-btn > .menu-item > a:hover, .global-header-nav-btn > .menu-item > .as-link:hover {
    opacity: 1;
  }
  .global-header--green .global-header-nav-btn {
    background-color: #006633;
  }

  /* ハンバーガーメニュー 展開時 */
  .open-global-header-nav .global-header::before {
    height: 100%;
    opacity: 1;
  }
  .open-global-header-nav .global-header-title__label img.this__white {
    opacity: 0;
  }
  .open-global-header-nav .global-header-title__label img.this__color {
    opacity: 1;
  }
  .open-global-header-nav .global-header-toggle-button::before {
    opacity: 1;
  }
  .open-global-header-nav .global-header-toggle-button span {
    border-top-color: #fff;
    top: 50%;
    transition: border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, top 0.3s cubic-bezier(0.4, 0, 1, 1) 0s, opacity 0.3s cubic-bezier(0.4, 0, 1, 1) 0s, left 0.3s cubic-bezier(0, 0, 0.6, 1) 0.3s, width 0.3s cubic-bezier(0, 0, 0.6, 1) 0.3s, transform 0.3s cubic-bezier(0, 0, 0.6, 1) 0.3s;
  }
  .open-global-header-nav .global-header-toggle-button span:nth-child(1) {
    left: 22.5%;
    width: 55%;
    transform: rotate(25deg);
  }
  .open-global-header-nav .global-header-toggle-button span:nth-child(2) {
    left: 22.5%;
    width: 55%;
    transform: rotate(-25deg);
  }
  .open-global-header-nav .global-header-content__canvas {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s;
  }
  .open-global-header-nav .global-header-content__panel {
    visibility: visible;
    opacity: 1;
    transform: translateX(0);
  }
}
@media print {
  /* 印刷時 */
  .global-header {
    position: absolute;
  }
}
/*
================================================================
 フッターバナー
================================================================
*/
ul.content-footer-bnr {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: 0 auto;
  padding: 100px 0;
  list-style-type: none;
}
ul.content-footer-bnr > li {
  width: calc(25% - 15px);
  margin: 0 0 20px 20px;
  padding: 0;
  list-style-type: none;
}
ul.content-footer-bnr > li:nth-child(4n+1) {
  margin-left: 0;
}
ul.content-footer-bnr > li > a, ul.content-footer-bnr > li > .as-link {
  display: block;
  width: 100%;
}
ul.content-footer-bnr > li img {
  display: block;
  width: 100%;
  height: auto;
}

@media all and (max-width: 1079px) {
  ul.content-footer-bnr {
    padding: 60px 0;
    max-width: 720px;
  }
  ul.content-footer-bnr > li {
    width: calc(50% - 10px);
    margin: 0 0 20px 20px;
  }
  ul.content-footer-bnr > li:nth-child(2n+1) {
    margin-left: 0;
  }
}
@media all and (max-width: 579px) {
  ul.content-footer-bnr {
    padding: 60px 0;
  }
  ul.content-footer-bnr > li {
    width: 100%;
    margin: 0 0 20px;
  }
}
/*
================================================================
 スクロールボタン
================================================================
*/
.scroll-to-top_container {
  position: sticky;
  z-index: 8990;
  bottom: 50px;
  display: block;
  margin-top: 40px;
  height: 0;
}
.scroll-to-top_container .container {
  position: relative;
}

a.scroll-to-top {
  position: absolute;
  right: -40px;
  bottom: -40px;
  display: block;
  box-sizing: border-box;
  width: 80px;
  height: 80px;
  padding: 0;
  margin: 0;
  background-color: #2b4a8a;
  border-radius: 50%;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.6s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.scroll-to-top img {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 15px;
  height: auto;
  transform: translate(-50%, -50%);
}
a.scroll-to-top.scrolled {
  visibility: visible;
  opacity: 1;
}
a.scroll-to-top.scrolled:hover {
  opacity: 0.7;
}
a.scroll-to-top.scroll-to-top--green {
  background-color: #006633;
}

@media all and (max-width: 1079px) {
  .scroll-to-top_container {
    bottom: 40px;
    margin-top: 30px;
  }

  a.scroll-to-top {
    right: -30px;
    bottom: -30px;
    width: 60px;
    height: 60px;
  }
}
@media all and (max-width: 767px) {
  .scroll-to-top_container {
    bottom: 35px;
    margin-top: 25px;
  }

  a.scroll-to-top {
    right: -15px;
    bottom: -25px;
    width: 50px;
    height: 50px;
  }
}
@media all and (max-width: 579px) {
  .scroll-to-top_container {
    bottom: 35px;
    margin-top: 25px;
  }

  a.scroll-to-top {
    right: -5px;
    bottom: -25px;
    width: 50px;
    height: 50px;
  }
}
@media all and (max-height: 479px) {
  a.scroll-to-top {
    display: none !important;
  }
}
@media print {
  a.scroll-to-top {
    display: none !important;
  }
}
/*
================================================================
 グローバルフッター
================================================================
*/
.global-footer {
  position: relative;
  z-index: 8900;
  display: block;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 60px 0 0;
  background-color: #d2dfee;
  color: #000;
}
.global-footer.global-footer--green {
  background-color: #cce0d6;
}

.global-footer-layout {
  display: block;
}

.global-footer-menu {
  margin: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
.global-footer-menu .content-container {
  text-align: center;
}

.global-footer-nav-menu {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-size: 0.75rem;
  line-height: 1.2;
  text-align: center;
}
.global-footer-nav-menu > .menu-item {
  position: relative;
  margin: 0 0 20px;
  padding: 0 1px 0 0;
}
.global-footer-nav-menu > .menu-item::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  display: block;
  box-sizing: content-box;
  width: 0;
  height: 1.2em;
  margin-top: -0.6em;
  border-right: 1px solid #000;
}
.global-footer-nav-menu > .menu-item:last-child {
  padding-right: 0;
}
.global-footer-nav-menu > .menu-item:last-child::after {
  display: none;
}
.global-footer-nav-menu > .menu-item > a, .global-footer-nav-menu > .menu-item > .as-link {
  display: block;
  padding: 0 3em;
  cursor: pointer;
  color: #000;
  text-decoration: none;
  opacity: 1;
  transition: opacity 0.4s ease 0s;
}
.global-footer-nav-menu > .menu-item > a:hover, .global-footer-nav-menu > .menu-item > .as-link:hover {
  opacity: 0.7;
}

.global-footer-credit {
  margin: 60px 0 40px;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  font-feature-settings: "palt" 1;
}
.global-footer-credit .content-container {
  position: relative;
  padding: 0 100px 0;
  text-align: center;
}
.global-footer-credit .content-container a {
  color: #000;
  text-decoration: none;
  opacity: 1;
  transition: opacity 0.4s ease 0s;
}
.global-footer-credit .content-container a:hover {
  opacity: 0.7;
}
.global-footer-credit .content-container .this__name {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.125rem;
  line-height: 1.4;
}
.global-footer-credit .content-container .this__address {
  margin-top: 5px;
  font-size: 0.8125rem;
  line-height: 1.8;
}
.global-footer-credit .content-container .this__sns {
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 100px;
}
.global-footer-credit .content-container .this__sns ul.this__sns-list {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  list-style-type: none;
}
.global-footer-credit .content-container .this__sns ul.this__sns-list > li {
  display: block;
  width: 35px;
  margin: 0 0 0 15px;
  list-style-type: none;
}
.global-footer-credit .content-container .this__sns ul.this__sns-list > li:first-child {
  margin-left: 0;
}
.global-footer-credit .content-container .this__sns ul.this__sns-list > li a {
  display: block;
  width: 100%;
}
.global-footer-credit .content-container .this__sns ul.this__sns-list > li img {
  display: block;
  width: 100%;
  height: auto;
}

.global-footer-copyright {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 20px 0 22px;
  background-color: #2b4a8a;
  color: #fff;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 0.75rem;
  line-height: 1.5;
  text-align: center;
}
.global-footer--green .global-footer-copyright {
  background-color: #006633;
}

@media all and (max-width: 1079px) {
  .global-footer-nav-menu {
    font-size: 0.75rem;
    line-height: 1.2;
  }
  .global-footer-nav-menu > .menu-item {
    margin: 0 0 20px;
  }
  .global-footer-nav-menu > .menu-item > a, .global-footer-nav-menu > .menu-item > .as-link {
    padding: 0 2em;
  }
}
@media all and (max-width: 767px) {
  .global-footer {
    padding: 40px 0 0;
  }

  .global-footer-menu {
    margin: 0;
  }
  .global-footer-menu .content-container {
    text-align: left;
  }

  .global-footer-nav-menu {
    justify-content: flex-start;
    width: 320px;
    max-width: 100%;
    margin: 0 auto;
    font-size: 0.75rem;
    line-height: 1.5;
    text-align: left;
  }
  .global-footer-nav-menu > .menu-item {
    position: relative;
    margin: 0 0 1em;
    padding: 0;
    width: 33.3333%;
    min-width: 8em;
  }
  .global-footer-nav-menu > .menu-item::after {
    display: none;
  }
  .global-footer-nav-menu > .menu-item > a, .global-footer-nav-menu > .menu-item > .as-link {
    box-sizing: border-box;
    width: 100%;
    padding: 0 2em 0 1em;
  }
  .global-footer-nav-menu > .menu-item > a::before, .global-footer-nav-menu > .menu-item > .as-link::before {
    content: '-';
    display: inline-block;
    width: 1em;
    margin-left: -1em;
  }
  .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item {
    width: auto;
  }
  .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item > a, .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item > .as-link {
    width: auto;
    padding: 0 2em 0 1em;
  }
  .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item > a::before, .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item > .as-link::before {
    content: '-';
    display: inline-block;
    width: 1em;
    margin-left: -1em;
  }
  .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item:last-child > a, .global-footer-nav-menu.global-footer-nav-menu--long-name-items > .menu-item:last-child > .as-link {
    padding-right: 0;
  }

  .global-footer-credit {
    margin: 40px 0 20px;
    font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 400;
    font-feature-settings: "palt" 1;
  }
  .global-footer-credit .content-container {
    padding: 0;
    text-align: center;
  }
  .global-footer-credit .content-container .this__name {
    font-size: 1rem;
    line-height: 1.4;
  }
  .global-footer-credit .content-container .this__address {
    margin-top: 5px;
    font-size: 0.75rem;
    line-height: 1.8;
  }
  .global-footer-credit .content-container .this__sns {
    position: static;
    width: 100%;
    margin: 20px 0 0;
  }
  .global-footer-credit .content-container .this__sns ul.this__sns-list {
    justify-content: center;
    width: 100%;
  }
  .global-footer-credit .content-container .this__sns ul.this__sns-list > li {
    width: 35px;
    margin: 0 0 0 15px;
  }

  .global-footer-copyright {
    padding: 14px 0 16px;
    font-size: 0.6875rem;
    line-height: 1.25rem;
    text-align: center;
  }
}
@media (max-width: 340px) {
  .global-footer-nav-menu {
    display: block;
    height: auto;
  }
}
/*
================================================================
 共通パーツ
================================================================
*/
a.nav-btn, a.nav-btn-move, a.nav-btn-forward, input[type="submit"].nav-btn, input[type="submit"].nav-btn-move, input[type="submit"].nav-btn-forward, input[type="button"].nav-btn, input[type="button"].nav-btn-move, input[type="button"].nav-btn-forward, button.nav-btn, button.nav-btn-move, button.nav-btn-forward {
  display: inline-block;
  box-sizing: border-box;
  min-width: 220px;
  max-width: 100%;
  padding: 9px 35px 9px;
  border: 0 none;
  outline: 0 none;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-decoration: none !important;
  font-size: 1rem;
  line-height: 40px;
  text-align: center;
  background-color: #fff !important;
  color: #000 !important;
  border: 1px solid #000 !important;
  border-radius: 30px;
  transform: none;
  transition: background-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.nav-btn:hover, a.nav-btn-move:hover, a.nav-btn-forward:hover, input[type="submit"].nav-btn:hover, input[type="submit"].nav-btn-move:hover, input[type="submit"].nav-btn-forward:hover, input[type="button"].nav-btn:hover, input[type="button"].nav-btn-move:hover, input[type="button"].nav-btn-forward:hover, button.nav-btn:hover, button.nav-btn-move:hover, button.nav-btn-forward:hover {
  opacity: 1;
  background-color: #2b4a8a !important;
  color: #fff !important;
  border-color: #2b4a8a !important;
}
a.nav-btn:disabled, a.nav-btn-move:disabled, a.nav-btn-forward:disabled, input[type="submit"].nav-btn:disabled, input[type="submit"].nav-btn-move:disabled, input[type="submit"].nav-btn-forward:disabled, input[type="button"].nav-btn:disabled, input[type="button"].nav-btn-move:disabled, input[type="button"].nav-btn-forward:disabled, button.nav-btn:disabled, button.nav-btn-move:disabled, button.nav-btn-forward:disabled {
  background-color: #a7a7a7 !important;
}
a.nav-btn:disabled:hover, a.nav-btn-move:disabled:hover, a.nav-btn-forward:disabled:hover, input[type="submit"].nav-btn:disabled:hover, input[type="submit"].nav-btn-move:disabled:hover, input[type="submit"].nav-btn-forward:disabled:hover, input[type="button"].nav-btn:disabled:hover, input[type="button"].nav-btn-move:disabled:hover, input[type="button"].nav-btn-forward:disabled:hover, button.nav-btn:disabled:hover, button.nav-btn-move:disabled:hover, button.nav-btn-forward:disabled:hover {
  background-color: #a7a7a7 !important;
  color: #000 !important;
  border-color: #000 !important;
}
@media all and (max-width: 767px) {
  a.nav-btn, a.nav-btn-move, a.nav-btn-forward, input[type="submit"].nav-btn, input[type="submit"].nav-btn-move, input[type="submit"].nav-btn-forward, input[type="button"].nav-btn, input[type="button"].nav-btn-move, input[type="button"].nav-btn-forward, button.nav-btn, button.nav-btn-move, button.nav-btn-forward {
    min-width: 180px;
    padding: 9px 30px 9px;
    font-size: 0.875rem;
    line-height: 30px;
    border-radius: 25px;
  }
}

a.nav-btn-white, a.nav-btn-move-white, a.nav-btn-forward-white, input[type="submit"].nav-btn-white, input[type="submit"].nav-btn-move-white, input[type="submit"].nav-btn-forward-white, input[type="button"].nav-btn-white, input[type="button"].nav-btn-move-white, input[type="button"].nav-btn-forward-white, button.nav-btn-white, button.nav-btn-move-white, button.nav-btn-forward-white {
  display: inline-block;
  box-sizing: border-box;
  min-width: 220px;
  max-width: 100%;
  padding: 9px 35px 9px;
  border: 0 none;
  outline: 0 none;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-decoration: none !important;
  font-size: 1rem;
  line-height: 40px;
  text-align: center;
  background-color: rgba(255, 255, 255, 0) !important;
  color: #fff !important;
  border: 1px solid #fff !important;
  border-radius: 30px;
  transform: none;
  transition: background-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.nav-btn-white:hover, a.nav-btn-move-white:hover, a.nav-btn-forward-white:hover, input[type="submit"].nav-btn-white:hover, input[type="submit"].nav-btn-move-white:hover, input[type="submit"].nav-btn-forward-white:hover, input[type="button"].nav-btn-white:hover, input[type="button"].nav-btn-move-white:hover, input[type="button"].nav-btn-forward-white:hover, button.nav-btn-white:hover, button.nav-btn-move-white:hover, button.nav-btn-forward-white:hover {
  opacity: 1;
  background-color: white !important;
  color: #000 !important;
  border-color: #fff !important;
}
a.nav-btn-white:disabled, a.nav-btn-move-white:disabled, a.nav-btn-forward-white:disabled, input[type="submit"].nav-btn-white:disabled, input[type="submit"].nav-btn-move-white:disabled, input[type="submit"].nav-btn-forward-white:disabled, input[type="button"].nav-btn-white:disabled, input[type="button"].nav-btn-move-white:disabled, input[type="button"].nav-btn-forward-white:disabled, button.nav-btn-white:disabled, button.nav-btn-move-white:disabled, button.nav-btn-forward-white:disabled {
  color: #a7a7a7 !important;
  border-color: #a7a7a7 !important;
}
a.nav-btn-white:disabled:hover, a.nav-btn-move-white:disabled:hover, a.nav-btn-forward-white:disabled:hover, input[type="submit"].nav-btn-white:disabled:hover, input[type="submit"].nav-btn-move-white:disabled:hover, input[type="submit"].nav-btn-forward-white:disabled:hover, input[type="button"].nav-btn-white:disabled:hover, input[type="button"].nav-btn-move-white:disabled:hover, input[type="button"].nav-btn-forward-white:disabled:hover, button.nav-btn-white:disabled:hover, button.nav-btn-move-white:disabled:hover, button.nav-btn-forward-white:disabled:hover {
  background-color: rgba(255, 255, 255, 0) !important;
  color: #a7a7a7 !important;
  border-color: #a7a7a7 !important;
}
@media all and (max-width: 767px) {
  a.nav-btn-white, a.nav-btn-move-white, a.nav-btn-forward-white, input[type="submit"].nav-btn-white, input[type="submit"].nav-btn-move-white, input[type="submit"].nav-btn-forward-white, input[type="button"].nav-btn-white, input[type="button"].nav-btn-move-white, input[type="button"].nav-btn-forward-white, button.nav-btn-white, button.nav-btn-move-white, button.nav-btn-forward-white {
    min-width: 180px;
    padding: 9px 30px 9px;
    font-size: 0.875rem;
    line-height: 30px;
    border-radius: 25px;
  }
}

a.nav-btn-menu, a.nav-btn-menu-blue, input[type="submit"].nav-btn-menu, input[type="submit"].nav-btn-menu-blue, input[type="button"].nav-btn-menu, input[type="button"].nav-btn-menu-blue, button.nav-btn-menu, button.nav-btn-menu-blue {
  display: inline-block;
  box-sizing: border-box;
  min-width: 220px;
  max-width: 100%;
  padding: 10px 35px 10px;
  border: 0 none;
  outline: 0 none;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-decoration: none !important;
  font-size: 1rem;
  line-height: 40px;
  text-align: center;
  background-color: #2b4a8a !important;
  background-image: linear-gradient(60deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff !important;
  border-radius: 30px;
  transform: none;
  transition: background-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.nav-btn-menu:hover, a.nav-btn-menu-blue:hover, input[type="submit"].nav-btn-menu:hover, input[type="submit"].nav-btn-menu-blue:hover, input[type="button"].nav-btn-menu:hover, input[type="button"].nav-btn-menu-blue:hover, button.nav-btn-menu:hover, button.nav-btn-menu-blue:hover {
  opacity: 0.7;
}
@media all and (max-width: 767px) {
  a.nav-btn-menu, a.nav-btn-menu-blue, input[type="submit"].nav-btn-menu, input[type="submit"].nav-btn-menu-blue, input[type="button"].nav-btn-menu, input[type="button"].nav-btn-menu-blue, button.nav-btn-menu, button.nav-btn-menu-blue {
    min-width: 180px;
    padding: 9px 30px 9px;
    font-size: 0.875rem;
    line-height: 30px;
    border-radius: 25px;
  }
}

a.nav-btn-menu-green, input[type="submit"].nav-btn-menu-green, input[type="button"].nav-btn-menu-green, button.nav-btn-menu-green {
  display: inline-block;
  box-sizing: border-box;
  min-width: 220px;
  max-width: 100%;
  padding: 10px 35px 10px;
  border: 0 none;
  outline: 0 none;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-decoration: none !important;
  font-size: 1rem;
  line-height: 40px;
  text-align: center;
  background-color: #006633 !important;
  background-image: linear-gradient(60deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff !important;
  border-radius: 30px;
  transform: none;
  transition: background-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.nav-btn-menu-green:hover, input[type="submit"].nav-btn-menu-green:hover, input[type="button"].nav-btn-menu-green:hover, button.nav-btn-menu-green:hover {
  opacity: 0.7;
}
@media all and (max-width: 767px) {
  a.nav-btn-menu-green, input[type="submit"].nav-btn-menu-green, input[type="button"].nav-btn-menu-green, button.nav-btn-menu-green {
    min-width: 180px;
    padding: 9px 30px 9px;
    font-size: 0.875rem;
    line-height: 30px;
    border-radius: 25px;
  }
}

a.nav-btn-back, input[type="submit"].nav-btn-back, input[type="button"].nav-btn-back, button.nav-btn-back, .form-btn-back a, .form-btn-back input[type="submit"], .form-btn-back input[type="button"], .form-btn-back button {
  display: inline-block;
  box-sizing: border-box;
  min-width: 220px;
  max-width: 100%;
  padding: 9px 35px 9px;
  border: 0 none;
  outline: 0 none;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-decoration: none !important;
  font-size: 1rem;
  line-height: 40px;
  text-align: center;
  background-color: #fff !important;
  color: #000 !important;
  border: 1px solid #000 !important;
  border-radius: 30px;
  transform: none;
  transition: background-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.nav-btn-back:hover, input[type="submit"].nav-btn-back:hover, input[type="button"].nav-btn-back:hover, button.nav-btn-back:hover, .form-btn-back a:hover, .form-btn-back input[type="submit"]:hover, .form-btn-back input[type="button"]:hover, .form-btn-back button:hover {
  opacity: 1;
  background-color: #2b4a8a !important;
  color: #fff !important;
  border-color: #2b4a8a !important;
}
a.nav-btn-back:disabled, input[type="submit"].nav-btn-back:disabled, input[type="button"].nav-btn-back:disabled, button.nav-btn-back:disabled, .form-btn-back a:disabled, .form-btn-back input[type="submit"]:disabled, .form-btn-back input[type="button"]:disabled, .form-btn-back button:disabled {
  background-color: #a7a7a7 !important;
}
a.nav-btn-back:disabled:hover, input[type="submit"].nav-btn-back:disabled:hover, input[type="button"].nav-btn-back:disabled:hover, button.nav-btn-back:disabled:hover, .form-btn-back a:disabled:hover, .form-btn-back input[type="submit"]:disabled:hover, .form-btn-back input[type="button"]:disabled:hover, .form-btn-back button:disabled:hover {
  background-color: #a7a7a7 !important;
  color: #000 !important;
  border-color: #000 !important;
}
@media all and (max-width: 767px) {
  a.nav-btn-back, input[type="submit"].nav-btn-back, input[type="button"].nav-btn-back, button.nav-btn-back, .form-btn-back a, .form-btn-back input[type="submit"], .form-btn-back input[type="button"], .form-btn-back button {
    min-width: 180px;
    padding: 10px 30px 10px;
    font-size: 0.875rem;
    line-height: 30px;
    border-radius: 25px;
  }
}

a.nav-btn-submit, input[type="submit"].nav-btn-submit, input[type="button"].nav-btn-submit, button.nav-btn-submit, .form-btn-submit a, .form-btn-submit input[type="submit"], .form-btn-submit input[type="button"], .form-btn-submit button {
  display: inline-block;
  box-sizing: border-box;
  min-width: 240px;
  max-width: 100%;
  padding: 8px 30px 8px;
  border: 0 none;
  outline: 0 none;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  text-decoration: none !important;
  font-size: 1.125rem;
  line-height: 40px;
  text-align: center;
  background-color: #ff0000 !important;
  color: #fff !important;
  border: 2px solid #ff0000 !important;
  border-radius: 30px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.5);
  transform: none;
  transition: background-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, border-color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
a.nav-btn-submit:hover, input[type="submit"].nav-btn-submit:hover, input[type="button"].nav-btn-submit:hover, button.nav-btn-submit:hover, .form-btn-submit a:hover, .form-btn-submit input[type="submit"]:hover, .form-btn-submit input[type="button"]:hover, .form-btn-submit button:hover {
  opacity: 1;
  background-color: #fff !important;
  color: #ff0000 !important;
  border-color: #ff0000 !important;
}
a.nav-btn-submit:disabled, input[type="submit"].nav-btn-submit:disabled, input[type="button"].nav-btn-submit:disabled, button.nav-btn-submit:disabled, .form-btn-submit a:disabled, .form-btn-submit input[type="submit"]:disabled, .form-btn-submit input[type="button"]:disabled, .form-btn-submit button:disabled {
  background-color: #a7a7a7 !important;
  border-color: #a7a7a7 !important;
}
a.nav-btn-submit:disabled:hover, input[type="submit"].nav-btn-submit:disabled:hover, input[type="button"].nav-btn-submit:disabled:hover, button.nav-btn-submit:disabled:hover, .form-btn-submit a:disabled:hover, .form-btn-submit input[type="submit"]:disabled:hover, .form-btn-submit input[type="button"]:disabled:hover, .form-btn-submit button:disabled:hover {
  background-color: #a7a7a7 !important;
  color: #fff !important;
  border-color: #a7a7a7 !important;
}
@media all and (max-width: 767px) {
  a.nav-btn-submit, input[type="submit"].nav-btn-submit, input[type="button"].nav-btn-submit, button.nav-btn-submit, .form-btn-submit a, .form-btn-submit input[type="submit"], .form-btn-submit input[type="button"], .form-btn-submit button {
    min-width: 180px;
    padding: 8px 30px 8px;
    font-size: 0.875rem;
    line-height: 30px;
    border-radius: 25px;
  }
}

.form-btn-submit {
  position: relative;
  display: inline-block;
  max-width: 100%;
}
.form-btn-submit a, .form-btn-submit input[type="submit"], .form-btn-submit input[type="button"], .form-btn-submit button {
  text-align: center;
}
.form-btn-submit .wpcf7-spinner {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0 -30px 0 0;
}

.form-btn-back {
  position: relative;
  display: inline-block;
  max-width: 100%;
}
.form-btn-back .wpcf7-spinner {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0 -30px 0 0;
}

.content-more-btn {
  margin-top: 60px;
  text-align: center;
}

@media all and (max-width: 767px) {
  .content-more-btn {
    margin-top: 40px;
    text-align: center;
  }
}
@media all and (max-width: 579px) {
  .content-more-btn {
    text-align: center;
  }
}
/*
================================================================
 セクション
================================================================
*/
.section-panel {
  background-color: #fff;
  color: #000;
}

.section-panel.section-panel--blue, .page-header-screen, .section-panel.section-panel--top-about, .section-panel.section-panel--top-case, .section-panel.section-panel--page-about-philosophy, .section-panel.section-panel--page-about-history, .section-panel.section-panel--page-service-solve, .section-panel.section-panel--page-privacy-contact {
  background-color: #fff;
  color: #fff;
  background-size: cover;
  background-repeat: no-repeat;
}
.section-panel.section-panel--blue::before, .page-header-screen::before, .section-panel.section-panel--top-about::before, .section-panel.section-panel--top-case::before, .section-panel.section-panel--page-about-philosophy::before, .section-panel.section-panel--page-about-history::before, .section-panel.section-panel--page-service-solve::before, .section-panel.section-panel--page-privacy-contact::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(30deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  mix-blend-mode: multiply;
}
.section-panel.section-panel--blue::after, .page-header-screen::after, .section-panel.section-panel--top-about::after, .section-panel.section-panel--top-case::after, .section-panel.section-panel--page-about-philosophy::after, .section-panel.section-panel--page-about-history::after, .section-panel.section-panel--page-service-solve::after, .section-panel.section-panel--page-privacy-contact::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.8;
  background-image: url(../img/common/dotted.png);
  background-position: center center;
  background-size: 4px 4px;
  background-repeat: repeat;
  mix-blend-mode: soft-light;
}

.page-service-case-link__main {
  background-color: #fff;
  color: #fff;
  background-size: cover;
  background-repeat: no-repeat;
}
.page-service-case-link__main::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(30deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  mix-blend-mode: multiply;
}
.page-service-case-link__main::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.8;
  background-image: url(../img/common/dotted.png);
  background-position: center center;
  background-size: 4px 4px;
  background-repeat: repeat;
  mix-blend-mode: soft-light;
}

.section-panel.section-panel--lp-staffing-solve {
  background-color: #fff;
  color: #fff;
  background-size: cover;
  background-repeat: no-repeat;
}
.section-panel.section-panel--lp-staffing-solve::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(30deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  mix-blend-mode: multiply;
}
.section-panel.section-panel--lp-staffing-solve::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.8;
  background-image: url(../img/common/dotted.png);
  background-position: center center;
  background-size: 4px 4px;
  background-repeat: repeat;
  mix-blend-mode: soft-light;
}

.lp-staffing-download__main {
  background-color: #fff;
  color: #fff;
  background-size: cover;
  background-repeat: no-repeat;
}
.lp-staffing-download__main::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(30deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  mix-blend-mode: multiply;
}
.lp-staffing-download__main::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.8;
  background-image: url(../img/common/dotted.png);
  background-position: center center;
  background-size: 4px 4px;
  background-repeat: repeat;
  mix-blend-mode: soft-light;
}

.hero-section-container {
  min-height: 70px;
}

.header-section-container {
  min-height: 70px;
}

.menu-section-container {
  min-height: 70px;
}

.upper-section-container {
  min-height: 70px;
}

.section-container {
  margin-top: -70px;
  padding-top: 70px;
  min-height: 70px;
}

.section-panel {
  position: relative;
  z-index: 11;
}
.section-panel .section-panel {
  background-color: transparent;
  color: inherit;
}

.section-panel-body {
  position: relative;
  z-index: 11;
}

.section-block {
  position: relative;
  z-index: 11;
}

.section-heading-title-label,
.section-heading-title-label-white {
  background-color: transparent;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 2.5rem;
  font-size: 1.75rem;
}
.section-heading-title-label .this__title,
.section-heading-title-label-white .this__title {
  text-align: center;
  display: inline-block;
  padding: 4px 1em 6px;
}

.section-heading-title-label .this__title {
  background-color: #000;
  color: #fff;
}

.section-heading-title-label-white .this__title {
  background-color: #fff;
  color: #000;
}

@media all and (max-width: 767px) {
  .hero-section-container {
    min-height: 70px;
  }

  .section-container {
    margin-top: -70px;
    padding-top: 70px;
    min-height: 70px;
  }

  .section-heading-title-label,
  .section-heading-title-label-white {
    line-height: 1.875rem;
    font-size: 1.25rem;
  }
  .section-heading-title-label .this__title,
  .section-heading-title-label-white .this__title {
    padding: 4px 1em 6px;
  }
}
/*
================================================================
 ページヘッダー
================================================================
*/
.page-header-screen {
  position: relative;
  display: block;
  box-sizing: border-box;
  width: 100%;
  min-height: 400px;
  padding: 150px 0 0;
}
.page-header-screen::before {
  opacity: 0.75;
}

.page-header-heading {
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 1.8;
}
.page-header-heading .this__en {
  display: block;
  font-size: 3.4375rem;
}
.page-header-heading .this__ja {
  display: block;
  font-size: 1.25rem;
}
.page-header-heading .this__sub {
  display: block;
  font-size: 1rem;
}

@media all and (max-width: 767px) {
  .page-header-screen {
    padding: 96px 0 40px;
    min-height: 240px;
  }

  .page-header-heading .this__en {
    font-size: 1.5rem;
  }
  .page-header-heading .this__ja {
    font-size: 0.875rem;
  }
  .page-header-heading .this__sub {
    font-size: 0.75rem;
  }
}
/*
================================================================
 イントロダクション
================================================================
*/
.section-panel.section-panel--introduction {
  padding: 100px 0 50px;
}

.section-introduction {
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  color: inherit;
  line-height: 2.5;
  font-size: 1.25rem;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--introduction {
    padding: 60px 0 30px;
  }

  .section-introduction {
    text-align: center;
    line-height: 2.5;
    font-size: 1rem;
  }
}
/*
================================================================
 トップ
================================================================
*/
.top-hero-screen {
  position: relative;
  display: block;
  width: 100%;
  height: 640px;
  min-height: 100vh;
  overflow: hidden;
}

.top-hero-canvas {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
}

.top-hero-slider {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
}

.top-hero-slider-item-frame {
  display: block;
  box-sizing: border-box;
  width: 100%;
  height: 640px;
  min-height: 100vh;
}

.top-hero-slider-item-canvas {
  display: block;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
}

.top-hero-slider-catch {
  position: absolute;
  z-index: 2;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  padding-bottom: calc(100lvh - 100svh);
}
.top-hero-slider-catch .this__layout {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
}
.top-hero-slider-catch .this__catch {
  order: 2;
  display: block;
  width: 100%;
  margin: 0;
  padding: 0 0 5vh;
}
.top-hero-slider-catch .this__catch > span {
  display: inline-block;
  padding: 0 0.8em 0.05em;
  margin: 0.2em 0;
  background-image: linear-gradient(60deg, #000030, #1e558c, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
  font-size: 2.5rem;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
.top-hero-slider-catch .this__catch > span.has--txt-punctuation {
  padding-right: 0.2em;
}
.top-hero-slider-catch ul.this__medals {
  order: 1;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.top-hero-slider-catch ul.this__medals > li {
  position: relative;
  display: block;
  width: 200px;
  height: 190px;
  margin: 0 30px 30px 0;
  padding: 0;
  list-style-type: none;
  background-image: url(../img/top/hero_medal.png);
  background-position: center center;
  background-size: contain;
  background-repeat: no-repeat;
  color: #000;
  text-shadow: 1px 1px 2px #fff;
  line-height: 1.2;
  overflow: hidden;
}
.top-hero-slider-catch ul.this__medals > li .this__medal-canvas {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 200px;
  height: 190px;
  margin: -95px 0 0 -100px;
}
.top-hero-slider-catch ul.this__medals > li .this__label {
  position: absolute;
  bottom: 63%;
  left: 0;
  display: block;
  box-sizing: border-box;
  width: 100%;
  text-align: center;
  font-family: "Zen Old Mincho", "游明朝体", "Yu Mincho", "YuMincho", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: 900;
  font-feature-settings: "palt" 1;
  font-size: 0.875rem;
}
.top-hero-slider-catch ul.this__medals > li .this__label.has--txt-2l {
  bottom: 61%;
}
.top-hero-slider-catch ul.this__medals > li .this__label:nth-last-child(2) {
  bottom: 62%;
  font-size: 0.9375rem;
}
.top-hero-slider-catch ul.this__medals > li .this__label:nth-last-child(2).has--txt-2l {
  bottom: 60%;
}
.top-hero-slider-catch ul.this__medals > li .this__number {
  position: absolute;
  top: 33%;
  left: 0;
  display: block;
  box-sizing: border-box;
  width: 100%;
  padding-left: 0.05em;
  text-align: center;
  font-family: "Zen Old Mincho", "游明朝体", "Yu Mincho", "YuMincho", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: 900;
  font-feature-settings: "palt" 1;
  font-size: 3.125rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number .this__unit {
  display: inline-block;
  position: relative;
  top: -0.2em;
  font-size: 0.875rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number.has--txt-long {
  top: 35%;
  font-size: 2.8125rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number.has--txt-long .this__unit {
  font-size: 0.8125rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number.has--txt-long:last-child {
  top: 39%;
  font-size: 2.8125rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number.has--txt-long:last-child .this__unit {
  font-size: 0.8125rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number:last-child {
  top: 33.5%;
  font-size: 3.75rem;
}
.top-hero-slider-catch ul.this__medals > li .this__number:last-child .this__unit {
  font-size: 1rem;
}
.top-hero-slider-catch ul.this__medals > li .this__notes {
  position: absolute;
  top: 64%;
  left: 0;
  display: block;
  box-sizing: border-box;
  width: 100%;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  font-feature-settings: "palt" 1;
  font-size: 0.6875rem;
}

.top-hero-heading {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #000030;
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 1;
  visibility: visible;
  transition: left 1s ease 0.5s, opacity 1s ease 0.5s, visibility 1s ease 0.5s;
}
.top-hero-heading::after {
  content: "";
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  display: block;
  width: 0;
  height: 100%;
  background-color: #fff;
  opacity: 0;
  transition: width 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.top-hero-heading .container {
  position: relative;
  height: 100%;
}
.top-hero-heading .this__heading {
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 0;
  display: block;
  width: 100%;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  color: #fff;
  font-size: 5.3125rem;
  line-height: 2;
  text-shadow: 0px 0px 5px #000;
  transform: translateY(-50%);
}
.top-hero-heading .this__heading > span {
  position: relative;
  left: 5%;
  display: block;
  width: 100%;
  opacity: 0;
}
.top-hero-heading .this__heading > span:nth-child(1) {
  transition: left 0.5s ease-in 0.2s, opacity 0.5s ease-in 0.2s;
}
.top-hero-heading .this__heading > span:nth-child(2) {
  transition: left 0.5s ease-in 0.6s, opacity 0.5s ease-in 0.6s;
}
.top-hero-heading .this__heading > span:nth-child(3) {
  transition: left 0.5s ease-in 1s, opacity 0.5s ease-in 1s;
}

.top-hero-screen.initialized .top-hero-heading .this__heading span {
  left: 0;
  opacity: 1;
}

body.top-hero-initialized .top-hero-heading {
  left: 100%;
  opacity: 0;
  visibility: hidden;
}
body.top-hero-initialized .top-hero-heading::after {
  width: 100%;
  opacity: 1;
}

@media all and (max-height: 767px) {
  .top-hero-slider-catch .this__catch {
    padding: 0 0 5vh;
  }
  .top-hero-slider-catch .this__catch > span {
    padding: 0 0.8em 0.05em;
    margin: 0.2em 0;
    font-size: 2rem;
    line-height: 1.6;
    letter-spacing: 0.1em;
  }
  .top-hero-slider-catch .this__catch > span.has--txt-punctuation {
    padding-right: 0.2em;
  }

  .top-hero-heading .this__heading {
    top: 50%;
    font-size: 2.625rem;
    line-height: 1.6;
    text-shadow: 0px 0px 5px #000;
    transform: translateY(-50%);
  }
}
@media all and (max-width: 1079px) {
  .top-hero-slider-catch .this__catch {
    padding: 0 0 5vh;
  }
  .top-hero-slider-catch .this__catch > span {
    padding: 0 0.8em 0.05em;
    margin: 0.2em 0;
    font-size: 2rem;
    line-height: 1.6;
    letter-spacing: 0.1em;
  }
  .top-hero-slider-catch .this__catch > span.has--txt-punctuation {
    padding-right: 0.2em;
  }

  .top-hero-heading .this__heading {
    top: 50%;
    font-size: 6vw;
    line-height: 2;
    text-shadow: 0px 0px 5px #000;
    transform: translateY(-50%);
  }
}
@media all and (max-width: 767px) {
  .top-hero-slider-catch .this__catch {
    padding: 0 0 5vh;
  }
  .top-hero-slider-catch .this__catch > span {
    padding: 0 0.8em 0.05em;
    margin: 0.2em 0;
    font-size: 1.75rem;
    line-height: 1.6;
    letter-spacing: 0.1em;
  }
  .top-hero-slider-catch .this__catch > span.has--txt-punctuation {
    padding-right: 0.2em;
  }

  .top-hero-heading .this__heading {
    top: 50%;
    font-size: 7vw;
    line-height: 2;
    text-shadow: 0px 0px 5px #000;
    transform: translateY(-50%);
  }
}
@media all and (max-width: 579px) {
  .top-hero-slider-catch .this__catch {
    padding: 0 0 5vh;
  }
  .top-hero-slider-catch .this__catch > span {
    padding: 0 0.8em 0.05em;
    margin: 0.2em 0;
    font-size: 5.5vw;
    line-height: 1.6;
    letter-spacing: 0.1em;
  }
  .top-hero-slider-catch .this__catch > span.has--txt-punctuation {
    padding-right: 0.2em;
  }
  .top-hero-slider-catch ul.this__medals > li {
    width: 120px;
    height: 114px;
    margin: 0 20px 20px 0;
  }
  .top-hero-slider-catch ul.this__medals > li .this__medal-canvas {
    transform: scale(0.6);
  }

  .top-hero-heading .this__heading {
    top: 50%;
    font-size: 8vw;
    line-height: 2;
    text-shadow: 0px 0px 5px #000;
    transform: translateY(-50%);
  }
}
/*
================================================================
 トップ 共通
================================================================
*/
.top-section-header {
  display: block;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  color: inherit;
  line-height: 1.4;
}
.top-section-header .this__en {
  display: block;
  font-size: 2.5rem;
}
.top-section-header .this__ja {
  display: block;
  font-size: 1rem;
}

.top-section-outline {
  display: block;
  margin: 72px 0 0;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  color: inherit;
  line-height: 2.8;
  font-size: 1rem;
}
.top-section-outline p {
  margin-bottom: 1.4em;
}

.top-section-link {
  display: block;
  margin: 60px 0 0;
  text-align: center;
}

@media all and (max-width: 767px) {
  .top-section-header .this__en {
    font-size: 2rem;
  }
  .top-section-header .this__ja {
    font-size: 0.875rem;
  }

  .top-section-outline {
    margin: 48px 0 0;
    line-height: 2.8;
    font-size: 0.875rem;
  }
  .top-section-outline p {
    margin-bottom: 1.4em;
  }

  .top-section-link {
    margin: 40px 0 0;
  }
}
/*
================================================================
 トップ サービス
================================================================
*/
.section-panel.section-panel--top-service {
  padding: 120px 0;
}

.top-service-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  margin: 100px 0 0;
  padding: 0;
}

.top-service-item {
  position: relative;
  display: block;
  background-color: #fff;
  color: #000;
  box-shadow: 0 0 15px rgba(43, 74, 138, 0.5);
  width: 44%;
  margin: 70px 0 0 12%;
  padding: 0 0 160px;
}
.top-service-item:nth-child(2n+1) {
  margin-left: 0;
}
.top-service-item:nth-child(1), .top-service-item:nth-child(2) {
  margin-top: 0;
}
.top-service-item .this__item-img {
  display: block;
  width: 100%;
}
.top-service-item .this__item-img img {
  display: block;
  width: 100%;
  height: auto;
}
.top-service-item .this__item-img img.this__img--for-PC {
  display: block;
}
.top-service-item .this__item-img img.this__img--for-SP {
  display: none;
}
.top-service-item .this__item-heading {
  display: block;
  width: 340px;
  max-width: calc(100% - 30px);
  margin: 20px auto 0;
  text-align: center;
  line-height: 1.2;
}
.top-service-item .this__item-heading .this__en {
  display: block;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.5rem;
}
.top-service-item .this__item-heading .this__ja {
  display: block;
  margin-top: 7px;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 0.875rem;
}
.top-service-item .this__item-txt {
  display: block;
  width: 340px;
  max-width: calc(100% - 30px);
  margin: 0 auto;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  line-height: 1.9;
}
.top-service-item .this__item-txt p {
  margin-top: 1.4em;
}
.top-service-item .this__item-link {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  box-sizing: border-box;
  width: 100%;
  height: auto;
  padding: 15px 10px 55px;
  text-align: center;
}

@media all and (max-width: 1079px) {
  .top-service-item {
    width: 48%;
    margin: 70px 0 0 4%;
  }
  .top-service-item .this__item-img img.this__img--for-PC {
    display: none;
  }
  .top-service-item .this__item-img img.this__img--for-SP {
    display: block;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--top-service {
    padding: 80px 0;
  }

  .top-service-list {
    margin: 60px 0 0;
  }

  .top-service-item {
    box-shadow: 0 0 15px rgba(43, 74, 138, 0.5);
    width: 100%;
    max-width: 440px;
    margin: 50px 0 0 0;
    padding: 0 0 120px;
  }
  .top-service-item:nth-child(2n+1) {
    margin-left: 0;
  }
  .top-service-item:nth-child(2) {
    margin-top: 50px;
  }
  .top-service-item .this__item-img img.this__img--for-PC {
    display: block;
  }
  .top-service-item .this__item-img img.this__img--for-SP {
    display: none;
  }
  .top-service-item .this__item-heading {
    width: 340px;
    max-width: calc(100% - 30px);
    margin: 20px auto 0;
    line-height: 1.4;
  }
  .top-service-item .this__item-heading .this__en {
    font-size: 1.25rem;
  }
  .top-service-item .this__item-heading .this__ja {
    font-size: 0.75rem;
  }
  .top-service-item .this__item-txt {
    width: 340px;
    max-width: calc(100% - 30px);
    font-size: 0.875rem;
    line-height: 1.9;
  }
  .top-service-item .this__item-txt p {
    margin-top: 1.4em;
  }
  .top-service-item .this__item-link {
    padding: 15px 10px 45px;
  }
}
@media all and (max-width: 579px) {
  .section-panel.section-panel--top-service {
    padding: 80px 0;
  }

  .top-service-list {
    margin: 60px 0 0;
  }

  .top-service-item {
    box-shadow: 0 0 15px rgba(43, 74, 138, 0.5);
    width: 100%;
    max-width: 440px;
    margin: 50px 0 0 0;
    padding: 0 0 120px;
  }
  .top-service-item:nth-child(2n+1) {
    margin-left: 0;
  }
  .top-service-item:nth-child(2) {
    margin-top: 50px;
  }
  .top-service-item .this__item-img img.this__img--for-PC {
    display: none;
  }
  .top-service-item .this__item-img img.this__img--for-SP {
    display: block;
  }
  .top-service-item .this__item-heading {
    width: 340px;
    max-width: calc(100% - 30px);
    margin: 20px auto 0;
    line-height: 1.4;
  }
  .top-service-item .this__item-heading .this__en {
    font-size: 1.25rem;
  }
  .top-service-item .this__item-heading .this__ja {
    font-size: 0.75rem;
  }
  .top-service-item .this__item-txt {
    width: 340px;
    max-width: calc(100% - 30px);
    font-size: 0.875rem;
    line-height: 1.9;
  }
  .top-service-item .this__item-txt p {
    margin-top: 1.4em;
  }
  .top-service-item .this__item-link {
    padding: 15px 10px 45px;
  }
}
/*
================================================================
 トップ 企業情報
================================================================
*/
.section-panel.section-panel--top-about {
  position: relative;
  padding: 120px 0;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--top-about {
    padding: 80px 0;
  }
}
/*
================================================================
 トップ 導入事例
================================================================
*/
.section-panel.section-panel--top-case {
  position: relative;
  padding: 120px 0;
}
.section-panel.section-panel--top-case::before {
  height: calc(100% - 240px);
}
.section-panel.section-panel--top-case::after {
  height: calc(100% - 240px);
}
.section-panel.section-panel--top-case .container {
  padding: 60px 0 120px;
  background-color: #fff;
  color: #000;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--top-case {
    padding: 80px 0;
  }
  .section-panel.section-panel--top-case::before {
    height: calc(100% - 160px);
  }
  .section-panel.section-panel--top-case::after {
    height: calc(100% - 160px);
  }
  .section-panel.section-panel--top-case .container {
    padding: 40px 0 80px;
  }
}
/*
================================================================
 企業情報 代表挨拶
================================================================
*/
.section-panel.section-panel--page-about-greeting {
  padding: 100px 0;
}

.page-about-greeting-layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  margin: 0 0 100px;
}

.page-about-greeting__heading {
  margin-bottom: 20px;
}

.page-about-greeting__img {
  width: 40%;
}
.page-about-greeting__img::before {
  content: "";
  display: block;
  box-sizing: content-box;
  width: 100%;
  height: 0;
  padding: 100% 0 0;
}

.page-about-greeting__content {
  width: 55%;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  line-height: 2.2;
  font-size: 1rem;
}
.page-about-greeting__content p {
  margin: 2em 0 0;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--page-about-greeting {
    padding: 60px 0;
  }

  .page-about-greeting-layout {
    margin: 0 0 60px;
    justify-content: center;
  }

  .page-about-greeting__heading {
    margin-bottom: 20px;
  }

  .page-about-greeting__img {
    width: 60%;
  }

  .page-about-greeting__content {
    width: 100%;
    line-height: 2.2;
    font-size: 0.875rem;
  }
  .page-about-greeting__content p {
    margin: 2em 0 0;
  }
}
@media all and (max-width: 579px) {
  .page-about-greeting__img {
    width: 80%;
  }
}
/*
================================================================
 企業情報 経営理念
================================================================
*/
.section-panel.section-panel--page-about-philosophy {
  padding: 100px 0;
}
.section-panel.section-panel--page-about-philosophy .section-heading-title-label .this__title {
  background-color: #fff;
  color: #000;
}

.page-about-philosophy-subsec__panel {
  padding: 40px 0 40px;
}

.page-about-philosophy-subsec__heading {
  position: relative;
  padding-bottom: 0.4em;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 2;
  font-size: 1.375rem;
}
.page-about-philosophy-subsec__heading::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  box-sizing: content-box;
  margin-left: -25px;
  width: 50px;
  height: 0;
  border-bottom: 1px solid #fff;
}

.page-about-philosophy-subsec__txt {
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 2;
  font-size: 1.75rem;
}
.page-about-philosophy-subsec__txt p {
  margin-top: 1em;
}
.page-about-philosophy-subsec__txt .this__msg-block .this__main {
  display: block;
  line-height: 1.5;
  font-size: 2.5rem;
}
.page-about-philosophy-subsec__txt .this__msg-block .this__sub {
  display: block;
  line-height: 2;
  font-size: 1.25rem;
}

ul.page-about-philosophy-subsec__value-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
ul.page-about-philosophy-subsec__value-list > li {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  list-style-type: none;
  box-sizing: border-box;
  margin: 5% 0 0 5%;
  padding: 20px;
  width: 30%;
  min-height: 270px;
  background-color: #fff;
  color: #000;
}
ul.page-about-philosophy-subsec__value-list > li:nth-child(3n+1) {
  margin-left: 0;
}
ul.page-about-philosophy-subsec__value-list > li .this__title {
  display: block;
  width: 100%;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 1.4;
  font-size: 1.5rem;
}
ul.page-about-philosophy-subsec__value-list > li .this__txt {
  display: block;
  width: 100%;
  max-width: 280px;
  margin-top: 1em;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  line-height: 1.8;
  font-size: 1rem;
}

@media all and (max-width: 1279px) {
  ul.page-about-philosophy-subsec__value-list > li {
    margin: 5% 0 0 5%;
    padding: 20px;
    width: 30%;
    min-height: 270px;
  }
  ul.page-about-philosophy-subsec__value-list > li:nth-child(3n+1) {
    margin-left: 0;
  }
  ul.page-about-philosophy-subsec__value-list > li .this__title {
    line-height: 1.4;
    font-size: 1.25rem;
  }
  ul.page-about-philosophy-subsec__value-list > li .this__txt {
    max-width: 280px;
    line-height: 1.8;
    font-size: 1rem;
  }
}
@media all and (max-width: 1079px) {
  ul.page-about-philosophy-subsec__value-list > li {
    margin: 6% 0 0 6%;
    padding: 20px;
    width: 47%;
    min-height: 270px;
  }
  ul.page-about-philosophy-subsec__value-list > li:nth-child(3n+1) {
    margin-left: 6%;
  }
  ul.page-about-philosophy-subsec__value-list > li:nth-child(2n+1) {
    margin-left: 0;
  }
  ul.page-about-philosophy-subsec__value-list > li .this__title {
    line-height: 1.4;
    font-size: 1.25rem;
  }
  ul.page-about-philosophy-subsec__value-list > li .this__txt {
    max-width: 280px;
    line-height: 1.8;
    font-size: 1rem;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-about-philosophy {
    padding: 60px 0;
  }

  .page-about-philosophy-subsec__panel {
    padding: 30px 0 30px;
  }

  .page-about-philosophy-subsec__heading {
    padding-bottom: 0.4em;
    line-height: 2;
    font-size: 1.25rem;
  }
  .page-about-philosophy-subsec__heading::before {
    margin-left: -25px;
    width: 50px;
  }

  .page-about-philosophy-subsec__txt {
    line-height: 2;
    font-size: 1rem;
  }
  .page-about-philosophy-subsec__txt p {
    margin-top: 1em;
  }
  .page-about-philosophy-subsec__txt .this__msg-block .this__main {
    line-height: 1.5;
    font-size: 1.5rem;
  }
  .page-about-philosophy-subsec__txt .this__msg-block .this__sub {
    line-height: 2;
    font-size: 0.875rem;
  }

  ul.page-about-philosophy-subsec__value-list > li {
    display: block;
    margin: 30px 0 0;
    padding: 30px 15px;
    width: 100%;
    min-height: auto;
  }
  ul.page-about-philosophy-subsec__value-list > li:nth-child(3n+1) {
    margin-left: 0;
  }
  ul.page-about-philosophy-subsec__value-list > li:nth-child(2n+1) {
    margin-left: 0;
  }
  ul.page-about-philosophy-subsec__value-list > li .this__title {
    line-height: 1.4;
    font-size: 1.125rem;
  }
  ul.page-about-philosophy-subsec__value-list > li .this__txt {
    max-width: none;
    line-height: 1.8;
    font-size: 0.875rem;
  }
}
/*
================================================================
 企業情報 会社概要
================================================================
*/
.section-panel.section-panel--page-about-outline {
  padding: 100px 0;
}

dl.page-about-outline-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  margin: 50px 0 0;
  width: 100%;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  background-color: #fff;
  color: #000;
  text-align: left;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  line-height: 2;
  font-size: 0.875rem;
}
dl.page-about-outline-list > dt {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  box-sizing: border-box;
  width: 240px;
  padding: 16px 50px;
  background-color: #bfc9dc;
  border-top: 1px solid #a7a7a7;
}
dl.page-about-outline-list > dt .this__name {
  display: block;
  width: max-content;
  max-width: 100%;
  min-width: 5em;
  text-align-last: justify;
}
dl.page-about-outline-list > dt:first-child {
  border-top: 0 none;
}
dl.page-about-outline-list > dt:first-child + dd {
  border-top: 0 none;
}
dl.page-about-outline-list > dd {
  display: block;
  box-sizing: border-box;
  width: calc(100% - 240px);
  padding: 16px 50px;
  border-top: 1px solid #a7a7a7;
}

.page-about-outline-map {
  margin-top: 100px;
}
.page-about-outline-map iframe {
  display: block;
  width: 100%;
  height: 450px;
}

@media all and (max-width: 1079px) {
  dl.page-about-outline-list {
    margin: 50px 0 0;
    font-size: 0.875rem;
  }
  dl.page-about-outline-list > dt {
    width: 200px;
    padding: 16px 30px;
  }
  dl.page-about-outline-list > dd {
    width: calc(100% - 200px);
    padding: 16px 30px;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-about-outline {
    padding: 60px 0;
  }

  dl.page-about-outline-list {
    margin: 30px 0 0;
    font-size: 0.875rem;
  }
  dl.page-about-outline-list > dt {
    width: 160px;
    padding: 16px 20px;
  }
  dl.page-about-outline-list > dd {
    width: calc(100% - 160px);
    padding: 16px 20px;
  }

  .page-about-outline-map {
    margin-top: 60px;
  }
  .page-about-outline-map iframe {
    height: 320px;
  }
}
@media all and (max-width: 579px) {
  dl.page-about-outline-list {
    margin: 50px 0 0;
    font-size: 0.875rem;
  }
  dl.page-about-outline-list > dt {
    flex-direction: row;
    width: 100%;
    padding: 10px 15px;
  }
  dl.page-about-outline-list > dd {
    width: 100%;
    padding: 12px 15px;
    border-top: 0 none;
  }
}
/*
================================================================
 企業情報 会社沿革
================================================================
*/
.section-panel.section-panel--page-about-history {
  padding: 100px 0;
}
.section-panel.section-panel--page-about-history .section-heading-title-label .this__title {
  background-color: #fff;
  color: #000;
}

dl.page-about-history-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  margin: 50px auto 0;
  width: 720px;
  max-width: 100%;
  color: #fff;
}
dl.page-about-history-list > dt {
  display: block;
  box-sizing: border-box;
  width: 100px;
  padding: 18px 0 22px;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 2.5rem;
  font-size: 2.375rem;
}
dl.page-about-history-list > dt .this__year {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  width: max-content;
  max-width: 100%;
  min-width: 2.2em;
  text-align: center;
}
dl.page-about-history-list > dt .this__year > span {
  display: block;
}
dl.page-about-history-list > dt + dd {
  margin-left: 0;
}
dl.page-about-history-list > dd {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  box-sizing: border-box;
  width: calc(100% - 100px);
  padding: 23px 0 27px 100px;
  margin: 0 0 0 100px;
}
dl.page-about-history-list > dd::before {
  content: "";
  position: absolute;
  top: 40px;
  left: 50px;
  display: block;
  box-sizing: content-box;
  margin-left: -1px;
  width: 0;
  height: 100%;
  border-left: 2px solid #fff;
}
dl.page-about-history-list > dd::after {
  content: "";
  position: absolute;
  top: 40px;
  left: 50px;
  display: block;
  box-sizing: border-box;
  margin-left: -4px;
  margin-top: -4px;
  width: 8px;
  height: 8px;
  background-color: #fff;
  border: 2px solid #fff;
  border-radius: 50%;
}
dl.page-about-history-list > dd:last-child::before {
  display: none;
}
dl.page-about-history-list > dd .this__month {
  display: block;
  width: 90px;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 1.875rem;
  font-size: 1.375rem;
}
dl.page-about-history-list > dd .this__txt {
  display: block;
  width: calc(100% - 90px);
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  line-height: 1.875rem;
  font-size: 1.125rem;
}

@media all and (max-width: 1079px) {
  dl.page-about-history-list {
    margin: 50px auto 0;
    width: 640px;
  }
  dl.page-about-history-list > dt {
    width: 80px;
    padding: 8px 0 12px;
    line-height: 2.5rem;
    font-size: 1.75rem;
  }
  dl.page-about-history-list > dt + dd {
    margin-left: 0;
  }
  dl.page-about-history-list > dd {
    width: calc(100% - 80px);
    padding: 13px 0 17px 50px;
    margin: 0 0 0 80px;
  }
  dl.page-about-history-list > dd::before {
    top: 30px;
    left: 20px;
    margin-left: -1px;
    border-left-width: 2px;
  }
  dl.page-about-history-list > dd::after {
    top: 30px;
    left: 20px;
    margin-left: -4px;
    margin-top: -4px;
    width: 8px;
    height: 8px;
    border-width: 2px;
  }
  dl.page-about-history-list > dd .this__month {
    width: 60px;
    line-height: 1.875rem;
    font-size: 1.125rem;
  }
  dl.page-about-history-list > dd .this__txt {
    width: calc(100% - 60px);
    line-height: 1.875rem;
    font-size: 1rem;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-about-history {
    padding: 60px 0;
  }
}
@media all and (max-width: 579px) {
  dl.page-about-history-list {
    margin: 30px auto 0;
    width: 480px;
  }
  dl.page-about-history-list > dt {
    width: 50px;
    padding: 8px 0 12px;
    line-height: 1.875rem;
    font-size: 1.25rem;
  }
  dl.page-about-history-list > dt + dd {
    margin-left: 0;
  }
  dl.page-about-history-list > dd {
    width: calc(100% - 50px);
    padding: 13px 0 17px 25px;
    margin: 0 0 0 50px;
  }
  dl.page-about-history-list > dd::before {
    top: 25px;
    left: 10px;
    margin-left: -1px;
    border-left-width: 2px;
  }
  dl.page-about-history-list > dd::after {
    top: 25px;
    left: 10px;
    margin-left: -4px;
    margin-top: -4px;
    width: 8px;
    height: 8px;
    border-width: 2px;
  }
  dl.page-about-history-list > dd .this__month {
    width: 50px;
    line-height: 1.25rem;
    font-size: 1rem;
  }
  dl.page-about-history-list > dd .this__txt {
    width: calc(100% - 50px);
    line-height: 1.25rem;
    font-size: 0.875rem;
  }
}
/*
================================================================
 サービス エフザタッチの特徴
================================================================
*/
.section-panel.section-panel--page-service-feature {
  padding: 100px 0;
}

ul.page-service-feature-list {
  list-style-type: none;
  margin: 80px 0 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
ul.page-service-feature-list > li {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
ul.page-service-feature-list > li .half-container {
  max-width: 600px;
}
ul.page-service-feature-list > li .this__item-layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
}
ul.page-service-feature-list > li .this__item-layout .this__content {
  display: block;
  width: 50%;
}
ul.page-service-feature-list > li .this__item-layout .this__content .this__title-box {
  border-bottom: 2px solid #2b4a8a;
}
ul.page-service-feature-list > li .this__item-layout .this__content .this__title {
  padding-top: 1.4em;
  padding-bottom: 1em;
  line-height: 1.6;
  font-size: 1.625rem;
}
ul.page-service-feature-list > li .this__item-layout .this__content .this__txt {
  padding-bottom: 1em;
  line-height: 2.2;
  font-size: 1rem;
}
ul.page-service-feature-list > li .this__item-layout .this__content .this__txt p {
  margin-top: 2em;
}
ul.page-service-feature-list > li .this__item-layout .this__img {
  display: block;
  box-sizing: border-box;
  clear: both;
  box-sizing: border-box;
  width: calc(50% - 15px);
  max-width: 600px;
}
@media all and (min-width: 580px) {
  ul.page-service-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 25px);
  }
}
@media all and (min-width: 768px) {
  ul.page-service-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 50px);
  }
}
@media all and (min-width: 1080px) {
  ul.page-service-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 60px);
  }
}
@media all and (min-width: 1280px) {
  ul.page-service-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 70px);
  }
}
@media all and (min-width: 1440px) {
  ul.page-service-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 80px);
  }
}
ul.page-service-feature-list > li .this__item-layout .this__img::before {
  content: "";
  display: block;
  box-sizing: content-box;
  width: 100%;
  height: 0;
  padding: 58.3333% 0 0;
}
ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout {
  flex-direction: row;
}
ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content {
  text-align: right;
}
ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .half-container {
  margin-left: auto;
}
ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
  padding-right: 60px;
}
ul.page-service-feature-list > li:nth-child(2n) .this__item-layout {
  flex-direction: row-reverse;
}
ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content {
  text-align: left;
}
ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .half-container {
  margin-right: auto;
}
ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
  padding-left: 60px;
}

@media all and (max-width: 1279px) {
  ul.page-service-feature-list {
    margin: 60px 0 0;
  }
  ul.page-service-feature-list > li .this__item-layout .this__content .this__title {
    font-size: 1.5rem;
  }
  ul.page-service-feature-list > li .this__item-layout .this__content .this__txt {
    font-size: 1rem;
  }
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
    padding-right: 40px;
  }
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
    padding-left: 40px;
  }
}
@media all and (max-width: 1079px) {
  ul.page-service-feature-list {
    margin: 40px 0 0;
  }
  ul.page-service-feature-list > li .this__item-layout .this__content .this__title {
    font-size: 1.25rem;
  }
  ul.page-service-feature-list > li .this__item-layout .this__content .this__txt {
    font-size: 0.875rem;
  }
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
    padding-right: 20px;
  }
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
    padding-left: 20px;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-service-feature {
    padding: 60px 0;
  }
}
@media all and (min-width: 768px) {
  ul.page-service-feature-list > li .container {
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  ul.page-service-feature-list {
    margin: 0 0 0;
  }
  ul.page-service-feature-list > li {
    margin: 40px 0 0;
  }
  ul.page-service-feature-list > li .half-container {
    width: 100%;
    max-width: 100%;
  }
  ul.page-service-feature-list > li .this__item-layout {
    display: block;
  }
  ul.page-service-feature-list > li .this__item-layout .this__content {
    width: 100%;
  }
  ul.page-service-feature-list > li .this__item-layout .this__img {
    width: 100%;
    max-width: 100%;
    min-height: 240px;
  }
  ul.page-service-feature-list > li .this__item-layout .this__img::before {
    padding: 50% 0 0;
  }
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content {
    text-align: left;
  }
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
  ul.page-service-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
    padding-right: 0;
  }
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content {
    text-align: left;
  }
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
  ul.page-service-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
    padding-left: 0;
  }
}
/*
================================================================
 サービス こんなお悩みを解決します
================================================================
*/
.section-panel.section-panel--page-service-solve {
  padding: 100px 0;
}
.section-panel.section-panel--page-service-solve .section-heading-title-label .this__title {
  background-color: #fff;
  color: #000;
}

ul.page-service-solve-list {
  display: block;
  list-style-type: none;
  margin: 0 0 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
ul.page-service-solve-list > li {
  display: block;
  list-style-type: none;
  margin: 40px 0 0;
  padding: 0;
}
ul.page-service-solve-list > li .this__item-layout {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  background-color: #fff;
  color: #000;
}
ul.page-service-solve-list > li .this__item-layout .this__img {
  display: block;
  width: 360px;
  height: auto;
}
ul.page-service-solve-list > li .this__item-layout .this__img img {
  display: block;
  width: 100%;
  height: auto;
}
ul.page-service-solve-list > li .this__item-layout .this__title {
  display: block;
  box-sizing: border-box;
  padding: 1em 60px;
  width: calc(100% - 360px);
  font-size: 1.5rem;
  line-height: 2;
}

@media all and (max-width: 1079px) {
  ul.page-service-solve-list {
    margin: 0 0 0;
    padding: 0;
  }
  ul.page-service-solve-list > li {
    margin: 40px 0 0;
  }
  ul.page-service-solve-list > li .this__item-layout .this__img {
    width: 240px;
  }
  ul.page-service-solve-list > li .this__item-layout .this__title {
    padding: 1em 30px;
    width: calc(100% - 240px);
    font-size: 1.125rem;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-service-solve {
    padding: 60px 0;
  }

  ul.page-service-solve-list {
    margin: 0 0 0;
    padding: 0;
  }
  ul.page-service-solve-list > li {
    margin: 40px 0 0;
  }
  ul.page-service-solve-list > li .this__item-layout .this__img {
    width: 180px;
  }
  ul.page-service-solve-list > li .this__item-layout .this__title {
    padding: 1em 20px;
    width: calc(100% - 180px);
    font-size: 1rem;
  }
}
@media all and (max-width: 579px) {
  ul.page-service-solve-list {
    margin: 0 0 0;
    padding: 0;
  }
  ul.page-service-solve-list > li {
    margin: 40px 0 0;
  }
  ul.page-service-solve-list > li .this__item-layout {
    display: block;
  }
  ul.page-service-solve-list > li .this__item-layout .this__img {
    width: 100%;
    overflow: hidden;
  }
  ul.page-service-solve-list > li .this__item-layout .this__img img {
    width: 80%;
    margin: 0 auto;
    transform: scale(1.3);
  }
  ul.page-service-solve-list > li .this__item-layout .this__title {
    padding: 1em 15px 1.1em;
    width: 100%;
    font-size: 1rem;
  }
}
/*
================================================================
 サービス 導入事例
================================================================
*/
.section-panel.section-panel--page-service-case-link {
  padding: 200px 0 100px;
}

.page-service-case-link__layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
}

.page-service-case-link__main {
  position: relative;
  flex-shrink: 1;
  order: 2;
  width: 40%;
  min-width: 320px;
}

.page-service-case-link__content {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  padding: 60px 20px 0;
  min-height: 300px;
  text-align: center;
}

.page-service-case-link__heading {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 1.8;
  font-size: 2rem;
}

.page-service-case-link__btn {
  margin: 40px 0 0;
}

.page-service-case-link__img {
  display: block;
  flex-shrink: 0;
  order: 3;
  box-sizing: content-box;
  width: 30%;
  max-width: calc(50% - 160px);
}
.page-service-case-link__main + .page-service-case-link__img {
  order: 1;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--page-service-case-link {
    padding: 60px 0 60px;
  }

  .page-service-case-link__main {
    order: 1;
    width: 100%;
    min-width: auto;
  }

  .page-service-case-link__content {
    padding: 60px 15px 60px;
    min-height: auto;
  }

  .page-service-case-link__heading {
    line-height: 1.8;
    font-size: 1.375rem;
  }

  .page-service-case-link__btn {
    margin: 20px 0 0;
  }

  .page-service-case-link__img {
    order: 3;
    width: 50%;
    max-width: none;
    padding: 30% 0 0;
  }
  .page-service-case-link__main + .page-service-case-link__img {
    order: 2;
  }
}
@media all and (max-width: 579px) {
  .page-service-case-link__img {
    padding: 50% 0 0;
  }
}
/*
================================================================
 導入事例 メニュー
================================================================
*/
.section-panel.section-panel--page-case-selector {
  padding: 100px 0 0;
}
.section-container-block + .menu-section-container .section-panel.section-panel--page-case-selector {
  padding: 0 0 100px;
}

ul.page-case-selector-menu {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
}
ul.page-case-selector-menu > li {
  display: block;
  list-style-type: none;
  margin: 0;
  padding: 0;
  width: 23.75%;
}
ul.page-case-selector-menu > li > a, ul.page-case-selector-menu > li > .as-link {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  margin: 0;
  padding: 20px 10px 50px;
  cursor: default;
  text-decoration: none;
  opacity: 1;
  text-align: center;
  background-image: linear-gradient(90deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
  border-radius: 10px;
  font-size: 1.25rem;
  line-height: 1.5;
  overflow: hidden;
  transition: color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
ul.page-case-selector-menu > li > a::before, ul.page-case-selector-menu > li > .as-link::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(90deg, #6893c6, #b3c9e2 40%, #b3c9e2 60%, #6893c6);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
ul.page-case-selector-menu > li > a::after, ul.page-case-selector-menu > li > .as-link::after {
  content: "";
  position: absolute;
  z-index: 2;
  bottom: 20px;
  left: 50%;
  display: block;
  margin-left: -10px;
  width: 20px;
  height: 20px;
  background-image: url(../img/common/tab_plus.svg);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
ul.page-case-selector-menu > li > a .this__title, ul.page-case-selector-menu > li > .as-link .this__title {
  position: relative;
  z-index: 11;
  display: block;
  width: 100%;
  text-align: center;
}
ul.page-case-selector-menu > li > a {
  cursor: pointer;
}
ul.page-case-selector-menu > li > a:hover {
  opacity: 0.7;
}
ul.page-case-selector-menu > li.current-menu-item > a, ul.page-case-selector-menu > li.current-menu-item > .as-link {
  color: #2b4a8a;
}
ul.page-case-selector-menu > li.current-menu-item > a::before, ul.page-case-selector-menu > li.current-menu-item > .as-link::before {
  opacity: 1;
}
ul.page-case-selector-menu > li.current-menu-item > a::after, ul.page-case-selector-menu > li.current-menu-item > .as-link::after {
  background-image: url(../img/common/tab_minus.svg);
}
ul.page-case-selector-menu > li.disabled-menu-item > a, ul.page-case-selector-menu > li.disabled-menu-item > .as-link {
  background-color: #a7a7a7;
  background-image: none;
}
ul.page-case-selector-menu > li.disabled-menu-item > a::after, ul.page-case-selector-menu > li.disabled-menu-item > .as-link::after {
  display: none;
}

@media all and (max-width: 1279px) {
  ul.page-case-selector-menu > li {
    width: 23.75%;
  }
  ul.page-case-selector-menu > li > a, ul.page-case-selector-menu > li > .as-link {
    padding: 15px 10px 40px;
    font-size: 1rem;
    line-height: 1.5;
  }
  ul.page-case-selector-menu > li > a::after, ul.page-case-selector-menu > li > .as-link::after {
    bottom: 16px;
    left: 50%;
    margin-left: -8px;
    width: 16px;
    height: 16px;
  }
}
@media all and (max-width: 1079px) {
  ul.page-case-selector-menu > li {
    width: 23.75%;
  }
  ul.page-case-selector-menu > li > a, ul.page-case-selector-menu > li > .as-link {
    padding: 10px 10px 40px;
    font-size: 1rem;
    line-height: 1.4;
  }
  ul.page-case-selector-menu > li > a .this__title, ul.page-case-selector-menu > li > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 50px;
  }
  ul.page-case-selector-menu > li > a .this__title > span, ul.page-case-selector-menu > li > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  ul.page-case-selector-menu > li > a::after, ul.page-case-selector-menu > li > .as-link::after {
    bottom: 16px;
    left: 50%;
    margin-left: -8px;
    width: 16px;
    height: 16px;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-case-selector {
    padding: 60px 0 0;
  }
  .section-container-block + .menu-section-container .section-panel.section-panel--page-case-selector {
    padding: 0 0 60px;
  }

  ul.page-case-selector-menu > li {
    width: 23.75%;
  }
  ul.page-case-selector-menu > li > a, ul.page-case-selector-menu > li > .as-link {
    padding: 5px 10px 35px;
    font-size: 0.875rem;
    line-height: 1.4;
  }
  ul.page-case-selector-menu > li > a .this__title, ul.page-case-selector-menu > li > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 42px;
  }
  ul.page-case-selector-menu > li > a .this__title > span, ul.page-case-selector-menu > li > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  ul.page-case-selector-menu > li > a::after, ul.page-case-selector-menu > li > .as-link::after {
    bottom: 14px;
    left: 50%;
    margin-left: -7px;
    width: 14px;
    height: 14px;
  }
}
@media all and (max-width: 579px) {
  ul.page-case-selector-menu > li {
    width: 48.5%;
    margin-top: 3%;
  }
  ul.page-case-selector-menu > li:first-child, ul.page-case-selector-menu > li:nth-child(2) {
    margin-top: 0;
  }
  ul.page-case-selector-menu > li > a, ul.page-case-selector-menu > li > .as-link {
    padding: 5px 10px 35px;
    font-size: 0.75rem;
    line-height: 1.4;
  }
  ul.page-case-selector-menu > li > a .this__title, ul.page-case-selector-menu > li > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 42px;
  }
  ul.page-case-selector-menu > li > a .this__title > span, ul.page-case-selector-menu > li > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  ul.page-case-selector-menu > li > a::after, ul.page-case-selector-menu > li > .as-link::after {
    bottom: 14px;
    left: 50%;
    margin-left: -7px;
    width: 14px;
    height: 14px;
  }
}
/*
================================================================
 導入事例 アイテム
================================================================
*/
.section-panel.section-panel--page-case-item {
  padding: 100px 0;
}
.section-container:nth-child(2n) > .section-panel.section-panel--page-case-item {
  background-color: #e1e9f4;
}
.section-panel.section-panel--page-case-item .section-block {
  padding: 0 0 50px;
}
.section-panel.section-panel--page-case-item .header-section-container .section-block {
  padding: 0 0 30px;
}

.page-case-item__heading {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  border: 2px solid #000;
  background-color: #fff;
  background-image: linear-gradient(0deg, #000000, #000000);
  background-size: 240px 100%;
  background-position: left top;
  background-repeat: no-repeat;
  border-radius: 30px;
  overflow: hidden;
}
.page-case-item__heading .this__label {
  display: block;
  box-sizing: border-box;
  width: 240px;
  padding: 6px 1em 10px 1.2em;
  color: #fff;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  text-align: center;
  font-size: 1.75rem;
  line-height: 2.5rem;
  letter-spacing: 0.2em;
}
.page-case-item__heading .this__title {
  display: block;
  box-sizing: border-box;
  width: calc(100% - 240px);
  padding: 6px 0 10px 30px;
  color: #000;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  text-align: left;
  font-size: 1.75rem;
  line-height: 2.5rem;
}

.page-case-item__introduction {
  display: block;
  box-sizing: border-box;
  width: 100%;
  padding: 0 0 1em 1em;
  margin: 1em 0 1em;
  color: #2b4a8a;
  text-align: left;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.625rem;
  line-height: 2.5rem;
}
.page-case-item__introduction p {
  margin-top: 1em;
}

.container--page-case-item > .section-container > .section-block {
  box-sizing: border-box;
  width: 100%;
  padding-left: 25px;
}

.page-case-item__sub-heading {
  position: relative;
  z-index: 1;
  display: block;
  box-sizing: border-box;
  width: 100%;
  padding: 0;
  margin: 0;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.25rem;
  line-height: 1.25;
}
.page-case-item__sub-heading::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 200px;
  display: block;
  box-sizing: content-box;
  width: calc(100% - 200px);
  height: 0;
  border-bottom: 2px solid #000;
}
.page-case-item__sub-heading .this__title {
  display: block;
  box-sizing: border-box;
  width: 200px;
  padding: 8px 8px 0;
  border-top: 2px solid #000;
  border-left: 2px solid #000;
  border-right: 2px solid #000;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
.page-case-item__sub-heading .this__title.short-txt {
  padding-left: 28px;
  letter-spacing: 20px;
}

ul.page-case-item__problem-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  overflow: hidden;
}
ul.page-case-item__problem-list > li {
  position: relative;
  display: block;
  width: 47.5%;
  list-style-type: none;
  margin: 30px 0 0;
  padding: 0;
}
ul.page-case-item__problem-list > li:nth-child(1):nth-last-child(1) {
  width: 100%;
}
ul.page-case-item__problem-list > li:nth-child(1):nth-last-child(1)::before {
  display: none;
}
ul.page-case-item__problem-list > li:nth-child(3n+1):nth-last-child(3n), ul.page-case-item__problem-list > li:nth-child(3n+2):nth-last-child(3n+2), ul.page-case-item__problem-list > li:nth-child(3n):nth-last-child(3n+1) {
  width: 30%;
}
ul.page-case-item__problem-list > li:nth-child(3n+1):nth-last-child(3n)::before, ul.page-case-item__problem-list > li:nth-child(3n+2):nth-last-child(3n+2)::before, ul.page-case-item__problem-list > li:nth-child(3n):nth-last-child(3n+1)::before {
  left: -8.3333%;
}
ul.page-case-item__problem-list > li::before {
  content: '';
  position: absolute;
  left: -5.1546%;
  top: 0;
  display: block;
  box-sizing: content-box;
  width: 0;
  height: 100%;
  margin-left: -1px;
  border-left: 2px dotted #bfc9dc;
}
ul.page-case-item__problem-list > li .this__title {
  display: block;
  box-sizing: border-box;
  margin: 0;
  padding: 8px 10px 9px;
  width: 100%;
  background-color: #e6e6e6;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.375rem;
  line-height: 1.5;
}
.section-container:nth-child(2n) > .section-panel.section-panel--page-case-item ul.page-case-item__problem-list > li .this__title {
  background-color: #fff;
}
ul.page-case-item__problem-list > li .this__txt {
  display: block;
  box-sizing: border-box;
  margin: 1em 0 0;
  padding: 0;
  width: 100%;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1.125rem;
  line-height: 2;
}

.page-case-item__contracted {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin: 30px 0 0;
  padding: 0 1em;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1.375rem;
  line-height: 2.5rem;
}

.page-case-item__result {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin: 30px 0 0;
  padding: 1em 1em;
  background-color: rgba(43, 74, 138, 0.3);
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1.375rem;
  line-height: 2.5rem;
}

@media all and (max-width: 1279px) {
  .page-case-item__heading {
    background-size: 200px 100%;
    border-radius: 25px;
  }
  .page-case-item__heading .this__label {
    width: 200px;
    padding: 6px 1em 10px 1.2em;
    border-radius: 20px;
    font-size: 1.375rem;
    line-height: 1.875rem;
    letter-spacing: 0.2em;
  }
  .page-case-item__heading .this__title {
    width: calc(100% - 200px);
    padding: 6px 0 10px 30px;
    font-size: 1.375rem;
    line-height: 1.875rem;
  }

  .page-case-item__introduction {
    font-size: 1.125rem;
    line-height: 1.875rem;
  }

  .page-case-item__sub-heading {
    font-size: 1.125rem;
    line-height: 1.25;
  }
  .page-case-item__sub-heading::before {
    left: 180px;
    width: calc(100% - 180px);
  }
  .page-case-item__sub-heading .this__title {
    width: 180px;
    padding: 8px 8px 0;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
  }
  .page-case-item__sub-heading .this__title.short-txt {
    padding-left: 26px;
    letter-spacing: 18px;
  }

  ul.page-case-item__problem-list > li {
    width: 47.5%;
    margin: 30px 0 0;
  }
  ul.page-case-item__problem-list > li:nth-child(3n+1):nth-last-child(3n), ul.page-case-item__problem-list > li:nth-child(3n+2):nth-last-child(3n+2), ul.page-case-item__problem-list > li:nth-child(3n):nth-last-child(3n+1) {
    width: 30%;
  }
  ul.page-case-item__problem-list > li:nth-child(3n+1):nth-last-child(3n)::before, ul.page-case-item__problem-list > li:nth-child(3n+2):nth-last-child(3n+2)::before, ul.page-case-item__problem-list > li:nth-child(3n):nth-last-child(3n+1)::before {
    left: -8.3333%;
  }
  ul.page-case-item__problem-list > li::before {
    left: -5.1546%;
  }
  ul.page-case-item__problem-list > li .this__title {
    padding: 8px 10px 9px;
    font-size: 1.125rem;
    line-height: 1.5;
  }
  ul.page-case-item__problem-list > li .this__txt {
    font-size: 0.875rem;
    line-height: 2;
  }

  .page-case-item__contracted {
    margin: 30px 0 0;
    padding: 0 1em;
    font-size: 1rem;
    line-height: 2;
  }

  .page-case-item__result {
    margin: 30px 0 0;
    padding: 1em 1em;
    font-size: 1rem;
    line-height: 2;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-case-item {
    padding: 60px 0;
  }
  .section-panel.section-panel--page-case-item .section-block {
    padding: 0 0 50px;
  }
  .section-panel.section-panel--page-case-item .header-section-container .section-block {
    padding: 0 0 30px;
  }

  .page-case-item__heading {
    border: 0 none;
    background-image: none;
    background-color: transparent;
    border-radius: 0;
  }
  .page-case-item__heading .this__label {
    width: 100%;
    padding: 3px 1em 7px 1.2em;
    background-color: #000;
    border-radius: 20px;
    font-size: 1.375rem;
    line-height: 1.875rem;
    letter-spacing: 0.2em;
  }
  .page-case-item__heading .this__title {
    width: 100%;
    padding: 12px 0 14px;
    font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 700;
    font-feature-settings: "palt" 1;
    font-size: 1.25rem;
    line-height: 1.875rem;
    text-align: center;
    border-bottom: 2px dotted #bfc9dc;
  }

  .page-case-item__introduction {
    padding-left: 0;
    text-align: center;
    font-size: 0.875rem;
    line-height: 1.875rem;
  }

  .container--page-case-item > .section-container > .section-block {
    padding-left: 0;
  }

  .page-case-item__sub-heading {
    font-size: 0.875rem;
    line-height: 1.25;
  }
  .page-case-item__sub-heading::before {
    left: 160px;
    width: calc(100% - 160px);
  }
  .page-case-item__sub-heading .this__title {
    width: 160px;
    padding: 8px 6px 0;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
  }
  .page-case-item__sub-heading .this__title.short-txt {
    padding-left: 22px;
    letter-spacing: 16px;
  }

  ul.page-case-item__problem-list > li {
    width: 100%;
    margin: 30px 0 0;
  }
  ul.page-case-item__problem-list > li:nth-child(3n+1):nth-last-child(3n), ul.page-case-item__problem-list > li:nth-child(3n+2):nth-last-child(3n+2), ul.page-case-item__problem-list > li:nth-child(3n):nth-last-child(3n+1) {
    width: 100%;
  }
  ul.page-case-item__problem-list > li:nth-child(3n+1):nth-last-child(3n)::before, ul.page-case-item__problem-list > li:nth-child(3n+2):nth-last-child(3n+2)::before, ul.page-case-item__problem-list > li:nth-child(3n):nth-last-child(3n+1)::before {
    display: none;
  }
  ul.page-case-item__problem-list > li::before {
    display: none;
  }
  ul.page-case-item__problem-list > li .this__title {
    padding: 8px 10px 9px;
    font-size: 1rem;
    line-height: 1.5;
  }
  ul.page-case-item__problem-list > li .this__txt {
    font-size: 0.875rem;
    line-height: 2;
  }

  .page-case-item__contracted {
    margin: 30px 0 0;
    padding: 0 0;
    font-size: 0.875rem;
    line-height: 2;
  }

  .page-case-item__result {
    margin: 30px 0 0;
    padding: 1em 1em;
    font-size: 0.875rem;
    line-height: 2;
  }
}
/*
================================================================
 導入の流れ
================================================================
*/
.section-panel.section-panel--page-flow-step {
  padding: 100px 0 50px;
}

ul.page-flow-step__list {
  display: block;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
ul.page-flow-step__list > li {
  display: block;
  list-style-type: none;
  margin: 0;
  padding: 40px 0;
  width: 100%;
  border-bottom: 2px dotted #bfc9dc;
}
ul.page-flow-step__list > li:last-child {
  border-bottom: 0 none;
}
ul.page-flow-step__list > li .this__layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
ul.page-flow-step__list > li .this__layout .this__step {
  display: block;
  box-sizing: border-box;
  padding-top: 20px;
  width: 120px;
  height: 120px;
  background-color: #2b4a8a;
  color: #fff;
  border-radius: 50%;
  text-align: center;
  font-size: 1.125rem;
  line-height: 1;
}
ul.page-flow-step__list > li .this__layout .this__step span {
  display: block;
}
ul.page-flow-step__list > li .this__layout .this__step span.this__number {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 3.4375rem;
}
ul.page-flow-step__list > li .this__layout .this__title {
  display: block;
  width: 170px;
  text-align: left;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.375rem;
  line-height: 1.6;
}
ul.page-flow-step__list > li .this__layout .this__txt {
  display: block;
  width: calc(100% - 340px);
  text-align: left;
  font-size: 1rem;
  line-height: 2;
}

@media all and (max-width: 1079px) {
  ul.page-flow-step__list > li .this__layout .this__step {
    padding-top: 20px;
    width: 120px;
    height: 120px;
    font-size: 1.125rem;
  }
  ul.page-flow-step__list > li .this__layout .this__step span.this__number {
    font-size: 3.4375rem;
  }
  ul.page-flow-step__list > li .this__layout .this__title {
    width: 150px;
    font-size: 1.25rem;
    line-height: 1.6;
  }
  ul.page-flow-step__list > li .this__layout .this__txt {
    width: calc(100% - 320px);
    font-size: 0.875rem;
    line-height: 2;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-flow-step {
    padding: 60px 0 30px;
  }

  ul.page-flow-step__list > li .this__layout .this__step {
    padding-top: 20px;
    width: 120px;
    height: 120px;
    font-size: 1.125rem;
  }
  ul.page-flow-step__list > li .this__layout .this__step span.this__number {
    font-size: 3.4375rem;
  }
  ul.page-flow-step__list > li .this__layout .this__title {
    width: calc(100% - 150px);
    font-size: 1.25rem;
    line-height: 1.6;
  }
  ul.page-flow-step__list > li .this__layout .this__txt {
    margin-top: 2em;
    width: 100%;
    font-size: 0.875rem;
    line-height: 2;
  }
}
@media all and (max-width: 579px) {
  ul.page-flow-step__list > li .this__layout .this__step {
    padding-top: 14px;
    width: 80px;
    height: 80px;
    font-size: 0.75rem;
  }
  ul.page-flow-step__list > li .this__layout .this__step span.this__number {
    font-size: 2rem;
  }
  ul.page-flow-step__list > li .this__layout .this__title {
    width: calc(100% - 100px);
    font-size: 1.125rem;
    line-height: 1.6;
  }
  ul.page-flow-step__list > li .this__layout .this__txt {
    margin-top: 2em;
    width: 100%;
    font-size: 0.875rem;
    line-height: 2;
  }
}
/*
================================================================
 採用情報 外部リンク
================================================================
*/
.section-panel.section-panel--page-recruit-jobs {
  padding: 0 0 50px;
}

ul.page-recruit-jobs-link {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
}
ul.page-recruit-jobs-link > li {
  display: block;
  list-style-type: none;
  margin: 0;
  padding: 0;
  width: 30%;
}
ul.page-recruit-jobs-link > li > a, ul.page-recruit-jobs-link > li > .as-link {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  margin: 0;
  padding: 20px 10px 50px;
  cursor: default;
  text-decoration: none;
  opacity: 1;
  text-align: center;
  background-image: linear-gradient(90deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
  border-radius: 10px;
  font-size: 1.25rem;
  line-height: 1.5;
  overflow: hidden;
  transition: color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
ul.page-recruit-jobs-link > li > a::before, ul.page-recruit-jobs-link > li > .as-link::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(90deg, #6893c6, #b3c9e2 40%, #b3c9e2 60%, #6893c6);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
ul.page-recruit-jobs-link > li > a::after, ul.page-recruit-jobs-link > li > .as-link::after {
  content: "";
  position: absolute;
  z-index: 2;
  bottom: 20px;
  left: 50%;
  display: block;
  margin-left: -10px;
  width: 20px;
  height: 20px;
  background-image: url(../img/common/tab_link.svg);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
ul.page-recruit-jobs-link > li > a .this__title, ul.page-recruit-jobs-link > li > .as-link .this__title {
  position: relative;
  z-index: 11;
  display: block;
  width: 100%;
  text-align: center;
}
ul.page-recruit-jobs-link > li > a {
  cursor: pointer;
}
ul.page-recruit-jobs-link > li > a:hover {
  opacity: 0.7;
}
ul.page-recruit-jobs-link > li.current-menu-item > a, ul.page-recruit-jobs-link > li.current-menu-item > .as-link {
  color: #2b4a8a;
}
ul.page-recruit-jobs-link > li.current-menu-item > a::before, ul.page-recruit-jobs-link > li.current-menu-item > .as-link::before {
  opacity: 1;
}
ul.page-recruit-jobs-link > li.current-menu-item > a::after, ul.page-recruit-jobs-link > li.current-menu-item > .as-link::after {
  background-image: url(../img/common/tab_link.svg);
}
ul.page-recruit-jobs-link > li.disabled-menu-item > a, ul.page-recruit-jobs-link > li.disabled-menu-item > .as-link {
  background-color: #a7a7a7;
  background-image: none;
}
ul.page-recruit-jobs-link > li.disabled-menu-item > a::after, ul.page-recruit-jobs-link > li.disabled-menu-item > .as-link::after {
  display: none;
}

@media all and (max-width: 1079px) {
  ul.page-recruit-jobs-link > li {
    width: 30%;
  }
  ul.page-recruit-jobs-link > li > a, ul.page-recruit-jobs-link > li > .as-link {
    padding: 10px 10px 45px;
    font-size: 1.125rem;
    line-height: 1.4;
  }
  ul.page-recruit-jobs-link > li > a .this__title, ul.page-recruit-jobs-link > li > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 60px;
  }
  ul.page-recruit-jobs-link > li > a .this__title > span, ul.page-recruit-jobs-link > li > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  ul.page-recruit-jobs-link > li > a::after, ul.page-recruit-jobs-link > li > .as-link::after {
    bottom: 18px;
    left: 50%;
    margin-left: -9px;
    width: 18px;
    height: 18px;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-recruit-jobs {
    padding: 0 0 30px;
  }

  ul.page-recruit-jobs-link > li {
    width: 30%;
  }
  ul.page-recruit-jobs-link > li > a, ul.page-recruit-jobs-link > li > .as-link {
    padding: 5px 10px 35px;
    font-size: 0.875rem;
    line-height: 1.4;
  }
  ul.page-recruit-jobs-link > li > a .this__title, ul.page-recruit-jobs-link > li > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 44px;
  }
  ul.page-recruit-jobs-link > li > a .this__title > span, ul.page-recruit-jobs-link > li > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  ul.page-recruit-jobs-link > li > a::after, ul.page-recruit-jobs-link > li > .as-link::after {
    bottom: 14px;
    left: 50%;
    margin-left: -7px;
    width: 14px;
    height: 14px;
  }
}
@media all and (max-width: 579px) {
  ul.page-recruit-jobs-link > li {
    width: 100%;
    margin-top: 3%;
  }
  ul.page-recruit-jobs-link > li:first-child {
    margin-top: 0;
  }
  ul.page-recruit-jobs-link > li > a, ul.page-recruit-jobs-link > li > .as-link {
    padding: 5px 10px 35px;
    font-size: 1rem;
    line-height: 1.4;
  }
  ul.page-recruit-jobs-link > li > a .this__title, ul.page-recruit-jobs-link > li > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 50px;
  }
  ul.page-recruit-jobs-link > li > a .this__title > span, ul.page-recruit-jobs-link > li > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  ul.page-recruit-jobs-link > li > a::after, ul.page-recruit-jobs-link > li > .as-link::after {
    bottom: 16px;
    left: 50%;
    margin-left: -8px;
    width: 16x;
    height: 16px;
  }
}
/*
================================================================
 お問い合わせ
================================================================
*/
.section-panel.section-panel--page-contact-form {
  padding: 100px 0 50px;
}

.page-contact-mailform-info {
  display: block;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  color: #000;
  font-size: 1rem;
  line-height: 2.2;
  margin-bottom: 30px;
}

.page-contact-mailform-privacyinfo {
  display: block;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  color: #000;
  font-size: 1rem;
  line-height: 2.2;
  margin-top: 30px;
}

ul.page-contact-mailform-flow {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  overflow: hidden;
  list-style-type: none;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  color: #000;
  font-size: 1.125rem;
  line-height: 30px;
  width: 100%;
  max-width: 900px;
  margin: 60px auto 0;
}
ul.page-contact-mailform-flow > li {
  position: relative;
  display: block;
  box-sizing: border-box;
  border-radius: 5px;
  width: 28.8888%;
  background-color: #e6e6e6;
  padding: 9px 10px 11px;
}
ul.page-contact-mailform-flow > li::after {
  content: "";
  position: absolute;
  right: -11.5385%;
  top: 50%;
  display: block;
  margin-top: -10px;
  margin-right: -10px;
  width: 20px;
  height: 20px;
  background-image: url(../img/common/angle_flow.svg);
  background-size: 100% 100%;
  background-position: center center;
  background-repeat: no-repeat;
}
ul.page-contact-mailform-flow > li:last-child::after {
  display: none;
}
ul.page-contact-mailform-flow > li.this__current {
  background-image: linear-gradient(90deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-size: 100% 100%;
  background-position: center center;
  background-repeat: no-repeat;
  color: #fff;
}

a.contact-form-require-link {
  color: #e01;
  text-decoration: none;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--page-contact-form {
    padding: 60px 0 30px;
  }

  .page-contact-mailform-info {
    font-size: 0.875rem;
    line-height: 2.2;
    margin-bottom: 30px;
    padding: 0 10px 0;
    text-align: center;
  }

  .page-contact-mailform-privacyinfo {
    font-size: 0.875rem;
    line-height: 2.2;
    margin-top: 30px;
    text-align: left;
  }
  .page-contact-mailform-privacyinfo .this__list {
    padding-left: 1.2em;
  }
  .page-contact-mailform-privacyinfo .this__list .this__list-ico {
    display: inline-block;
    margin-left: -1.2em;
    width: 1.2em;
  }

  ul.page-contact-mailform-flow {
    font-size: 0.875rem;
    line-height: 20px;
    margin: 30px auto 0;
  }
  .page-contact-type-heading + ul.page-contact-mailform-flow {
    margin-top: 30px;
  }
  ul.page-contact-mailform-flow > li {
    border-radius: 5px;
    width: 30%;
    padding: 9px 10px 11px;
  }
  ul.page-contact-mailform-flow > li::after {
    right: -8.3333%;
    top: 50%;
    margin-top: -6px;
    margin-right: -6px;
    width: 12px;
    height: 12px;
  }
}
/*
================================================================
 お問い合わせ フォーム様式
================================================================
*/
.contact-form-area .wpcf7-form-control-wrap {
  display: block;
}
.contact-form-area input[type="text"],
.contact-form-area input[type="email"],
.contact-form-area input[type="tel"],
.contact-form-area input[type="number"],
.contact-form-area input[type="date"],
.contact-form-area select,
.contact-form-area textarea {
  display: inline-block;
  vertical-align: middle;
  box-sizing: border-box;
  padding: 9px 10px 10px;
  max-width: 100%;
  border-width: 1px;
  border-style: solid;
  font-size: 1rem;
  line-height: 1.5;
  text-align: left;
  border-radius: 5px;
  outline-color: #06b;
  border-color: #4d4d4d;
  background: #fff;
  color: #000;
}
.contact-form-area input[type="text"]::placeholder,
.contact-form-area input[type="email"]::placeholder,
.contact-form-area input[type="tel"]::placeholder,
.contact-form-area input[type="number"]::placeholder,
.contact-form-area input[type="date"]::placeholder,
.contact-form-area select::placeholder,
.contact-form-area textarea::placeholder {
  color: #a7a7a7;
}
.contact-form-area input[type="text"]::-webkit-input-placeholder,
.contact-form-area input[type="email"]::-webkit-input-placeholder,
.contact-form-area input[type="tel"]::-webkit-input-placeholder,
.contact-form-area input[type="number"]::-webkit-input-placeholder,
.contact-form-area input[type="date"]::-webkit-input-placeholder,
.contact-form-area select::-webkit-input-placeholder,
.contact-form-area textarea::-webkit-input-placeholder {
  color: #a7a7a7;
}
.contact-form-area input[type="text"]::-moz-input-placeholder,
.contact-form-area input[type="email"]::-moz-input-placeholder,
.contact-form-area input[type="tel"]::-moz-input-placeholder,
.contact-form-area input[type="number"]::-moz-input-placeholder,
.contact-form-area input[type="date"]::-moz-input-placeholder,
.contact-form-area select::-moz-input-placeholder,
.contact-form-area textarea::-moz-input-placeholder {
  color: #a7a7a7;
}
.contact-form-area input[type="text"]:-ms-input-placeholder,
.contact-form-area input[type="email"]:-ms-input-placeholder,
.contact-form-area input[type="tel"]:-ms-input-placeholder,
.contact-form-area input[type="number"]:-ms-input-placeholder,
.contact-form-area input[type="date"]:-ms-input-placeholder,
.contact-form-area select:-ms-input-placeholder,
.contact-form-area textarea:-ms-input-placeholder {
  color: #a7a7a7;
}
.contact-form-area input[type="text"]::-ms-input-placeholder,
.contact-form-area input[type="email"]::-ms-input-placeholder,
.contact-form-area input[type="tel"]::-ms-input-placeholder,
.contact-form-area input[type="number"]::-ms-input-placeholder,
.contact-form-area input[type="date"]::-ms-input-placeholder,
.contact-form-area select::-ms-input-placeholder,
.contact-form-area textarea::-ms-input-placeholder {
  color: #a7a7a7;
}
.contact-form-area input[type="text"] {
  width: 100%;
}
.contact-form-area input[type="text"].type--zip, .contact-form-area input[type="text"].p-postal-code {
  width: 10em;
}
.contact-form-area input[type="text"].type--mail, .contact-form-area input[type="text"].type--addr, .contact-form-area input[type="text"].p-locality {
  width: 100%;
}
.contact-form-area input[type="text"].type--tel {
  width: 100%;
}
.contact-form-area input[type="email"] {
  width: 100%;
}
.contact-form-area input[type="tel"] {
  width: 100%;
}
.contact-form-area input[type="number"] {
  width: 10em;
}
.contact-form-area input[type="date"] {
  width: 100%;
}
.contact-form-area select:not([multiple]) {
  padding-right: 20px;
}
.contact-form-area textarea {
  width: 100%;
}
.contact-form-area input[type="range"] {
  max-width: 100%;
  width: 320px;
  font-size: 1rem;
  display: inline-block;
  vertical-align: middle;
  margin: 14px 5px 16px;
}
.contact-form-area input[type="file"] {
  max-width: 100%;
  font-size: 1rem;
  display: inline-block;
  vertical-align: middle;
  padding: 10px 10px 11px;
}
.contact-form-area .wpcf7-quiz-label {
  font-size: 1rem;
  display: inline-block;
  vertical-align: middle;
  margin: 0 1em 0 0;
  padding: 10px 10px 11px;
}
.contact-form-area .contact-form-checkbox-br .wpcf7-list-item {
  display: block;
  width: 100%;
  margin: 0;
}
.contact-form-area .contact-form-checkbox-br .wpcf7-list-item > label {
  display: block;
  width: 100%;
}
.contact-form-area .wpcf7-list-item {
  font-size: 1rem;
  display: inline-block;
  box-sizing: border-box;
  vertical-align: middle;
  margin: 0 1em 0 0;
}
.contact-form-area .wpcf7-list-item > label {
  position: relative;
  z-index: auto;
  display: inline-block;
  box-sizing: border-box;
  padding-left: 1.5em;
  line-height: 1.5;
  text-align: left;
  border: 0px none;
  outline: 0px none;
  cursor: pointer;
}
.contact-form-area .wpcf7-list-item > label::before {
  position: absolute;
  top: 50%;
  left: 0.1em;
  display: block;
  box-sizing: border-box;
  margin-top: -0.6em;
  width: 1.2em;
  height: 1.2em;
  background-color: #fff;
  border: 1px solid #4d4d4d;
  border-radius: 5px;
  content: "";
}
.contact-form-area .wpcf7-list-item > label > input[type="checkbox"]:first-child {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0.1em;
  display: inline-block;
  box-sizing: border-box;
  width: 0.8em;
  height: 1.75em;
  border: none;
  outline: none;
  opacity: 0;
}
.contact-form-area .wpcf7-list-item > label > input[type="checkbox"]:first-child + .wpcf7-list-item-label {
  display: inline-block;
  margin: 0;
  padding: 10px 10px 11px;
  box-sizing: content-box;
  text-align: left;
}
.contact-form-area .wpcf7-list-item > label > input[type="checkbox"]:first-child + .wpcf7-list-item-label::before {
  position: absolute;
  top: 50%;
  left: 0.2em;
  display: block;
  box-sizing: border-box;
  margin-top: -0.2em;
  width: 0.6em;
  height: 0.25em;
  background-color: #06b;
  border: 1px solid #06b;
  border-radius: 5px;
  transform: rotate(45deg);
  content: "";
  opacity: 0;
}
.contact-form-area .wpcf7-list-item > label > input[type="checkbox"]:first-child + .wpcf7-list-item-label::after {
  position: absolute;
  top: 50%;
  left: 0.4em;
  display: block;
  box-sizing: border-box;
  margin-top: -0.4em;
  width: 1.25em;
  height: 0.25em;
  background-color: #06b;
  border: 1px solid #06b;
  border-radius: 5px;
  transform: rotate(-45deg);
  content: "";
  opacity: 0;
}
.contact-form-area .wpcf7-list-item > label > input[type="checkbox"]:first-child:checked + .wpcf7-list-item-label::before {
  opacity: 1;
  transition: opacity 0.3s ease 0s;
}
.contact-form-area .wpcf7-list-item > label > input[type="checkbox"]:first-child:checked + .wpcf7-list-item-label::after {
  opacity: 1;
  transition: opacity 0.3s ease 0.05s;
}
.contact-form-area .wpcf7-list-item > label > input[type="radio"]:first-child {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0.1em;
  display: inline-block;
  box-sizing: border-box;
  width: 0.8em;
  height: 1.75em;
  border: none;
  outline: none;
  opacity: 0;
}
.contact-form-area .wpcf7-list-item > label > input[type="radio"]:first-child + .wpcf7-list-item-label {
  display: inline-block;
  margin: 0;
  padding: 10px 10px 11px;
  box-sizing: content-box;
  text-align: left;
}
.contact-form-area .wpcf7-list-item > label > input[type="radio"]:first-child + .wpcf7-list-item-label::before {
  position: absolute;
  top: 50%;
  left: 0.4em;
  display: block;
  box-sizing: border-box;
  margin-top: -0.3em;
  width: 0.6em;
  height: 0.6em;
  background-color: #06b;
  border: 1px solid #06b;
  border-radius: 50% 50%;
  content: "";
  opacity: 0;
}
.contact-form-area .wpcf7-list-item > label > input[type="radio"]:first-child + .wpcf7-list-item-label::after {
  display: none;
}
.contact-form-area .wpcf7-list-item > label > input[type="radio"]:first-child:checked + .wpcf7-list-item-label::before {
  opacity: 1;
  transition: opacity 0.3s ease 0s;
}
.contact-form-area .wpcf7-radio .wpcf7-list-item > label::before {
  border-radius: 50% 50%;
}
.contact-form-area .wpcf7 form .wpcf7-response-output {
  border-color: #0ae;
}
.contact-form-area .wpcf7 form.sent .wpcf7-response-output {
  border-color: #2a3;
}
.contact-form-area .wpcf7 form.failed .wpcf7-response-output,
.contact-form-area .wpcf7 form.aborted .wpcf7-response-output {
  border-color: #e01;
}
.contact-form-area .wpcf7 form.spam .wpcf7-response-output {
  border-color: #fa0;
}
.contact-form-area .wpcf7 form.invalid .wpcf7-response-output,
.contact-form-area .wpcf7 form.unaccepted .wpcf7-response-output,
.contact-form-area .wpcf7 form.payment-required .wpcf7-response-output {
  border-color: #fa0;
}
.contact-form-area .this__error-val,
.contact-form-area .wpcf7-not-valid-tip {
  color: #f00;
}
.contact-form-area .use-floating-validation-tip .wpcf7-not-valid-tip {
  border-color: #f00;
}

#multistep-contact-form-area.contact-form-area {
  opacity: 1;
  transition: opacity 0.5s ease;
}
#multistep-contact-form-area.contact-form-area.jsctrl--display-update {
  opacity: 0;
}
#multistep-contact-form-area.contact-form-area.contact-form-area--input .this__confirm, #multistep-contact-form-area.contact-form-area.contact-form-area--confirm .this__input, #multistep-contact-form-area.contact-form-area.contact-form-area--confirm .this__error {
  display: none;
}
#multistep-contact-form-area.contact-form-area .this__input--disp-error .wpcf7-not-valid-tip {
  display: none;
}
#multistep-contact-form-area.contact-form-area .wpcf7 form.sent .wpcf7-response-output {
  display: none;
}

.contact-form-addrblock {
  display: block;
}
.contact-form-addrblock span.p-country-name {
  display: none;
}

dl.contact-form-input-table {
  margin: 30px 0 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  color: #000;
  font-size: 1rem;
  line-height: 1.75;
  text-align: left;
}
dl.contact-form-input-table > dt {
  position: relative;
  box-sizing: border-box;
  width: 280px;
  padding: 38px 0 32px 60px;
  border-top: 1px solid #a7a7a7;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
}
dl.contact-form-input-table > dt:first-child {
  border-top: 0 none;
}
dl.contact-form-input-table > dt em.contact-form-require-badge {
  position: absolute;
  left: 0;
  top: 40px;
}
dl.contact-form-input-table > dd {
  box-sizing: border-box;
  width: calc(100% - 280px);
  padding: 38px 0 32px 30px;
  border-top: 1px solid #a7a7a7;
}
dl.contact-form-input-table > dd:nth-child(2) {
  border-top: 0 none;
}
dl.contact-form-input-table > dd dl > dt {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  margin-top: 1.5em;
}
dl.contact-form-input-table > dd dl > dt:first-child {
  margin-top: 0;
}
dl.contact-form-input-table > dd .this__zip::before {
  content: "〒";
  display: inline-block;
  margin-right: 0.5em;
}
dl.contact-form-input-table > dd .this__confirm--zip .this__confirm-val::before {
  content: "〒";
  display: inline-block;
  margin-right: 0.5em;
}
.contact-form-area--input dl.contact-form-input-table > dd .this__zip::after {
  /* clearfix */
  content: "";
  clear: both;
  display: block;
  width: 100%;
  height: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
}
.contact-form-area--input dl.contact-form-input-table > dd .this__zip::before {
  content: "〒";
  float: left;
  display: block;
  margin-right: 0.5em;
  padding-top: 8px;
}
.contact-form-area--confirm dl.contact-form-input-table > dd .this__mail,
.contact-form-area--confirm dl.contact-form-input-table > dd .this__confirm--mail {
  word-break: break-all;
}

em.contact-form-require-badge {
  position: relative;
  top: -0.2em;
  display: inline-block;
  vertical-align: middle;
  box-sizing: border-box;
  border-radius: 0.9em;
  padding: 0.2em 0.8em 0.2em;
  margin: 0 0.5em;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-style: normal !important;
  font-size: 80%;
  line-height: 1.4;
  color: #fff;
  background-color: #f00;
  text-align: center;
}

.contact-form-agree {
  margin-top: 30px;
  text-align: center;
}

.contact-form-button {
  margin-top: 30px;
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.contact-form-button > *:not(:first-child) {
  margin-right: 80px;
}

.contact-form-area--confirm .contact-form-area__input-only,
.contact-form-area--complete .contact-form-area__input-only,
.contact-form-area--input .contact-form-area__confirm-only,
.contact-form-area--complete .contact-form-area__confirm-only,
.contact-form-area--input .contact-form-area__complete-only,
.contact-form-area--confirm .contact-form-area__complete-only {
  display: none !important;
}

.contact-form-complete {
  margin: 100px 0 100px;
  width: 100%;
}

.contact-form-complete-heading {
  display: block;
  font-size: 1.375rem;
  line-height: 1.8;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  width: 100%;
  text-align: center;
}

.contact-form-complete-msg {
  display: block;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  line-height: 2.2;
  max-width: 100%;
  text-align: center;
  margin: 30px 0 0;
}
.contact-form-complete-msg .this__notes {
  font-size: 90%;
}
.contact-form-complete-msg p:not(:first-child) {
  margin-top: 20px;
}

@media all and (min-width: 1080px) {
  .contact-form-area--input dl.contact-form-input-table > dd > .this__check,
  .contact-form-area--input dl.contact-form-input-table > dd > .this__textbox,
  .contact-form-area--input dl.contact-form-input-table > dd > .this__text {
    display: block;
    margin: -8px 0;
  }
  .contact-form-area--input dl.contact-form-input-table > dd > .this__error {
    display: block;
    margin: 8px 0 -8px;
  }
}
@media all and (max-width: 1079px) {
  dl.contact-form-input-table {
    font-size: 1rem;
    line-height: 1.75;
  }
  dl.contact-form-input-table > dt {
    width: 100%;
    padding: 20px 10px 10px;
  }
  dl.contact-form-input-table > dt em.contact-form-require-badge {
    position: relative;
    top: -0.2em;
    left: 0;
  }
  dl.contact-form-input-table > dd {
    border-top: 0 none;
    width: 100%;
    padding: 0 10px 20px;
  }
}
@media all and (max-width: 767px) {
  dl.contact-form-input-table {
    line-height: 1.75;
  }
  dl.contact-form-input-table > dt {
    width: 100%;
    padding: 20px 10px 10px;
  }
  dl.contact-form-input-table > dd {
    font-size: 0.875rem;
    border-top: 0 none;
    width: 100%;
    padding: 0 10px 20px;
  }

  .contact-form-agree {
    margin-top: 20px;
  }

  .contact-form-button {
    margin-top: 40px;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
  }
  .contact-form-button > *:not(:first-child) {
    margin: 30px 0;
  }

  .contact-form-complete {
    margin: 70px 0 70px;
  }

  .contact-form-complete-heading {
    font-size: 1.125rem;
    line-height: 1.8;
  }

  .contact-form-complete-msg {
    font-size: 0.875rem;
    line-height: 2.2;
    max-width: 100%;
    margin: 20px 0 0;
  }
  .contact-form-complete-msg .this__notes {
    font-size: 90%;
  }
  .contact-form-complete-msg p:not(:first-child) {
    margin-top: 17px;
  }
}
/*
================================================================
 個人情報保護方針 イントロダクション
================================================================
*/
.section-panel.section-panel--page-privacy-introduction {
  padding: 0;
}

.page-privacy-introduction__content {
  padding: 100px 0;
  border-bottom: 1px solid #000;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  line-height: 2;
}
.page-privacy-introduction__content > *:not(:first-child) {
  margin-top: 2em;
}

@media all and (max-width: 767px) {
  .page-privacy-introduction__content {
    padding: 60px 0;
    font-size: 0.875rem;
    line-height: 2;
  }
}
/*
================================================================
 個人情報保護方針 基本
================================================================
*/
.section-panel.section-panel--page-privacy-main {
  padding: 0 0 100px;
}
.section-panel.section-panel--page-privacy-main .section-block {
  padding: 100px 0 0;
}

.page-privacy-main__heading {
  background-color: transparent;
  text-align: center;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 2.5rem;
  font-size: 1.75rem;
}
.page-privacy-main__heading .this__title {
  text-align: center;
  display: inline-block;
  width: 450px;
  max-width: 100%;
  padding: 4px 1em 6px;
  background-image: linear-gradient(90deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
}

.page-privacy-main__introduction {
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  line-height: 2;
}
.page-privacy-main__introduction > *:not(:first-child) {
  margin-top: 2em;
}

.page-privacy-main__subpage {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
}
.page-privacy-main__subpage > a, .page-privacy-main__subpage > .as-link {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  margin: 0;
  padding: 20px 2em 50px;
  cursor: default;
  text-decoration: none;
  opacity: 1;
  text-align: center;
  background-image: linear-gradient(90deg, #000030, #1e558c 40%, #1e558c 60%, #000030);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
  border-radius: 10px;
  font-size: 1.25rem;
  line-height: 1.5;
  overflow: hidden;
  transition: color 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s, opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.page-privacy-main__subpage > a::before, .page-privacy-main__subpage > .as-link::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(90deg, #6893c6, #b3c9e2 40%, #b3c9e2 60%, #6893c6);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.2, 0, 0.8, 1) 0s;
}
.page-privacy-main__subpage > a::after, .page-privacy-main__subpage > .as-link::after {
  content: "";
  position: absolute;
  z-index: 2;
  bottom: 20px;
  left: 50%;
  display: block;
  margin-left: -10px;
  width: 20px;
  height: 20px;
  background-image: url(../img/common/tab_link.svg);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
.page-privacy-main__subpage > a .this__title, .page-privacy-main__subpage > .as-link .this__title {
  position: relative;
  z-index: 11;
  display: block;
  width: 100%;
  text-align: center;
}
.page-privacy-main__subpage > a {
  cursor: pointer;
}
.page-privacy-main__subpage > a:hover {
  opacity: 0.7;
}
.page-privacy-main__subpage.current-menu-item > a, .page-privacy-main__subpage.current-menu-item > .as-link {
  color: #2b4a8a;
}
.page-privacy-main__subpage.current-menu-item > a::before, .page-privacy-main__subpage.current-menu-item > .as-link::before {
  opacity: 1;
}
.page-privacy-main__subpage.current-menu-item > a::after, .page-privacy-main__subpage.current-menu-item > .as-link::after {
  background-image: url(../img/common/tab_link.svg);
}
.page-privacy-main__subpage.disabled-menu-item > a, .page-privacy-main__subpage.disabled-menu-item > .as-link {
  background-color: #a7a7a7;
  background-image: none;
}
.page-privacy-main__subpage.disabled-menu-item > a::after, .page-privacy-main__subpage.disabled-menu-item > .as-link::after {
  display: none;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--page-privacy-main {
    padding: 0 0 60px;
  }
  .section-panel.section-panel--page-privacy-main .section-block {
    padding: 60px 0 0;
  }

  .page-privacy-main__heading {
    line-height: 1.875rem;
    font-size: 1.25rem;
  }
  .page-privacy-main__heading .this__title {
    width: auto;
    padding: 4px 1em 6px;
  }

  .page-privacy-main__introduction {
    font-size: 0.875rem;
    line-height: 2;
  }
  .page-privacy-main__introduction > *:not(:first-child) {
    margin-top: 2em;
  }

  .page-privacy-main__subpage > a, .page-privacy-main__subpage > .as-link {
    padding: 5px 2em 35px;
    font-size: 1rem;
    line-height: 1.4;
  }
  .page-privacy-main__subpage > a .this__title, .page-privacy-main__subpage > .as-link .this__title {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: 50px;
  }
  .page-privacy-main__subpage > a .this__title > span, .page-privacy-main__subpage > .as-link .this__title > span {
    display: block;
    width: 100%;
  }
  .page-privacy-main__subpage > a::after, .page-privacy-main__subpage > .as-link::after {
    bottom: 16px;
    left: 50%;
    margin-left: -8px;
    width: 16x;
    height: 16px;
  }
}
/*
================================================================
 個人情報保護方針 サブセクション
================================================================
*/
.section-block.page-privacy-sub {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  line-height: 2;
  text-align: justify;
}
.section-block.page-privacy-sub .line-break-span {
  text-align: left;
}

.page-privacy-sub__heading {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  background-color: transparent;
  color: #2b4a8a;
  box-sizing: border-box;
  width: 100%;
  padding: 0 0 2px 10px;
  border-left: 10px solid #2b4a8a;
  text-align: justify;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 2.375rem;
  font-size: 1.75rem;
}
.page-privacy-sub__heading .this__number {
  display: block;
  width: 1.2em;
  text-align: center;
}
.page-privacy-sub__heading .this__number + .this__title {
  width: calc(100% - 1.2em);
}
.page-privacy-sub__heading .this__title {
  display: block;
  width: 100%;
}

.page-privacy-sub__txt > * {
  margin-top: 2em;
}

ol.page-privacy-sub__ol {
  display: block;
  list-style-type: none;
  counter-reset: privacyol;
}
ol.page-privacy-sub__ol > li {
  position: relative;
  list-style-type: none;
  margin: 2em 0 0;
  padding-left: 2.5em;
  text-align: justify;
  counter-increment: privacyol;
}
ol.page-privacy-sub__ol > li::before {
  position: absolute;
  top: 0.1em;
  left: 0;
  content: counter(privacyol);
  display: block;
  width: 2em;
  background-color: #bfc9dc;
  color: #2b4a8a;
  text-align: center;
  line-height: 1.9;
  padding-bottom: 0.1em;
}

dl.page-privacy-sub__icon-dl {
  display: block;
}
dl.page-privacy-sub__icon-dl > dt {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin-top: 2em;
  padding: 0 0 0 1.2em;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
}
dl.page-privacy-sub__icon-dl > dt .this__icon {
  display: inline-block;
  min-width: 1.2em;
  margin-left: -1.2em;
}

dl.page-privacy-sub__subcontent-dl {
  display: block;
}
dl.page-privacy-sub__subcontent-dl > dt {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin-top: 2em;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  color: #2b4a8a;
  font-size: 112.5%;
}

dl.page-privacy-sub__tables {
  display: block;
}
dl.page-privacy-sub__tables > dt {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin-top: 2em;
  padding: 1px 1em 2px;
  background-color: #b3c9e2;
  color: #2b4a8a;
  font-size: 112.5%;
  line-height: 1.4;
}
dl.page-privacy-sub__tables > dd {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin-top: 1em;
  overflow-x: auto;
  font-size: 87.5%;
}
dl.page-privacy-sub__tables > dd table {
  width: 100%;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  background-color: #fff;
  color: #231815;
}
dl.page-privacy-sub__tables > dd table th {
  box-sizing: border-box;
  padding: 0.5em 1em 0.5em 3em;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  text-align: justify;
  vertical-align: top;
}
dl.page-privacy-sub__tables > dd table th:first-child {
  width: 250px;
  background-color: #b3c9e2;
}
dl.page-privacy-sub__tables > dd table td {
  box-sizing: border-box;
  padding: 0.5em 1em 0.5em 3em;
  text-align: justify;
  vertical-align: top;
}
dl.page-privacy-sub__tables > dd table thead {
  border-bottom: 3px double #a7a7a7;
}
dl.page-privacy-sub__tables > dd table tbody th {
  border-top: 1px solid #a7a7a7;
}
dl.page-privacy-sub__tables > dd table tbody td {
  border-top: 1px solid #a7a7a7;
}
dl.page-privacy-sub__tables > dd table tbody tr:first-child th, dl.page-privacy-sub__tables > dd table tbody tr:first-child td {
  border-top: 0 none;
}

.page-privacy-sub__txt ul,
ol.page-privacy-sub__ol ul,
dl.page-privacy-sub__icon-dl ul,
dl.page-privacy-sub__subcontent-dl ul {
  display: block;
  list-style-type: none;
}
.page-privacy-sub__txt ul > li,
ol.page-privacy-sub__ol ul > li,
dl.page-privacy-sub__icon-dl ul > li,
dl.page-privacy-sub__subcontent-dl ul > li {
  padding-left: 1em;
  text-align: justify;
  line-height: 2;
}
.page-privacy-sub__txt ul > li::before,
ol.page-privacy-sub__ol ul > li::before,
dl.page-privacy-sub__icon-dl ul > li::before,
dl.page-privacy-sub__subcontent-dl ul > li::before {
  content: '・';
  display: inline-block;
  vertical-align: baseline;
  min-width: 1em;
  margin-left: -1em;
  margin-right: 0;
  text-align: center;
}
.page-privacy-sub__txt ul.type--notes > li::before,
ol.page-privacy-sub__ol ul.type--notes > li::before,
dl.page-privacy-sub__icon-dl ul.type--notes > li::before,
dl.page-privacy-sub__subcontent-dl ul.type--notes > li::before {
  content: '※';
}

.page-privacy-sub__credit {
  margin-top: 4em;
  text-align: right;
}
.page-privacy-sub__credit .this__name {
  display: block;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
}
.page-privacy-sub__credit .this__name em {
  font-size: 120%;
  font-style: inherit;
}
.page-privacy-sub__credit .this__data {
  display: block;
}

@media all and (max-width: 1079px) {
  .page-privacy-sub__heading {
    padding: 0 0 2px 10px;
    border-left-width: 10px;
    line-height: 2rem;
    font-size: 1.375rem;
  }

  dl.page-privacy-sub__tables > dd {
    font-size: 0.75rem;
  }
  dl.page-privacy-sub__tables > dd table {
    min-width: 560px;
  }
  dl.page-privacy-sub__tables > dd table th {
    padding: 0.5em 1em 0.5em 1.5em;
  }
  dl.page-privacy-sub__tables > dd table th:first-child {
    width: 180px;
  }
  dl.page-privacy-sub__tables > dd table td {
    padding: 0.5em 1em 0.5em 1.5em;
  }
}
@media all and (max-width: 767px) {
  .section-block.page-privacy-sub {
    font-size: 0.875rem;
    line-height: 2;
  }

  .page-privacy-sub__heading {
    padding: 0 0 2px 10px;
    border-left-width: 10px;
    line-height: 1.625rem;
    font-size: 1.125rem;
  }
}
/*
================================================================
 個人情報保護方針 問合せ窓口
================================================================
*/
.section-panel.section-panel--page-privacy-contact {
  padding: 100px 0;
}
.section-panel.section-panel--page-privacy-contact .section-heading-title-label .this__title {
  box-sizing: border-box;
  width: 100%;
  background-color: #fff;
  color: #000;
}

dl.page-privacy-contact__details {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  margin: 30px 0 0;
  width: 100%;
  text-align: left;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  line-height: 2;
  font-size: 1.125rem;
}
dl.page-privacy-contact__details > dt {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  box-sizing: border-box;
  width: 200px;
  padding: 2em 0;
  border-top: 1px solid #fff;
}
dl.page-privacy-contact__details > dt .this__name {
  display: block;
  width: max-content;
  max-width: 100%;
  min-width: 5em;
  text-align-last: justify;
}
dl.page-privacy-contact__details > dt:first-child {
  border-top: 0 none;
}
dl.page-privacy-contact__details > dt:first-child + dd {
  border-top: 0 none;
}
dl.page-privacy-contact__details > dd {
  display: block;
  box-sizing: border-box;
  width: calc(100% - 200px);
  padding: 2em 0 2em 50px;
  border-top: 1px solid #fff;
}

@media all and (max-width: 1079px) {
  dl.page-privacy-contact__details {
    margin: 30px 0 0;
    line-height: 2;
    font-size: 1rem;
  }
  dl.page-privacy-contact__details > dt {
    width: 160px;
    padding: 2em 0;
  }
  dl.page-privacy-contact__details > dd {
    width: calc(100% - 160px);
    padding: 2em 0 2em 30px;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--page-privacy-contact {
    padding: 60px 0;
  }

  dl.page-privacy-contact__details {
    margin: 30px 0 0;
    line-height: 2;
  }
  dl.page-privacy-contact__details > dt {
    flex-direction: row;
    width: 100%;
    padding: 15px 15px 10px;
    font-size: 1.125rem;
  }
  dl.page-privacy-contact__details > dd {
    width: 100%;
    padding: 0 15px 20px;
    border-top: 0 none;
    font-size: 0.875rem;
  }
}
/*
================================================================
 エラーページ
================================================================
*/
.section-panel.section-panel--page-error-msg {
  padding: 100px 0 50px;
  color: #0a194d;
}

.page-error-msg__heading {
  text-align: center;
  display: block;
}
.page-error-msg__heading .this__main {
  display: block;
  color: #2b4a8a;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 2.5rem;
  line-height: 1.6;
}
.page-error-msg__heading .this__sub {
  display: block;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
  font-size: 1.25rem;
  line-height: 2;
}

.page-error-msg__img {
  text-align: center;
  display: block;
  margin: 100px 0;
}
.page-error-msg__img img {
  display: inline-block;
  width: 315px;
  max-width: 100%;
  height: auto;
}

.page-error-msg__txt {
  text-align: center;
  display: block;
  font-size: 1rem;
}

@media all and (max-width: 767px) {
  .section-panel.section-panel--page-error-msg {
    padding: 60px 0 30px;
  }

  .page-error-msg__heading .this__main {
    font-size: 1.75rem;
    line-height: 1.6;
  }
  .page-error-msg__heading .this__sub {
    font-size: 1rem;
    line-height: 2;
  }

  .page-error-msg__img {
    margin: 60px 0;
  }

  .page-error-msg__txt {
    font-size: 0.875rem;
  }
}
/*
================================================================
 人材派遣 ヒーローイメージ
================================================================
*/
.lp-staffing-hero-screen {
  position: relative;
  display: block;
  width: 100%;
  overflow: hidden;
  background-color: #006633;
  background-size: cover;
  background-repeat: no-repeat;
}

.lp-staffing-hero-heading {
  display: block;
  width: 100%;
  height: 640px;
  min-height: 100vh;
  color: #fff;
}
.lp-staffing-hero-heading .container {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-end;
  height: 100%;
}
.lp-staffing-hero-heading .this__heading {
  width: 60%;
  text-align: right;
}
.lp-staffing-hero-heading .this__heading img {
  display: inline-block;
  max-width: 100%;
  height: auto;
}

@media all and (max-width: 767px) {
  .lp-staffing-hero-heading .this__heading {
    width: 80%;
  }
}
/*
================================================================
 人材派遣 エフザタッチの特徴
================================================================
*/
.section-panel.section-panel--lp-staffing-feature {
  padding: 100px 0;
}
.section-panel.section-panel--lp-staffing-feature .section-heading-title-label .this__title {
  background-image: linear-gradient(90deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
}

ul.lp-staffing-feature-list {
  list-style-type: none;
  margin: 80px 0 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
ul.lp-staffing-feature-list > li {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
ul.lp-staffing-feature-list > li .half-container {
  max-width: 600px;
}
ul.lp-staffing-feature-list > li .this__item-layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
}
ul.lp-staffing-feature-list > li .this__item-layout .this__content {
  display: block;
  width: 50%;
}
ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__title-box {
  border-bottom: 2px solid #006633;
}
ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__title {
  padding-top: 1.4em;
  padding-bottom: 1em;
  line-height: 1.6;
  font-size: 1.625rem;
}
ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__txt {
  padding-bottom: 1em;
  line-height: 2.2;
  font-size: 1rem;
}
ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__txt p {
  margin-top: 2em;
}
ul.lp-staffing-feature-list > li .this__item-layout .this__img {
  display: block;
  box-sizing: border-box;
  clear: both;
  box-sizing: border-box;
  width: calc(50% - 15px);
  max-width: 600px;
}
@media all and (min-width: 580px) {
  ul.lp-staffing-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 25px);
  }
}
@media all and (min-width: 768px) {
  ul.lp-staffing-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 50px);
  }
}
@media all and (min-width: 1080px) {
  ul.lp-staffing-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 60px);
  }
}
@media all and (min-width: 1280px) {
  ul.lp-staffing-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 70px);
  }
}
@media all and (min-width: 1440px) {
  ul.lp-staffing-feature-list > li .this__item-layout .this__img {
    width: calc(50% - 80px);
  }
}
ul.lp-staffing-feature-list > li .this__item-layout .this__img::before {
  content: "";
  display: block;
  box-sizing: content-box;
  width: 100%;
  height: 0;
  padding: 58.3333% 0 0;
}
ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout {
  flex-direction: row;
}
ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content {
  text-align: right;
}
ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .half-container {
  margin-left: auto;
}
ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
  padding-right: 60px;
}
ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout {
  flex-direction: row-reverse;
}
ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content {
  text-align: left;
}
ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .half-container {
  margin-right: auto;
}
ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
  padding-left: 60px;
}

@media all and (max-width: 1279px) {
  ul.lp-staffing-feature-list {
    margin: 60px 0 0;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__title {
    font-size: 1.5rem;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__txt {
    font-size: 1rem;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
    padding-right: 40px;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
    padding-left: 40px;
  }
}
@media all and (max-width: 1079px) {
  ul.lp-staffing-feature-list {
    margin: 40px 0 0;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__title {
    font-size: 1.25rem;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__content .this__txt {
    font-size: 0.875rem;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
    padding-right: 20px;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
    padding-left: 20px;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--lp-staffing-feature {
    padding: 60px 0;
  }
}
@media all and (min-width: 768px) {
  ul.lp-staffing-feature-list > li .container {
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  ul.lp-staffing-feature-list {
    margin: 0 0 0;
  }
  ul.lp-staffing-feature-list > li {
    margin: 40px 0 0;
  }
  ul.lp-staffing-feature-list > li .half-container {
    width: 100%;
    max-width: 100%;
  }
  ul.lp-staffing-feature-list > li .this__item-layout {
    display: block;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__content {
    width: 100%;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__img {
    width: 100%;
    max-width: 100%;
    min-height: 240px;
  }
  ul.lp-staffing-feature-list > li .this__item-layout .this__img::before {
    padding: 50% 0 0;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content {
    text-align: left;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__title,
  ul.lp-staffing-feature-list > li:nth-child(2n+1) .this__item-layout .this__content .this__txt {
    padding-right: 0;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content {
    text-align: left;
  }
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__title,
  ul.lp-staffing-feature-list > li:nth-child(2n) .this__item-layout .this__content .this__txt {
    padding-left: 0;
  }
}
/*
================================================================
 人材派遣 こんなお悩みを解決します
================================================================
*/
.section-panel.section-panel--lp-staffing-solve {
  padding: 100px 0;
}
.section-panel.section-panel--lp-staffing-solve .section-heading-title-label .this__title {
  background-color: #fff;
  color: #006633;
}

ul.lp-staffing-solve-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  list-style-type: none;
  margin: 0 0 0;
  padding: 0;
  width: 100%;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
ul.lp-staffing-solve-list > li {
  position: relative;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  list-style-type: none;
  width: 30%;
  margin: 40px 0 0 5%;
  padding: 26% 0 2%;
  background-color: #fff;
  color: #000;
}
ul.lp-staffing-solve-list > li:nth-child(3n+1) {
  margin-left: 0;
}
ul.lp-staffing-solve-list > li .this__item-layout {
  display: block;
}
ul.lp-staffing-solve-list > li .this__item-layout .this__img {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: auto;
}
ul.lp-staffing-solve-list > li .this__item-layout .this__img img {
  display: block;
  width: 100%;
  height: auto;
}
ul.lp-staffing-solve-list > li .this__item-layout .this__title {
  display: block;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0 1em;
  width: 100%;
  max-width: 320px;
  font-size: 1.125rem;
  line-height: 2;
  text-align: center;
}

@media all and (max-width: 1079px) {
  ul.lp-staffing-solve-list > li {
    width: 47%;
    margin: 40px 0 0 6%;
    padding: 41% 0 4%;
  }
  ul.lp-staffing-solve-list > li:nth-child(3n+1) {
    margin-left: 6%;
  }
  ul.lp-staffing-solve-list > li:nth-child(2n+1) {
    margin-left: 0;
  }
  ul.lp-staffing-solve-list > li .this__item-layout .this__title {
    font-size: 1.125rem;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--lp-staffing-solve {
    padding: 60px 0;
  }

  ul.lp-staffing-solve-list > li {
    width: 47%;
    margin: 40px 0 0 6%;
    padding: 41% 0 4%;
  }
  ul.lp-staffing-solve-list > li:nth-child(3n+1) {
    margin-left: 6%;
  }
  ul.lp-staffing-solve-list > li:nth-child(2n+1) {
    margin-left: 0;
  }
  ul.lp-staffing-solve-list > li .this__item-layout .this__title {
    font-size: 0.875rem;
  }
}
@media all and (max-width: 579px) {
  ul.lp-staffing-solve-list {
    margin: 0 0 0;
    padding: 0;
  }
  ul.lp-staffing-solve-list > li {
    display: block;
    padding: 0;
    width: 100%;
    margin: 40px 0 0;
  }
  ul.lp-staffing-solve-list > li:nth-child(3n+1) {
    margin-left: 0;
  }
  ul.lp-staffing-solve-list > li:nth-child(2n+1) {
    margin-left: 0;
  }
  ul.lp-staffing-solve-list > li .this__item-layout .this__img {
    position: static;
    width: 100%;
  }
  ul.lp-staffing-solve-list > li .this__item-layout .this__title {
    padding: 2em 15px;
    max-width: 240px;
    font-size: 0.875rem;
  }
}
/*
================================================================
 人材派遣 導入の流れ
================================================================
*/
.section-panel.section-panel--lp-staffing-step {
  padding: 100px 0 0;
}
.section-panel.section-panel--lp-staffing-step .section-heading-title-label .this__title {
  background-image: linear-gradient(90deg, #006934, #1eaa39 40%, #1eaa39 60%, #006934);
  background-position: center center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  color: #fff;
}

ul.lp-staffing-step__list {
  display: block;
  list-style-type: none;
  margin: 0;
  padding: 0;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
  font-feature-settings: "palt" 1;
}
ul.lp-staffing-step__list > li {
  display: block;
  list-style-type: none;
  margin: 0;
  padding: 40px 0;
  width: 100%;
  border-bottom: 2px dotted #cce0d6;
}
ul.lp-staffing-step__list > li:last-child {
  border-bottom: 0 none;
}
ul.lp-staffing-step__list > li .this__layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
ul.lp-staffing-step__list > li .this__layout .this__step {
  display: block;
  box-sizing: border-box;
  padding-top: 20px;
  width: 120px;
  height: 120px;
  background-color: #006633;
  color: #fff;
  border-radius: 50%;
  text-align: center;
  font-size: 1.125rem;
  line-height: 1;
}
ul.lp-staffing-step__list > li .this__layout .this__step span {
  display: block;
}
ul.lp-staffing-step__list > li .this__layout .this__step span.this__number {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 3.4375rem;
}
ul.lp-staffing-step__list > li .this__layout .this__title {
  display: block;
  width: 170px;
  text-align: left;
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  font-size: 1.25rem;
  line-height: 1.6;
}
ul.lp-staffing-step__list > li .this__layout .this__txt {
  display: block;
  width: calc(100% - 340px);
  text-align: left;
  font-size: 1rem;
  line-height: 2;
}

@media all and (max-width: 1079px) {
  ul.lp-staffing-step__list > li .this__layout .this__step {
    padding-top: 20px;
    width: 120px;
    height: 120px;
    font-size: 1.125rem;
  }
  ul.lp-staffing-step__list > li .this__layout .this__step span.this__number {
    font-size: 3.4375rem;
  }
  ul.lp-staffing-step__list > li .this__layout .this__title {
    width: 150px;
    font-size: 1.125rem;
    line-height: 1.6;
  }
  ul.lp-staffing-step__list > li .this__layout .this__txt {
    width: calc(100% - 320px);
    font-size: 0.875rem;
    line-height: 2;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--lp-staffing-step {
    padding: 60px 0 0;
  }

  ul.lp-staffing-step__list > li .this__layout .this__step {
    padding-top: 20px;
    width: 120px;
    height: 120px;
    font-size: 1.125rem;
  }
  ul.lp-staffing-step__list > li .this__layout .this__step span.this__number {
    font-size: 3.4375rem;
  }
  ul.lp-staffing-step__list > li .this__layout .this__title {
    width: calc(100% - 150px);
    font-size: 1.125rem;
    line-height: 1.6;
  }
  ul.lp-staffing-step__list > li .this__layout .this__txt {
    margin-top: 2em;
    width: 100%;
    font-size: 0.875rem;
    line-height: 2;
  }
}
@media all and (max-width: 579px) {
  ul.lp-staffing-step__list > li .this__layout .this__step {
    padding-top: 14px;
    width: 80px;
    height: 80px;
    font-size: 0.75rem;
  }
  ul.lp-staffing-step__list > li .this__layout .this__step span.this__number {
    font-size: 2rem;
  }
  ul.lp-staffing-step__list > li .this__layout .this__title {
    width: calc(100% - 100px);
    font-size: 1rem;
    line-height: 1.6;
  }
  ul.lp-staffing-step__list > li .this__layout .this__txt {
    margin-top: 2em;
    width: 100%;
    font-size: 0.875rem;
    line-height: 2;
  }
}
/*
================================================================
 人材派遣 ダウンロード
================================================================
*/
.section-panel.section-panel--lp-staffing-download {
  padding: 100px 0;
}

.lp-staffing-download__layout {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
}

.lp-staffing-download__main {
  position: relative;
  flex-shrink: 1;
  order: 2;
  width: 40%;
  min-width: 320px;
}

.lp-staffing-download__content {
  position: relative;
  z-index: 11;
  display: block;
  box-sizing: border-box;
  padding: 60px 20px 0;
  min-height: 300px;
  text-align: center;
}

.lp-staffing-download__heading {
  font-family: "Zen Kaku Gothic Antique", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  line-height: 1.8;
  font-size: 2rem;
}

.lp-staffing-download__btn {
  margin: 40px 0 0;
}

.lp-staffing-download__img {
  display: block;
  flex-shrink: 0;
  order: 3;
  box-sizing: content-box;
  width: 30%;
  max-width: calc(50% - 160px);
}
.lp-staffing-download__main + .lp-staffing-download__img {
  order: 1;
}

.lp-staffing-download__low {
  margin: 40px 0 0;
  font-size: 0.75rem;
  line-height: 1.6;
  text-align: right;
}
.lp-staffing-download__low a.low-btn {
  display: inline-block;
  color: #4d4d4d;
  text-decoration: none;
  border: 1px solid #4d4d4d;
  border-radius: 0.8em;
  padding: 0 0.8em 0.05em;
  line-height: 1.4;
}

@media all and (max-width: 1079px) {
  .lp-staffing-download__heading {
    line-height: 1.8;
    font-size: 1.5rem;
  }
}
@media all and (max-width: 767px) {
  .section-panel.section-panel--lp-staffing-download {
    padding: 60px 0;
  }

  .lp-staffing-download__main {
    order: 1;
    width: 100%;
    min-width: auto;
  }

  .lp-staffing-download__content {
    padding: 60px 15px 60px;
    min-height: auto;
  }

  .lp-staffing-download__heading {
    line-height: 1.8;
    font-size: 1.375rem;
  }

  .lp-staffing-download__btn {
    margin: 20px 0 0;
  }

  .lp-staffing-download__img {
    order: 3;
    width: 50%;
    max-width: none;
    padding: 30% 0 0;
  }
  .lp-staffing-download__main + .lp-staffing-download__img {
    order: 2;
  }

  .lp-staffing-download__low {
    margin: 30px 0 0;
    font-size: 0.75rem;
    line-height: 1.6;
    text-align: right;
  }
}
@media all and (max-width: 579px) {
  .lp-staffing-download__img {
    padding: 50% 0 0;
  }
}
