@charset "UTF-8";
img {
  width: 100%;
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block;
  }
}

/* -----------------------------------------------
* Plugins エントリーポイント
-------------------------------------------------- */
/*------------------------------------------------------------------------------
  reset PC
------------------------------------------------------------------------------*/
html,
input,
textarea,
select,
button {
  font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, sans-serif;
  font-weight: 400;
  font-size: 16px;
}

html {
  color: #1B1C1D;
  background: #fff;
  font-size: 16px;
  line-height: 1.5;
  word-break: break-all;
}

body {
  background: #fff;
  margin: 0;
}
@media screen and (max-width: 1440px) {
  body {
    margin: 0;
  }
}
@media screen and (max-width: 1250px) {
  body {
    margin: 0;
  }
}
@media screen and (min-width: 1140px) {
  body {
    margin: 0;
  }
}
@media screen and (max-width: 1139px) {
  body {
    margin: 0;
  }
}
@media screen and (max-width: 767px) {
  body {
    margin: 0;
  }
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

img {
  border: 0;
  margin: 0;
  vertical-align: top;
  max-width: 100%;
  width: 100%;
  height: auto;
}

p {
  margin: 0;
  padding: 0;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

a {
  color: #1B1C1D;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 1140px) {
  a:hover {
    color: #1056B2;
  }
}

input,
select,
textarea,
button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

::-webkit-input-placeholder {
  color: #ccc;
}

:-ms-input-placeholder {
  color: #ccc;
}

::-ms-input-placeholder {
  color: #ccc;
}

::-moz-placeholder {
  color: #ccc;
}

::placeholder {
  color: #ccc;
}

button {
  border: none;
  cursor: pointer;
}

label {
  cursor: pointer;
}

table {
  border-collapse: collapse;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 16px;
  font-weight: 500;
  margin: 0;
  padding: 0;
}

main {
  display: block;
}

dl, dt, dd {
  padding: 0;
  margin: 0;
}

@media screen and (min-width: 1140px) {
  .sp {
    display: none !important;
  }
  a[href^="tel:"] {
    pointer-events: none;
  }
  a,
  a::before,
  a::after,
  button {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}
/*------------------------------------------------------------------------------
  reset SP
------------------------------------------------------------------------------*/
@media screen and (max-width: 767px) {
  body {
    font-size: 15px;
    position: relative;
    -webkit-appearance: none;
    -webkit-text-size-adjust: 100%;
  }
  input[type=submit] {
    -webkit-text-size-adjust: 100%;
  }
  input,
  select,
  textarea {
    font-size: 16px !important;
  }
  .pc {
    display: none !important;
  }
}
/*------------------------------------------------------------------------------
  基本設定
------------------------------------------------------------------------------*/
html,
input,
textarea,
select,
button {
  font-family: "Noto Sans JP", sans-serif;
}

.zen-old-mincho-regular {
  font-family: "Zen Old Mincho", serif;
}

.cormorant-garamond {
  font-family: "Cormorant Garamond", serif;
}

.main {
  margin-top: 76px;
}
@media screen and (max-width: 1185px) {
  .main {
    margin-top: 58px;
  }
}

/*------------------------------------------------------------------------------
  wow
------------------------------------------------------------------------------*/
.wow-wrap {
  overflow: hidden;
}

/*------------------------------------------------------------------------------
  wow
------------------------------------------------------------------------------*/
.over-hi {
  overflow: hidden;
}

/*------------------------------------------------------------------------------
  背景グラデーション
------------------------------------------------------------------------------*/
.bg-wrap {
  background: -webkit-gradient(linear, left top, left bottom, from(#F7F7F9), color-stop(rgba(238, 240, 246, 0.93)), to(rgba(229, 234, 244, 0.87)));
  background: linear-gradient(to bottom, #F7F7F9, rgba(238, 240, 246, 0.93), rgba(229, 234, 244, 0.87));
  overflow: hidden;
}
.bg-wrap--no-hidden {
  overflow: unset;
}

/*------------------------------------------------------------------------------
  下層ページ メインコンテンツエリア
------------------------------------------------------------------------------*/
.main-contentWrap {
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .main-contentWrap {
    padding-top: 40px;
  }
}

/*------------------------------------------------------------------------------
  下層ページ 基本
------------------------------------------------------------------------------*/
.page-base__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}

/*------------------------------------------------------------------------------
  優先順位
------------------------------------------------------------------------------*/
.c-front {
  position: relative;
  z-index: 100;
  top: -2px;
}

/*------------------------------------------------------------------------------
  モーダル
------------------------------------------------------------------------------*/
body.modal-open {
  width: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
}

/*------------------------------------------------------------------------------
  固定ページ基本
------------------------------------------------------------------------------*/
.page-base {
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .page-base {
    padding-bottom: 50px;
  }
}

body.modal-open {
  overflow: hidden;
}

/*------------------------------------------------------------------------------
  reCAPTCHA
------------------------------------------------------------------------------*/
.grecaptcha-badge {
  z-index: 9000;
}

/* -----------------------------------------------
* Modules エントリーポイント
-------------------------------------------------- */
.header {
  height: 76px;
  background: #fff;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}
@media screen and (max-width: 1185px) {
  .header {
    height: 58px;
  }
}
.header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 13px 13px 13px 18px;
  gap: 60px;
  height: inherit;
}
@media screen and (max-width: 1440px) {
  .header__inner {
    gap: 20px;
    padding: 13px 10px 13px 10px;
  }
}
@media screen and (max-width: 1185px) {
  .header__inner {
    padding: 0;
    height: auto;
  }
}
.header__logo {
  width: 170px;
}
@media screen and (max-width: 1440px) {
  .header__logo {
    width: 153px;
  }
}
@media screen and (max-width: 1185px) {
  .header__logo {
    position: fixed;
    z-index: 9000;
    top: 10px;
    left: 20px;
  }
}
.header__nav {
  height: 100%;
  -ms-flex-item-align: stretch;
      -ms-grid-row-align: stretch;
      align-self: stretch;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (max-width: 1185px) {
  .header__nav {
    height: auto;
    max-width: 335px;
    width: 100%;
  }
}
.header__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
  height: 100%;
}
@media screen and (max-width: 1250px) {
  .header__list {
    gap: 9px;
  }
}
@media screen and (max-width: 1185px) {
  .header__list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 10%;
  }
}
@media screen and (max-width: 1185px) {
  .header__list .pc {
    display: none;
  }
}
.header__list .sp-menu {
  display: none;
}
@media screen and (max-width: 1185px) {
  .header__list .sp-menu {
    display: block;
  }
}
@media screen and (max-width: 1185px) {
  .header__list .half {
    width: 45%;
  }
}
@media screen and (max-width: 357px) {
  .header__list .half {
    width: 100%;
  }
}
@media screen and (max-width: 1185px) {
  .header__list > li {
    border-bottom: 1px solid #fff;
    padding: 10px 0;
  }
}
.header__list li {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 1185px) {
  .header__list li {
    height: auto;
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    opacity: 0;
    -webkit-transform: translateY(20px);
        -ms-transform: translateY(20px);
            transform: translateY(20px);
    -webkit-transition: opacity 0.6s ease, -webkit-transform 0.6s ease;
    transition: opacity 0.6s ease, -webkit-transform 0.6s ease;
    transition: opacity 0.6s ease, transform 0.6s ease;
    transition: opacity 0.6s ease, transform 0.6s ease, -webkit-transform 0.6s ease;
  }
}
.header__list li.is-visible {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.header__list li.is-fading-out {
  opacity: 0;
}
.header__list a {
  font-weight: 500;
  font-size: 14px;
}
@media screen and (max-width: 1185px) {
  .header__list a {
    color: #fff;
    width: 100%;
  }
}
.header__time {
  font-size: 12px;
  font-weight: 500;
}
.header__btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  margin-left: 28px;
  height: inherit;
}
@media screen and (max-width: 1440px) {
  .header__btns {
    margin-left: 10px;
  }
}
@media screen and (max-width: 1185px) {
  .header__btns {
    display: none;
  }
}
.header__wrap {
  height: inherit;
}
.header__btn {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.header__menu-wrap {
  display: contents;
}
@media screen and (max-width: 1185px) {
  .header__menu-wrap {
    display: block;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.header__position {
  display: contents;
}
@media screen and (max-width: 1185px) {
  .header__position {
    display: block;
    padding: 10px 20px 60px;
    width: 100%;
    max-width: 375px;
    margin: 0 auto;
  }
}
.header__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
}
@media screen and (max-width: 1185px) {
  .header__body {
    position: fixed;
    z-index: 9100;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #23345A;
    -webkit-transition: -webkit-transform 0.8s cubic-bezier(0.33, 1, 0.68, 1);
    transition: -webkit-transform 0.8s cubic-bezier(0.33, 1, 0.68, 1);
    transition: transform 0.8s cubic-bezier(0.33, 1, 0.68, 1);
    transition: transform 0.8s cubic-bezier(0.33, 1, 0.68, 1), -webkit-transform 0.8s cubic-bezier(0.33, 1, 0.68, 1);
    -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
            transform: translateY(100%);
  }
  .header__body.panelactive {
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
  }
  .header__body.panelactive .header__menu-wrap {
    position: fixed;
    z-index: 999;
    width: 100%;
    height: calc(100% - 58px);
    top: 42px;
    overflow: auto;
  }
  .header__body.slide-out-up {
    -webkit-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}

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

.drop-down {
  position: relative;
  font-weight: 500;
  font-size: 14px;
}
.drop-down a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
  font-size: 14px;
}
@media screen and (max-width: 1185px) {
  .drop-down a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    text-align: left;
  }
}
.drop-down__icon {
  margin-left: 4px;
  width: 11px;
  height: 7px;
}
@media screen and (max-width: 1185px) {
  .drop-down__icon {
    display: none;
  }
}
.drop-down__content {
  display: none;
  position: absolute;
  top: 50px;
  left: -50px;
  background: #fff;
  z-index: 100;
  padding: 10px 20px;
  width: 400px;
}
@media screen and (max-width: 1185px) {
  .drop-down__content {
    background: none;
    display: block;
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    padding: 10px 0 10px 20px;
  }
}
@media screen and (max-width: 1185px) {
  .drop-down__item {
    list-style: disc;
    display: list-item !important;
  }
}
@media screen and (max-width: 1185px) {
  .drop-down__item::marker {
    color: #fff;
  }
}
.drop-down__item + .drop-down__item {
  margin-top: 10px;
}
@media screen and (max-width: 1185px) {
  .drop-down__list {
    list-style: list-item !important;
    margin-left: 2em;
  }
}

.open-btn {
  display: none;
}
@media screen and (max-width: 1185px) {
  .open-btn {
    display: block;
    position: fixed;
    top: 18px;
    right: 20px;
    z-index: 9999;
    cursor: pointer;
    width: 34px;
    height: 22px;
  }
  .open-btn span {
    display: inline-block;
    -webkit-transition: background-color 1s ease, -webkit-transform 0.8s ease;
    transition: background-color 1s ease, -webkit-transform 0.8s ease;
    transition: transform 0.8s ease, background-color 1s ease;
    transition: transform 0.8s ease, background-color 1s ease, -webkit-transform 0.8s ease;
    position: absolute;
    left: 0;
    height: 2px;
    background: #1056B2;
    width: 100%;
  }
  .open-btn span:nth-last-of-type(1) {
    top: 0;
  }
  .open-btn span:nth-last-of-type(2) {
    top: 11px;
  }
  .open-btn span:nth-last-of-type(3) {
    top: 22px;
  }
  .open-btn.active span {
    background: #fff;
  }
  .open-btn.active span:nth-last-of-type(1) {
    top: 4px;
    left: 0;
    -webkit-transform: translateY(6px) rotate(-45deg);
        -ms-transform: translateY(6px) rotate(-45deg);
            transform: translateY(6px) rotate(-45deg);
  }
  .open-btn.active span:nth-last-of-type(2) {
    opacity: 0;
  }
  .open-btn.active span:nth-last-of-type(3) {
    top: 4px;
    left: 0;
    -webkit-transform: translateY(6px) rotate(45deg);
        -ms-transform: translateY(6px) rotate(45deg);
            transform: translateY(6px) rotate(45deg);
  }
}

.footer__main {
  background: #23345A;
}
.footer__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 75px;
  padding-bottom: 90px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 1139px) {
  .footer__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    padding-top: 40px;
    padding-bottom: 70px;
  }
}
@media screen and (max-width: 1139px) {
  .footer__info {
    margin-top: 50px;
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
  }
}
.footer__img {
  width: 278px;
}
.footer__company {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.9;
  letter-spacing: 0.04em;
  color: #fff;
  margin-top: 37px;
}
@media screen and (max-width: 767px) {
  .footer__company {
    margin-top: 20px;
  }
}
.footer__address-title {
  font-weight: 400;
  font-size: 16px;
  line-height: 1.9;
  letter-spacing: 0.04em;
  color: #fff;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .footer__address-title {
    margin-top: 10px;
  }
}
.footer__address {
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #fff;
  margin-top: 6px;
}
@media screen and (max-width: 767px) {
  .footer__address {
    margin-top: 4px;
  }
}
.footer__sns-box {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .footer__sns-box {
    margin-top: 40px;
  }
}
.footer__sns {
  width: 34px;
}
.footer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 100px;
}
@media screen and (max-width: 1139px) {
  .footer__nav {
    gap: 50px;
  }
}
@media screen and (max-width: 767px) {
  .footer__nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
}
.footer__nav a {
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border-bottom: 1px solid transparent;
}
.footer__nav a:hover {
  border-bottom: 1px solid #fff;
}
.footer__list {
  width: 276px;
}
@media screen and (max-width: 1139px) {
  .footer__list {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: 100%;
  }
}
.footer__item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.26);
  padding: 30px 0;
}
.footer__child-list {
  margin-left: 4em;
  margin-top: 26px;
  list-style: disc;
}
.footer__child-item + .footer__child-item {
  margin-top: 24px;
}
.footer__child-item::marker {
  color: #fff;
}
.footer__copy {
  padding: 13px;
  text-align: center;
  background: #F2F6F8;
  font-size: 12px;
  letter-spacing: 0.04em;
  line-height: 1;
}

.single-webinar .footer__inner {
  margin-left: max((100vw - 1280px) / 2, 0px);
  width: min(1280px, 100vw - 420px - max((100vw - 1280px) / 2, 0px));
}
@media screen and (max-width: 1250px) {
  .single-webinar .footer__inner {
    margin-left: auto;
    width: 100%;
  }
}
@media screen and (max-width: 1600px) {
  .single-webinar .footer__nav {
    gap: 50px;
  }
}
@media screen and (max-width: 1440px) {
  .single-webinar .footer__nav {
    gap: 3%;
  }
}
@media screen and (max-width: 1250px) {
  .single-webinar .footer__nav {
    gap: 100px;
  }
}
@media screen and (max-width: 1139px) {
  .single-webinar .footer__nav {
    gap: 50px;
  }
}
@media screen and (max-width: 767px) {
  .single-webinar .footer__nav {
    gap: 0;
  }
}

.util-title {
  font-size: 38px;
  line-height: 1.4;
  font-family: "Zen Old Mincho", serif;
  color: #1056B2;
  font-weight: 900;
  position: relative;
  padding-bottom: 34px;
}
@media screen and (max-width: 767px) {
  .util-title {
    font-size: 32px;
    padding-bottom: 22px;
  }
}
.util-title::after {
  content: attr(data-en);
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: 20px;
  letter-spacing: 0.04em;
  font-weight: 700;
  color: #7B9ED7;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767px) {
  .util-title::after {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .util-title--sp-center {
    text-align: center;
    width: 100%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .util-title--sp-center::after {
    width: 100%;
    text-align: center;
  }
}
.util-title--white {
  color: #fff;
}
.util-title--white::after {
  color: #fff;
  opacity: 0.65;
}
.util-title span {
  display: block;
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 5px;
}

@media screen and (max-width: 767px) {
  body:not(.home) .util-title {
    font-size: 26px;
  }
}
@media screen and (max-width: 767px) {
  body:not(.home) .util-title::after {
    bottom: -8px;
  }
}

.icon-btn {
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.04em;
  padding: 18px 0;
  width: 172px;
  border-radius: 4px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  line-height: 1;
  position: relative;
  z-index: 0;
}
.icon-btn--mail {
  text-indent: 7px;
}
.icon-btn--mail::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 14px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/icon-mail_white.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 12px;
}
.icon-btn--file {
  text-indent: 14px;
  background: #fff;
}
.icon-btn--file::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 14px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/icon-file_blue.svg) no-repeat;
  background-size: contain;
  width: 12px;
  height: 15px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.icon-btn--file:hover::before {
  background: url(../img/common/icon-file_white.svg) no-repeat;
  background-size: contain;
}
.icon-btn--type01 {
  background-image: -webkit-gradient(linear, left bottom, left top, from(#1056B2), to(#1079B2));
  background-image: linear-gradient(to top, #1056B2, #1079B2);
  color: #fff;
}
.icon-btn--type01::after {
  position: absolute;
  content: "";
  inset: 0;
  z-index: -1;
  background: #1079B2;
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  border-radius: 4px;
}
.icon-btn--type01:hover {
  color: #fff;
}
.icon-btn--type01:hover::after {
  opacity: 1;
}
.icon-btn--type02 {
  color: #1056B2;
  border: 2px solid #1056B2;
}
.icon-btn--type02:hover {
  background: #1056B2;
  color: #fff;
}
.icon-btn--type03 {
  background: #fff;
  color: #1056B2;
  border: 2px solid #fff !important;
  -webkit-box-shadow: 0 0 22px rgba(5, 33, 66, 0.26);
          box-shadow: 0 0 22px rgba(5, 33, 66, 0.26);
}
.icon-btn--type03:hover {
  opacity: 0.8;
}
.icon-btn--type03.icon-btn--mail::before {
  background: url(../img/common/icon-mail_blue.svg) no-repeat;
  background-size: contain;
}
.icon-btn--type03.icon-btn--mail span::after {
  background: url(../img/common/arrow-right_blue.svg) no-repeat !important;
  background-size: contain;
}
.icon-btn--type04 {
  background: transparent;
  color: #fff;
  border: 2px solid #fff !important;
  -webkit-box-shadow: 0 0 22px rgba(5, 33, 66, 0.26);
          box-shadow: 0 0 22px rgba(5, 33, 66, 0.26);
}
.icon-btn--type04:hover {
  color: #fff;
  background: #1079B2;
  border-color: #1079B2 !important;
}
.icon-btn--type04.icon-btn--file::before {
  background: url(../img/common/icon-file_white.svg) no-repeat;
  background-size: contain;
}
.icon-btn--type04.icon-btn--file span::after {
  background: url(../img/common/arrow-right_white.svg) no-repeat !important;
  background-size: contain;
}

.icon-btn2 {
  width: 62px;
  height: 29px;
  border: 1px solid #1056B2;
  border-radius: 4px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.icon-btn2 svg {
  fill: #1056B2;
}

.util-btn {
  background: #1056B2;
  color: #fff;
  border-radius: 4px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.04em;
  padding: 25px 24px;
  max-width: 300px;
  width: 100%;
  display: block;
  -webkit-box-shadow: 0 0 22px 0 rgba(5, 33, 66, 0.26);
          box-shadow: 0 0 22px 0 rgba(5, 33, 66, 0.26);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .util-btn {
    margin: 0 auto;
  }
}
.util-btn:hover {
  background: #1079B2;
  color: #fff;
}
.util-btn span {
  position: relative;
  width: 100%;
  display: inline-block;
}
.util-btn span::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
  width: 17px;
  height: 11px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.util-btn--white {
  background: #fff;
  color: #1056B2;
}
.util-btn--white span::after {
  background: url(../img/common/arrow-right_blue.svg) no-repeat;
  background-size: contain;
}
.util-btn--white:hover {
  background: #1056B2;
  color: #fff;
}
.util-btn--white:hover span::after {
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
}
.util-btn--white2 {
  background: #fff;
  color: #1056B2;
  border: 1px solid #1056B2;
  -webkit-box-shadow: 0 0 18px rgba(5, 33, 66, 0.18);
          box-shadow: 0 0 18px rgba(5, 33, 66, 0.18);
}
.util-btn--white2 span::after {
  background: url(../img/common/arrow-right_blue.svg) no-repeat;
  background-size: contain;
}
.util-btn--white2:hover {
  background: #1056B2;
  color: #fff;
}
.util-btn--white2:hover span::after {
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
}
.util-btn--back span::after {
  content: "";
  position: absolute;
  left: 0;
  top: 30%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
  width: 17px;
  height: 11px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.card01 {
  border-radius: 4px;
  padding: 42px 0;
  border-top: 1px solid #7B9ED7;
}
@media screen and (max-width: 767px) {
  .card01 {
    padding: 40px 0;
  }
}
.card01__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 3%;
}
@media screen and (max-width: 1139px) {
  .card01__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.card01__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (max-width: 1139px) {
  .card01__body {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    padding: 20px 20px 0;
    width: 100%;
  }
}
.card01__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 30px;
  gap: 10%;
}
@media screen and (max-width: 767px) {
  .card01__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px;
    margin-top: 20px;
  }
}
.card01__main {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.card01__num {
  font-size: 20px;
  font-family: "Cormorant Garamond", serif;
  color: #1056B2;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  position: relative;
  padding-left: 23px;
}
@media screen and (max-width: 767px) {
  .card01__num {
    font-size: 18px;
  }
}
.card01__num::before {
  content: "";
  position: absolute;
  bottom: 10px;
  left: 0;
  width: 8px;
  height: 8px;
  background: linear-gradient(135deg, #1778F7 0%, #1363CC 20%, #1056B2 51%);
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.card01__num span {
  font-size: 42px;
}
@media screen and (max-width: 767px) {
  .card01__num span {
    font-size: 34px;
  }
}
.card01__label {
  font-size: 21px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1;
  color: #1056B2;
}
.card01__title {
  font-size: 36px;
  color: #1056B2;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .card01__title {
    font-size: 24px;
    margin-top: 14px;
  }
}
.card01__img {
  width: 30%;
  overflow: hidden;
}
@media screen and (max-width: 1139px) {
  .card01__img {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 100%;
    aspect-ratio: 355/163;
  }
}
.card01__img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.card01__text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.9;
  text-align: justify;
}
@media screen and (max-width: 767px) {
  .card01__text {
    margin-top: 0;
    line-height: 1.7;
  }
}

.card02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .card02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.card02 a {
  padding: 20px;
}
.card02__img-box {
  position: relative;
}
.card02__img {
  border-radius: 4px;
  overflow: hidden;
}
.card02__img img {
  aspect-ratio: 390/235;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.card02__btn {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: #1056B2;
  width: 60px;
  border-radius: 4px;
  padding: 2px 3px 4px;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .card02__btn {
    width: 47px;
  }
}
.card02__btn svg {
  fill: #fff;
}
@media screen and (max-width: 767px) {
  .card02__btn svg {
    width: 13px;
  }
}
.card02__body {
  margin-top: 14px;
}
@media screen and (max-width: 767px) {
  .card02__body {
    margin-top: 12px;
  }
}
.card02__tag {
  border: 1px solid #1056B2;
  border-radius: 2px;
  background: #fff;
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 2px 5px;
  color: #1056B2;
}
@media screen and (max-width: 767px) {
  .card02__tag {
    font-size: 14px;
  }
}
.card02__title {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .card02__title {
    margin-top: 8px;
    font-size: 16px;
  }
}
.card02__name {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.5;
  margin-top: 18px;
}
@media screen and (max-width: 767px) {
  .card02__name {
    margin-top: 8px;
  }
}
.card02__time {
  color: #757575;
  font-size: 14px;
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-weight: 400;
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .card02__time {
    margin-top: 2px;
  }
}
.card02:hover {
  -webkit-box-shadow: 0 4px 20px 0 rgba(5, 33, 66, 0.12);
          box-shadow: 0 4px 20px 0 rgba(5, 33, 66, 0.12);
  z-index: 10;
}
.card02 a:hover {
  color: #1B1C1D;
}
.card02 a:hover .card02__btn {
  background: #1079B2;
}
.card02 a:hover .card02__img img {
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}
.card02__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 18px;
}

.card03 {
  width: 400px;
}
.card03__img-box {
  position: relative;
}
.card03__img {
  overflow: hidden;
}
.card03__img img {
  width: 400px;
  height: 376px;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 1139px) {
  .card03__img img {
    width: 100%;
    height: auto;
  }
}
.card03__btn {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: #1056B2;
  width: 60px;
  border-radius: 4px;
  padding: 2px 3px 4px;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .card03__btn {
    width: 47px;
  }
}
.card03__btn svg {
  fill: #fff;
}
@media screen and (max-width: 767px) {
  .card03__btn svg {
    width: 13px;
  }
}
.card03__tag {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.04em;
  color: #fff;
  padding: 8px;
  background: #7B9ED7;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .card03__tag {
    font-size: 16px;
  }
}
.card03__body {
  background: #fff;
  padding: 20px 20px 30px;
}
@media screen and (max-width: 767px) {
  .card03__body {
    padding: 12px 16px 22px;
  }
}
.card03__position {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.9;
  color: #757575;
  position: relative;
}
.card03__name-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 20px;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .card03__name-box {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8px;
  }
}
.card03__name {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .card03__name {
    font-size: 20px;
  }
}
.card03__name--en {
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #7B9ED7;
}
.card03:not(.card03--top):hover .card03__btn {
  background: #1079B2;
}
.card03:not(.card03--top):hover .card03__img img {
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}
.card03:not(.card03--top):hover .card03__img img {
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}
.card03--top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.card03--top .card03__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.card03--top .card03__position {
  margin-bottom: 10px;
}
.card03--top .card03__name-box {
  margin-top: auto;
}
@media screen and (max-width: 767px) {
  .card03--top .card03__img img {
    aspect-ratio: 400/376;
  }
}
.card03.js-modal {
  cursor: pointer;
}
.card03-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100%;
  z-index: 6000;
  display: none;
}
.card03-modal__bg {
  background: rgba(27, 28, 29, 0.36);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.card03-modal__content {
  max-width: 1250px;
  position: relative;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: #fff;
  width: calc(100% - 20px);
  height: 70vh;
  padding: 80px 75px;
}
@media screen and (max-width: 767px) {
  .card03-modal__content {
    padding: 20px;
    height: 75vh;
    top: 54%;
  }
}
.card03-modal__inner {
  max-height: 100%; /* 高さ制限 */
  overflow-y: auto; /* スクロール可能にする */
}
.card03-modal__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 60px;
}
@media screen and (max-width: 767px) {
  .card03-modal__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 16px;
  }
}
.card03-modal__body .card03__body {
  padding: 0;
}
.card03-modal__body .card03__tag {
  position: unset;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.card03-modal__body .card03__position {
  margin-top: 20px;
  padding-right: 50px;
}
.card03-modal__img {
  width: 39.273%;
}
@media screen and (max-width: 767px) {
  .card03-modal__img {
    width: 100%;
  }
}
.card03-modal__img img {
  aspect-ratio: 432/490;
  -o-object-fit: cover;
     object-fit: cover;
}
.card03-modal__info {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
}
.card03-modal__scroll {
  overflow-y: auto; /* スクロール可能にする */
}
@media screen and (max-width: 767px) {
  .card03-modal__scroll {
    overflow: unset;
    max-height: unset;
  }
}
.card03-modal__main, .card03-modal__career-main {
  font-weight: 500;
  line-height: 2;
}
.card03-modal__main {
  margin-top: 40px;
}
.card03-modal__career-main {
  margin-top: 20px;
}
.card03-modal__career {
  margin-top: 30px;
  padding-top: 30px;
  border-top: 1px solid #7B9ED7;
}
.card03-modal__career-title {
  font-weight: bold;
  font-size: 22px;
  line-height: 1;
  color: #1056B2;
}
.card03-modal__close-link {
  margin-top: 40px;
  color: #1056B2;
  padding-bottom: 4px;
  border-bottom: 1px solid #1056B2;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  padding-right: 77px;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.card03-modal__close-link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/arrow-right_blue.svg) no-repeat;
  background-size: contain;
  width: 17px;
  height: 11px;
}
.card03-modal__close-link:hover {
  opacity: 0.7;
}
.card03-modal__close {
  width: 50px;
  height: 50px;
  position: absolute;
  top: 30px;
  right: 30px;
}
@media screen and (max-width: 767px) {
  .card03-modal__close {
    top: 10px;
    right: 10px;
  }
}
.card03-modal__close-btn {
  width: 50px;
  height: 50px;
  position: relative;
  border: 1px solid #1056B2;
  z-index: 1000;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.card03-modal__close-btn:hover {
  opacity: 0.7;
}
.card03-modal__close-btn span {
  width: 80%;
  height: 1px;
  background: #1056B2;
  display: inline-block;
  position: absolute;
  left: 10%;
  top: 25px;
}
.card03-modal__close-btn span:nth-child(1) {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.card03-modal__close-btn span:nth-child(2) {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.card03-modal__scroll-line {
  display: none;
}
@media screen and (max-width: 767px) {
  .card03-modal__scroll-line {
    display: block;
    position: absolute;
    right: 0;
    top: 25px;
  }
}

.border {
  content: "";
  display: inline-block;
  width: 20px;
  height: 1px;
  vertical-align: middle;
}

.l-section-top {
  width: 100%;
  height: 100%;
  position: relative;
}

.l-section-container {
  width: 100%;
  height: 100%;
  position: relative;
  top: 0;
  bottom: 0;
  margin: auto;
  overflow: hidden;
}

.c-title {
  margin: 0;
  color: #1056B2;
  text-align: center;
}

.c-scrolldown {
  width: 1px;
  height: 60px;
  position: absolute;
  top: 30px;
  left: 0;
  right: 0;
  margin: 0 auto;
  overflow: hidden;
}
.c-scrolldown .c-line {
  width: 100%;
  height: 100%;
  display: block;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #1056b2), color-stop(50%, rgba(16, 86, 178, 0)));
  background: linear-gradient(to bottom, #1056b2 50%, rgba(16, 86, 178, 0) 50%);
  background-position: 0 -60px;
  background-size: 100% 200%;
  -webkit-animation: scrolldown 2.2s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
          animation: scrolldown 2.2s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
}

@-webkit-keyframes scrolldown {
  0% {
    background-position: 0 -60px;
  }
  75% {
    background-position: 0 0;
  }
  100% {
    background-position: 0 60px;
  }
}

@keyframes scrolldown {
  0% {
    background-position: 0 -60px;
  }
  75% {
    background-position: 0 0;
  }
  100% {
    background-position: 0 60px;
  }
}
.js-slider2 .slick-slide {
  max-width: none !important;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding: 0 6.5px; /* 画像同士の余白を作る */
}

.card04 {
  background: #fff;
  padding: 20px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .card04 {
    padding: 15px 20px;
  }
}
.card04__img-box {
  position: relative;
}
.card04__img {
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .card04__img {
    aspect-ratio: 335/170;
    width: 100%;
  }
}
.card04__img img {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.card04__btn {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: #1056B2;
  width: 60px;
  border-radius: 4px;
  padding: 2px 3px 4px;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .card04__btn {
    width: 47px;
    padding: 0 3px;
  }
}
.card04__btn svg {
  fill: #fff;
}
@media screen and (max-width: 767px) {
  .card04__btn svg {
    width: 13px;
  }
}
.card04__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 18px;
  margin-top: 14px;
}
.card04__time {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
.card04__tag {
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #1056B2;
  border: 1px solid #1056B2;
  border-radius: 2px;
  padding: 6px;
}
.card04__title {
  margin-top: 10px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-align: justify;
}
@media screen and (max-width: 767px) {
  .card04__title {
    margin-top: 8px;
    font-size: 16px;
  }
}
.card04:hover {
  -webkit-box-shadow: 0 4px 20px 0 rgba(5, 33, 66, 0.12);
          box-shadow: 0 4px 20px 0 rgba(5, 33, 66, 0.12);
  z-index: 10;
}
.card04 a:hover {
  color: #1B1C1D;
}
.card04 a:hover .card04__btn {
  background: #1079B2;
}
.card04 a:hover .card04__img img {
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}

.card05__item {
  background: #fff;
  border: 1px solid #7B9ED7;
  padding: 50px 56px;
  border-radius: 4px;
  position: relative;
}
@media screen and (max-width: 1139px) {
  .card05__item {
    padding: 35px;
  }
}
@media screen and (max-width: 767px) {
  .card05__item {
    padding: 22px 20px;
  }
}
.card05__item::after {
  content: "";
  position: absolute;
  bottom: -32px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 21px solid transparent;
  border-left: 21px solid transparent;
  border-top: 20px solid #7B9ED7;
  border-bottom: 0;
}
@media screen and (max-width: 767px) {
  .card05__item::after {
    bottom: -26px;
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 15px solid transparent;
    border-left: 15px solid transparent;
    border-top: 14px solid #7B9ED7;
    border-bottom: 0;
  }
}
.card05__item:last-child::after {
  content: none;
}
.card05__item + .card05__item {
  margin-top: 44px;
}
@media screen and (max-width: 767px) {
  .card05__item + .card05__item {
    margin-top: 38px;
  }
}
.card05__label {
  background: #1056B2;
  display: inline-block;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.5;
  color: #fff;
  padding: 2px 7px;
}
@media screen and (max-width: 767px) {
  .card05__label {
    font-size: 16px;
  }
}
.card05__title {
  margin-top: 16px;
  line-height: 1.4;
  font-size: 26px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .card05__title {
    margin-top: 14px;
    font-size: 18px;
  }
}
.card05__child-list {
  margin-top: 22px;
  background: #F2F6F8;
  border-radius: 4px;
  padding: 20px 24px;
}
@media screen and (max-width: 767px) {
  .card05__child-list {
    padding: 20px 16px;
  }
}
.card05__child-item {
  padding: 14px 0;
  font-weight: 500;
  line-height: 1.3;
  border-bottom: 1px solid #7B9ED7;
}
.card05__child-item:first-child {
  padding-top: 0;
}
.card05__child-item:last-child {
  padding-bottom: 0;
  border: none;
}

.card06 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .card06 {
    gap: 60px;
  }
}
.card06__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .card06__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 28px;
  }
}
.card06__img {
  max-width: 460px;
  width: 48%;
  -webkit-box-shadow: -2px 0 30px rgba(5, 33, 66, 0.1);
          box-shadow: -2px 0 30px rgba(5, 33, 66, 0.1);
}
@media screen and (max-width: 767px) {
  .card06__img {
    max-width: 100%;
    width: 100%;
  }
}
.card06__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.card06__label {
  color: #7B9ED7;
  font-family: "Cormorant Garamond", serif;
  font-weight: bold;
  letter-spacing: 0.04em;
}
.card06__label span {
  margin-left: 12px;
  padding-left: 63px;
  position: relative;
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  font-weight: 500;
}
.card06__label span::before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  width: 51px;
  height: 1px;
  background: #7B9ED7;
}
.card06__title {
  margin-top: 18px;
  font-size: 32px;
  font-weight: bold;
  line-height: 1.5;
  color: #1056B2;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 767px) {
  .card06__title {
    font-size: 26px;
  }
}
.card06__title span {
  color: #E87800;
}
.card06__text {
  margin-top: 14px;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .card06__text {
    line-height: 1.8;
  }
}

.card07 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
}
.card07__item {
  background: #fff;
  padding: 32px 50px 50px;
  border-radius: 4px;
}
@media screen and (max-width: 767px) {
  .card07__item {
    padding: 20px 10px;
  }
}
.card07__title {
  color: #1056B2;
  font-size: 32px;
  font-family: "Zen Old Mincho", serif;
  font-weight: bold;
  line-height: 1.5;
  padding-left: 45px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .card07__title {
    font-size: 24px;
    padding-left: 28px;
  }
}
.card07__title::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 6px;
  background: linear-gradient(45deg, rgb(23, 120, 247) 0%, rgb(19, 99, 204) 20%, rgb(16, 86, 178) 51%, rgb(16, 86, 178) 100%);
  width: 24px;
  height: 24px;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .card07__title::before {
    width: 12px;
    height: 12px;
  }
}
.card07__title span {
  color: #E87800;
}
.card07__box {
  margin-top: 20px;
  border-top: 1px solid #7B9ED7;
  padding-top: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 30px;
}
@media screen and (max-width: 767px) {
  .card07__box {
    padding-top: 20px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
  }
}
.card07__info {
  background: #f2f6f8;
  padding-top: 10px;
  max-width: 295px;
  width: 35%;
}
@media screen and (max-width: 767px) {
  .card07__info {
    width: 100%;
    max-width: 100%;
  }
}
.card07__sub-title {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
.card07__img {
  margin-top: 11px;
}
@media screen and (max-width: 767px) {
  .card07__img {
    margin-top: 10px;
  }
}
.card07__wrap {
  padding: 24px;
}
@media screen and (max-width: 767px) {
  .card07__wrap {
    padding: 14px 10px;
  }
}
.card07__sub-title2 {
  font-size: 26px;
  font-weight: 900;
  line-height: 1;
  font-family: "Zen Old Mincho", serif;
  color: #1056B2;
  margin-top: 10px;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .card07__sub-title2 {
    margin-bottom: 16px;
  }
}
.card07__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.ba-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 33px;
}
.ba-box__content {
  padding: 20px 30px;
}
@media screen and (max-width: 767px) {
  .ba-box__content {
    padding: 16px;
  }
}
.ba-box__icons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
}
.ba-box__icon {
  width: 35px;
}
.ba-box__title {
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
}
.ba-box__text {
  font-weight: 500;
  line-height: 1.6;
}
.ba-box__before {
  background: #f2f6f8;
  position: relative;
}
.ba-box__before::after {
  content: "";
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: -23px;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 43px solid transparent;
  border-left: 43px solid transparent;
  border-top: 43px solid #f2f6f8;
  border-bottom: 0;
}
.ba-box__before .ba-box__text span {
  color: #1056B2;
  font-weight: bold;
}
.ba-box__after {
  background: #FEF7F0;
}
.ba-box__after .ba-box__text span {
  color: #E87800;
  font-weight: bold;
}

.card08 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 12px;
}
@media screen and (max-width: 767px) {
  .card08 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.card08__item {
  width: calc((100% - 24px) / 3);
  border: 1px dashed #7B9ED7;
  border-radius: 4px;
  padding: 22px 10px;
}
@media screen and (max-width: 767px) {
  .card08__item {
    width: 100%;
  }
}
.card08__text {
  text-align: center;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .card08__text {
    line-height: 1.6;
  }
}

.card09 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 33px 0;
}
@media screen and (max-width: 1139px) {
  .card09 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 37px;
  }
}
.card09__item {
  width: calc((100% - 61px) / 2);
  background: #fff;
  position: relative;
  -webkit-box-shadow: 0 2px 8px 0 rgba(5, 33, 66, 0.12);
          box-shadow: 0 2px 8px 0 rgba(5, 33, 66, 0.12);
  padding: 20px 30px;
}
@media screen and (max-width: 1139px) {
  .card09__item {
    width: 100%;
    padding: 20px 10px;
  }
}
.card09__item::after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -24px;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 10px solid #7B9ED7;
  border-right: 0;
}
@media screen and (max-width: 1139px) {
  .card09__item::after {
    top: auto;
    bottom: -28px;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(90deg);
        -ms-transform: translateX(-50%) rotate(90deg);
            transform: translateX(-50%) rotate(90deg);
  }
}
.card09__item:nth-child(even) {
  margin-right: 23px;
}
.card09__item:last-child::after {
  content: none;
}
.card09__item:nth-of-type(1) .card09__label {
  background: #17A9F7;
}
.card09__item:nth-of-type(1) .card09__icon {
  width: 43px;
}
.card09__item:nth-of-type(2) .card09__label {
  background: linear-gradient(112deg, rgb(23, 169, 247) 0%, rgb(23, 120, 247) 100%);
}
.card09__item:nth-of-type(2) .card09__icon {
  width: 33px;
}
.card09__item:nth-of-type(3) .card09__label {
  background: #1778F7;
}
.card09__item:nth-of-type(3) .card09__icon {
  width: 48px;
}
.card09__item:nth-of-type(4) .card09__label {
  background: linear-gradient(112deg, rgb(23, 120, 247) 0%, rgb(16, 86, 178) 100%);
}
.card09__item:nth-of-type(4) .card09__icon {
  width: 47px;
}
.card09__item:nth-of-type(5) .card09__label {
  background: #1056B2;
}
.card09__item:nth-of-type(5) .card09__icon {
  width: 37px;
}
.card09__label {
  position: absolute;
  top: -12px;
  left: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  line-height: 0.5;
  letter-spacing: 0.04em;
  font-weight: 500;
  display: inline-block;
  color: #fff;
  width: 62px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 3px 2px 10px;
  clip-path: polygon(0 0, 85% 0, 100% 50%, 85% 100%, 0 100%);
}
.card09__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 1139px) {
  .card09__wrap {
    gap: 16px;
  }
}
.card09__icons {
  text-align: center;
  width: 45%;
}
@media screen and (max-width: 1139px) {
  .card09__icons {
    width: 37%;
  }
}
.card09__icon {
  margin: 0 auto;
}
.card09__title {
  margin-top: 30px;
  font-weight: bold;
  font-size: 17px;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color: #1056B2;
}
.card09__span {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.3;
  background: #f2f6f8;
  display: inline-block;
  padding: 4px 15px;
  margin-top: 10px;
}
.card09__child-list {
  width: 53%;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  list-style: disc;
  list-style-position: inside;
}
@media screen and (max-width: 1139px) {
  .card09__child-list {
    width: 65%;
  }
}
.card09__child-list li {
  text-indent: -1.2em;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.3;
  padding: 12px 0 12px 1.8em;
  border-bottom: 1px solid rgba(123, 158, 215, 0.4);
}
.card09__child-list li:first-child {
  padding-top: 12px;
}
.card09__child-list li:last-child {
  padding-bottom: 12px;
  border: none;
}

.card10 {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.card10__title {
  position: absolute;
  top: -1em;
  left: 0;
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #fff;
  background: #1056B2;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 11px 21px;
}
.card10__list {
  list-style: disc;
  list-style-position: inside;
  margin-top: 12px;
  min-height: 61px;
}
.card10__item {
  border-bottom: 1px solid rgba(123, 158, 215, 0.4);
  padding-bottom: 12px;
  padding-left: 1.8em;
  text-indent: -1.4em;
  font-weight: 500;
  line-height: 1.5;
}
.card10__wrap + .card10__wrap {
  margin-top: 26px;
}
.card10__sub-title {
  font-weight: 500;
  line-height: 1.3;
  background: rgba(123, 158, 215, 0.24);
  max-width: 83px;
  padding: 2px;
  text-align: center;
}
.card10__body {
  background: #fff;
  padding: 24px 24px 50px;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .card10__body {
    padding: 20px;
  }
}
.card10__text {
  margin-top: 10px;
  font-weight: 500;
  line-height: 1.5;
}
.card10__annotation {
  margin-top: 4px;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.5;
}

.js-slider2__navigation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 38px;
  margin-top: 38px;
}
.js-slider2__navigation .slick-slide {
  max-width: none !important;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding: 0 6.5px; /* 画像同士の余白を作る */
}
.js-slider2__navigation .slide-dots {
  margin: 0;
  padding: 0;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 14px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.js-slider2__navigation .slide-dots li {
  display: inline-block;
}
.js-slider2__navigation .slide-dots li button {
  position: relative;
  text-indent: -9999px;
}
.js-slider2__navigation .slide-dots li button::before {
  background: #7B9ED7;
  border-radius: 10px;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  cursor: pointer;
  height: 7px;
  left: 0;
  margin: auto;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 7px;
}
.js-slider2__navigation .slide-dots li.slick-active button::before {
  background: #1056B2;
}
.js-slider2__navigation .slide-arrow {
  background: #7B9ED7;
  width: 62px;
  height: 31px;
  border-radius: 4px;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.js-slider2__navigation .slide-arrow:hover {
  background: #1056B2;
}
.js-slider2__navigation .slide-arrow span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 17px;
  height: 10px;
}
.js-slider2__navigation .slide-arrow.prev-arrow span {
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
  -webkit-transform: translate(-50%, -50%) rotate(180deg);
      -ms-transform: translate(-50%, -50%) rotate(180deg);
          transform: translate(-50%, -50%) rotate(180deg);
}
.js-slider2__navigation .slide-arrow.next-arrow {
  margin-left: 7px;
}
.js-slider2__navigation .slide-arrow.next-arrow span {
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.list {
  width: calc(100% + 40px);
  margin-left: -20px;
}
@media screen and (max-width: 767px) {
  .list {
    width: 100%;
    margin: 0 auto;
  }
}
.list__item {
  border-top: 1px solid rgba(123, 158, 215, 0.4);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.list__item:hover {
  border-top: 1px solid transparent;
}
.list__item.is-hover + .list__item {
  border-top: 1px solid transparent;
}
.list__item:last-child {
  border-bottom: 1px solid rgba(123, 158, 215, 0.4);
}
.list__item:last-child:hover {
  border-bottom: 1px solid transparent;
}
.list__item a {
  padding: 30px 20px;
  display: block;
}
@media screen and (max-width: 767px) {
  .list__item a {
    padding: 20px 0;
  }
}
.list__item a:hover {
  color: #1B1C1D;
  -webkit-box-shadow: 0 4px 20px 0 rgba(5, 33, 66, 0.12);
          box-shadow: 0 4px 20px 0 rgba(5, 33, 66, 0.12);
  z-index: 10;
}
.list__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 18px;
}
@media screen and (max-width: 767px) {
  .list__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.list__child-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 18px;
}
@media screen and (max-width: 767px) {
  .list__child-wrap {
    gap: 10px;
  }
}
.list__child-wrap2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 50px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (max-width: 767px) {
  .list__child-wrap2 {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    gap: 10px;
  }
}
.list__time {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #757575;
}
.list__tag {
  font-size: 14px;
  color: #1056B2;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  border: 1px solid #1056B2;
  padding: 6px;
  border-radius: 2px;
}
.list__title {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.02em;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (max-width: 767px) {
  .list__title {
    font-size: 16px;
  }
}
@media screen and (max-width: 767px) {
  .list__btn {
    width: 47px;
  }
}
@media screen and (max-width: 767px) {
  .list__btn svg {
    width: 13px;
  }
}

.list02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10%;
}
@media screen and (max-width: 1139px) {
  .list02 {
    gap: 30px;
  }
}
@media screen and (max-width: 767px) {
  .list02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.list02__num {
  color: #7B9ED7;
  font-family: "Cormorant Garamond", serif;
  font-size: 20px;
  letter-spacing: 0.04em;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .list02__num {
    font-size: 18px;
    margin-top: 18px;
  }
}
.list02__num span {
  display: inline-block;
  padding-left: 74px;
  position: relative;
  font-size: 32px;
}
.list02__num span::before {
  content: "";
  position: absolute;
  top: 55%;
  left: 12px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  height: 1px;
  width: 50px;
  background: #7B9ED7;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.list02__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.list02__title {
  font-family: "Zen Old Mincho", serif;
  font-size: 38px;
  line-height: 1.5;
  font-weight: bold;
  color: #fff;
  margin-top: 32px;
}
@media screen and (max-width: 1139px) {
  .list02__title {
    font-size: 30px;
  }
}
@media screen and (max-width: 767px) {
  .list02__title {
    margin-top: 18px;
    font-size: 26px;
  }
}
.list02__text {
  font-weight: 500;
  line-height: 2;
  color: #fff;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .list02__text {
    line-height: 1.8;
  }
}
.list02__img {
  width: 52%;
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .list02__img {
    width: 100%;
  }
}

.list03 {
  border-top: 1px solid rgba(123, 158, 215, 0.3);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media screen and (max-width: 767px) {
  .list03 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.list03:before {
  position: absolute;
  content: "";
  width: 31.5%;
  min-width: 390px;
  left: 0;
  top: -1px;
  border-top: 1px solid #7B9ED7;
}
@media screen and (max-width: 767px) {
  .list03:before {
    min-width: 20%;
  }
}
.list03 dt, .list03 dd {
  padding: 90px 0;
}
@media screen and (max-width: 767px) {
  .list03 dt, .list03 dd {
    padding: 0;
  }
}
.list03 dt {
  width: 31.5%;
  min-width: 390px;
  font-family: "Zen Old Mincho", serif;
  font-size: 32px;
  font-weight: 900;
  line-height: 1;
  color: #1056B2;
  position: relative;
  padding-left: 6%;
}
@media screen and (max-width: 1139px) {
  .list03 dt {
    min-width: 250px;
    font-size: 26px;
    padding-left: 3%;
  }
}
@media screen and (max-width: 767px) {
  .list03 dt {
    font-size: 20px;
    padding-left: 0;
    padding-top: 48px;
  }
}
.list03 dt::before {
  content: attr(data-en);
  position: absolute;
  top: 26px;
  left: 0;
  font-size: 90px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 500;
  font-family: "Cormorant Garamond", serif;
  opacity: 0.18;
}
@media screen and (max-width: 1139px) {
  .list03 dt::before {
    font-size: 70px;
    top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .list03 dt::before {
    font-size: 50px;
    top: 16px;
  }
}
.list03 dt span {
  margin-left: 20px;
  padding-left: 20px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .list03 dt span {
    padding-left: 10px;
    margin-left: 10px;
  }
}
.list03 dt span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1px;
  height: 32px;
  background: #1056B2;
}
@media screen and (max-width: 767px) {
  .list03 dt span::before {
    height: 1em;
  }
}
.list03 dd {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding-left: 11%;
  font-family: "Zen Old Mincho", serif;
  font-weight: bold;
  font-size: 28px;
  line-height: 1.7;
}
@media screen and (max-width: 1139px) {
  .list03 dd {
    font-size: 24px;
  }
}
@media screen and (max-width: 767px) {
  .list03 dd {
    font-size: 18px;
    letter-spacing: -0.02em;
    padding-left: 0;
    padding-bottom: 28px;
    margin-top: 16px;
  }
}

.num-list {
  counter-reset: li;
}
.num-list__item {
  position: relative;
  font-size: 24px;
  padding-left: 48px;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .num-list__item {
    font-size: 16px;
    line-height: 1.7;
  }
}
.num-list__item:before {
  position: absolute;
  top: 0;
  left: 0;
  font-weight: bold;
  color: #1056B2;
  line-height: 1;
  counter-increment: li;
  content: "0" counter(li);
  font-size: 32px;
  font-family: "Cormorant Garamond", serif;
}
.num-list__item + .num-list__item {
  margin-top: 52px;
}
@media screen and (max-width: 767px) {
  .num-list__item + .num-list__item {
    margin-top: 16px;
  }
}

.dl-list__wrap {
  border-bottom: 1px solid rgba(123, 158, 215, 0.3);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media screen and (max-width: 767px) {
  .dl-list__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 22px 0;
  }
}
.dl-list__wrap:before {
  position: absolute;
  content: "";
  width: 10%;
  min-width: 150px;
  left: 0;
  bottom: -1px;
  border-bottom: 1px solid #7B9ED7;
}
@media screen and (max-width: 767px) {
  .dl-list__wrap:before {
    min-width: 30%;
  }
}
.dl-list dt, .dl-list dd {
  padding: 22px 0;
}
@media screen and (max-width: 767px) {
  .dl-list dt, .dl-list dd {
    padding: 0;
  }
}
.dl-list dt {
  width: 150px;
  font-size: 18px;
  line-height: 1.4;
  font-weight: bold;
}
.dl-list dd {
  font-size: 18px;
  font-weight: 400;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .dl-list dd {
    margin-top: 12px;
  }
}
.dl-list dd a {
  color: #1056B2;
  border-bottom: 1px solid #1056B2;
  padding-bottom: 4px;
  margin-top: 10px;
  display: inline-block;
}

.text-list {
  list-style: disc;
  margin-left: 10px;
}
.text-list li {
  font-weight: 500;
  font-size: 18px;
  line-height: 2.4;
}
@media screen and (max-width: 767px) {
  .text-list li {
    font-size: 16px;
    line-height: 1.8;
  }
}

.sticky-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 30px;
}
@media screen and (max-width: 767px) {
  .sticky-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
  }
}
.sticky-content__head {
  position: sticky;
  top: 100px;
  height: 100%;
}
@media screen and (max-width: 1139px) {
  .sticky-content__head {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media screen and (max-width: 767px) {
  .sticky-content__head {
    position: unset;
  }
}
@media screen and (max-width: 767px) {
  .sticky-content__title {
    text-align: center;
  }
  .sticky-content__title::after {
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.sticky-content__num {
  font-size: 20px;
  font-family: "Cormorant Garamond", serif;
  color: #1056B2;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  position: relative;
  padding-left: 23px;
}
@media screen and (max-width: 767px) {
  .sticky-content__num {
    font-size: 18px;
  }
}
.sticky-content__num::before {
  content: "";
  position: absolute;
  bottom: 10px;
  left: 0;
  width: 8px;
  height: 8px;
  background: linear-gradient(135deg, #1778F7 0%, #1363CC 20%, #1056B2 51%);
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.sticky-content__num span {
  font-size: 42px;
}
@media screen and (max-width: 767px) {
  .sticky-content__num span {
    font-size: 34px;
  }
}
.sticky-content__body {
  max-width: 685px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (max-width: 767px) {
  .sticky-content__body {
    max-width: 100%;
  }
}
.sticky-content__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.sticky-content__item {
  padding: 50px 0 60px;
  border-bottom: 1px solid #7B9ED7;
}
@media screen and (max-width: 767px) {
  .sticky-content__item {
    padding: 40px 0;
  }
}
.sticky-content__item:first-child {
  padding-top: 20px;
}
.sticky-content__head-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
.sticky-content__icon {
  width: 113px;
}
@media screen and (max-width: 767px) {
  .sticky-content__icon {
    width: 70px;
  }
}
.sticky-content__wrap {
  margin-top: -20px;
}
@media screen and (max-width: 767px) {
  .sticky-content__wrap {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
.sticky-content__sub-title {
  font-size: 28px;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
  line-height: 1.4;
  letter-spacing: 0.02em;
  color: #1056B2;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .sticky-content__sub-title {
    font-size: 22px;
    margin-top: 8px;
  }
}
.sticky-content__text {
  margin-top: 30px;
  font-weight: 500;
  line-height: 1.9;
}
.sticky-content__head-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.sticky-content__head-annotation {
  margin-top: 30px;
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .sticky-content__head-annotation {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-top: 20px;
  }
}
.sticky-content__head-img {
  margin-top: 30px;
  max-width: 469px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .sticky-content__head-img {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    margin-top: 40px;
  }
}

.step-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  gap: 28px;
}
@media screen and (max-width: 767px) {
  .step-list {
    gap: 0;
  }
}
.step-list::after {
  content: "";
  position: absolute;
  left: 36px;
  top: 0;
  width: 1px;
  height: 100%;
  background: #1056B2;
}
@media screen and (max-width: 767px) {
  .step-list::after {
    left: 16px;
  }
}
.step-list > * + * {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .step-list > * + * {
    margin-top: 0;
  }
}
.step-list__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .step-list__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
    gap: 0;
  }
}
.step-list__num {
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  color: #1056B2;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.04em;
  position: relative;
  width: 77px;
  margin-top: -2px;
  background: #fff;
  z-index: 10;
  padding: 10px 0;
  top: -10px;
}
@media screen and (max-width: 767px) {
  .step-list__num {
    top: 0;
  }
}
.step-list__num span {
  font-size: 28px;
  margin-left: 0.2em;
  line-height: 1;
}
.step-list__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (max-width: 767px) {
  .step-list__body {
    padding-left: 40px;
    padding-bottom: 0;
    width: 100%;
  }
}
.step-list__title {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  color: #1056B2;
}
.step-list__box {
  margin-top: 14px;
}

.box-list {
  background: #F2F6F8;
  padding: 12px 10px 12px calc(10px + 1.4em);
  list-style: disc;
}
.box-list li {
  font-weight: 500;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .info-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px 0;
  }
}
.info-list > * + * {
  margin-top: 12px;
}
@media screen and (max-width: 767px) {
  .info-list > * + * {
    margin-top: 0;
  }
}
.info-list__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}
@media screen and (max-width: 767px) {
  .info-list__wrap {
    width: 50%;
  }
}
@media screen and (max-width: 767px) {
  .info-list__wrap:last-child {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    width: 100%;
  }
}
.info-list dt {
  font-size: 15px;
  font-weight: bold;
  line-height: 1.5;
  color: #1056B2;
  padding: 2px;
  text-align: center;
  width: 79px;
  background: #fff;
  border: 1px solid #1056B2;
  width: 79px;
}
.info-list dd {
  line-height: 1.6;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .info-list dd {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}

.cta {
  background: #F2F2F2;
}
.cta__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  padding-top: 60px;
  padding-bottom: 60px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 767px) {
  .cta__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 40px 20px;
    gap: 30px;
  }
}
.cta__title {
  font-size: 38px;
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  line-height: 1.4;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .cta__title {
    font-size: 30px;
  }
}
.cta__title span {
  position: relative;
}
.cta__lead {
  text-align: center;
  line-height: 1.9;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-top: 30px;
  margin-bottom: 30px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .cta__lead {
    margin-top: 22px;
  }
}
.cta__btn {
  margin-top: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.cta__content {
  width: calc((100% - 50px) / 2);
  padding: 60px 50px 50px;
  border-radius: 4px;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 2px 30px 0 rgba(5, 33, 66, 0.1);
          box-shadow: 0 2px 30px 0 rgba(5, 33, 66, 0.1);
}
@media screen and (max-width: 767px) {
  .cta__content {
    width: 100%;
    padding: 48px 18px 40px;
  }
}
.cta__content a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.cta__content--download {
  background: #fff;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
@media screen and (max-width: 767px) {
  .cta__content--download {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
.cta__content--download::before {
  content: "Download";
  position: absolute;
  top: -10px;
  left: 0;
  text-align: center;
  font-size: clamp(4.375rem, 1.563rem + 5.86vw, 6.25rem);
  font-family: "Cormorant Garamond", serif;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(80, 120, 185, 0.12);
  width: 100%;
}
@media screen and (max-width: 1250px) {
  .cta__content--download::before {
    top: -10px;
  }
}
@media screen and (max-width: 1139px) {
  .cta__content--download::before {
    top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .cta__content--download::before {
    top: -1%;
    font-size: clamp(3.125rem, -1.875rem + 26.67vw, 4.375rem);
  }
}
.cta__content--download .cta__title {
  color: #1056B2;
}
.cta__content--download .cta__title span {
  text-indent: 14px;
  padding-left: 44px;
}
.cta__content--download .cta__title span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-40%);
      -ms-transform: translateY(-40%);
          transform: translateY(-40%);
  background: url(../img/common/icon-file_blue2.svg) no-repeat;
  background-size: contain;
  width: 22px;
  height: 27px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.cta__content--download:hover {
  background: #1056B2;
}
.cta__content--download:hover::before {
  color: rgba(255, 255, 255, 0.12);
}
.cta__content--download:hover .util-btn {
  background: #fff;
  color: #1056B2;
}
.cta__content--download:hover .util-btn span::after {
  background: url(../img/common/arrow-right_blue.svg) no-repeat;
}
.cta__content--download:hover .cta__title,
.cta__content--download:hover .cta__lead {
  color: #fff;
}
.cta__content--contact {
  background: -webkit-gradient(linear, left top, left bottom, from(#1079B2), to(#1056B2));
  background: linear-gradient(to bottom, #1079B2, #1056B2);
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .cta__content--contact {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
.cta__content--contact::after {
  position: absolute;
  content: "";
  inset: 0;
  z-index: -1;
  background: #1079B2;
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  border-radius: 4px;
}
.cta__content--contact::before {
  content: "Contact";
  position: absolute;
  top: -10px;
  left: 0;
  text-align: center;
  font-size: clamp(4.375rem, 1.563rem + 5.86vw, 6.25rem);
  font-family: "Cormorant Garamond", serif;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: rgba(128, 168, 214, 0.2);
  width: 100%;
}
@media screen and (max-width: 1250px) {
  .cta__content--contact::before {
    top: -10px;
  }
}
@media screen and (max-width: 1139px) {
  .cta__content--contact::before {
    top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .cta__content--contact::before {
    top: -1%;
    font-size: clamp(3.125rem, -1.875rem + 26.67vw, 4.375rem);
  }
}
.cta__content--contact .cta__title {
  color: #fff;
}
.cta__content--contact .cta__title span {
  text-indent: 7px;
  padding-left: 45px;
}
.cta__content--contact .cta__title span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-40%);
      -ms-transform: translateY(-40%);
          transform: translateY(-40%);
  background: url(../img/common/icon-mail_white.svg) no-repeat;
  background-size: contain;
  width: 25px;
  height: 20px;
}
.cta__content--contact .cta__lead {
  color: #fff;
}
.cta__content--contact:hover {
  color: #fff;
}
.cta__content--contact:hover::after {
  opacity: 1;
}
.cta__content--contact:hover .util-btn {
  background: #1056B2;
  color: #fff;
}
.cta__content--contact:hover .util-btn span::after {
  background: url(../img/common/arrow-right_white.svg) no-repeat;
}

.cta2 {
  background: url(../img/common/cta2-bg.jpg) no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .cta2 {
    background: url(../img/common/cta2-bg_sp.jpg) no-repeat center;
    background-size: cover;
  }
}
.cta2__inner {
  max-width: 1130px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 120px;
  padding-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .cta2__inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
.cta2__title {
  font-size: 38px;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
  line-height: 1.4;
  letter-spacing: 0.02em;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .cta2__title {
    font-size: 26px;
  }
}
.cta2__btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 16px;
  margin-top: 46px;
}
@media screen and (max-width: 1139px) {
  .cta2__btns {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 30px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 12px;
  }
}
.cta2__btn {
  border: none;
  width: 300px;
  font-size: 16px;
  padding: 29px 10px 29px 50px;
  display: block;
  text-align: left;
}
.cta2__btn.icon-btn--mail {
  text-indent: 0;
}
.cta2__btn.icon-btn--mail::before {
  left: 24px;
  width: 18px;
  height: 14px;
}
.cta2__btn.icon-btn--mail span {
  position: relative;
  display: block;
}
.cta2__btn.icon-btn--mail span::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
  width: 17px;
  height: 11px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.cta2__btn.icon-btn--file {
  text-indent: 0;
}
.cta2__btn.icon-btn--file::before {
  left: 25px;
  width: 13px;
  height: 16px;
}
.cta2__btn.icon-btn--file span {
  position: relative;
  display: block;
}
.cta2__btn.icon-btn--file span::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../img/common/arrow-right_blue.svg) no-repeat;
  background-size: contain;
  width: 17px;
  height: 11px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.cta2__btn.icon-btn--file:hover span::after {
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
}

.loading {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100svw;
  height: 100svh;
  background: #23345A;
  z-index: 9999;
}
.loading__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: inherit;
  padding: 0 15px;
}
.loading__img {
  text-align: center;
  width: 100%;
}
.loading__img svg {
  width: 100%;
}
.loading__before {
  opacity: 0.5;
}
.loading__after {
  clip-path: inset(0 100% 0 0);
  -webkit-animation: clipReveal 3s ease-in-out forwards;
          animation: clipReveal 3s ease-in-out forwards;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
.loading.is-first {
  display: block;
}

@-webkit-keyframes clipReveal {
  to {
    clip-path: inset(0 0% 0 0);
  }
}

@keyframes clipReveal {
  to {
    clip-path: inset(0 0% 0 0);
  }
}
.under-header {
  background: url(../img/common/under-header_bg01.jpg) no-repeat center;
  background-size: cover;
  position: relative;
  z-index: 5000;
}
@media screen and (max-width: 767px) {
  .under-header {
    background: url(../img/common/under-header_bg01_sp.jpg) no-repeat center;
    background-size: cover;
  }
}
.under-header--blue {
  background: url(../img/common/under-header_bg02.jpg) no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .under-header--blue {
    background: url(../img/common/under-header_bg02_sp.jpg) no-repeat center;
    background-size: cover;
  }
}
.under-header--blue .under-header__title {
  color: #fff;
}
.under-header--blue .under-header__title span {
  color: #fff;
}
.under-header__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding: 80px 15px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .under-header__inner {
    padding: 50px 20px 84px;
  }
}
.under-header__title {
  font-size: 36px;
  line-height: 1.4;
  font-weight: 900;
  color: #1056B2;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 767px) {
  .under-header__title {
    font-size: 26px;
  }
}
.under-header__title span {
  display: block;
  font-size: 20px;
  margin-top: 12px;
  color: #7B9ED7;
  line-height: 1;
  font-weight: bold;
  letter-spacing: 0.04em;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767px) {
  .under-header__title span {
    font-size: 18px;
    margin-top: 12px;
  }
}
.under-header__title span::first-letter {
  text-transform: uppercase;
}
.under-header__breadcrumb {
  position: absolute;
  bottom: 20px;
  left: 20px;
}
@media screen and (max-width: 767px) {
  .under-header__breadcrumb {
    bottom: 14px;
  }
}

.under-header2 {
  background: url(../img/common/under-header2_bg.jpg) no-repeat center;
  background-size: cover;
  position: relative;
}
@media screen and (max-width: 767px) {
  .under-header2 {
    background: url(../img/common/under-header2_bg_sp.jpg) no-repeat center;
    background-size: cover;
  }
}
.under-header2__inner {
  max-width: 1470px;
  padding: 0 20px;
  width: 100%;
  padding-top: 30px;
  padding-left: clamp(0px, 6.593%, 95px);
  padding-right: 0;
  padding-bottom: 60px;
  margin: 0 auto;
}
@media screen and (max-width: 1440px) {
  .under-header2__inner {
    padding-left: 30px;
  }
}
@media screen and (max-width: 1250px) {
  .under-header2__inner {
    padding-left: 10px;
  }
}
@media screen and (max-width: 1139px) {
  .under-header2__inner {
    padding: 40px 20px 0;
  }
}
.under-header2__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 30px;
}
@media screen and (max-width: 1139px) {
  .under-header2__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
}
.under-header2__body {
  margin-top: 23px;
  width: 49.2575%;
}
@media screen and (max-width: 1139px) {
  .under-header2__body {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
}
.under-header2__label {
  padding-left: 22px;
  position: relative;
  font-size: 21px;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.02em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .under-header2__label {
    font-size: 18px;
  }
}
.under-header2__label::before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  width: 14px;
  height: 14px;
  background: #fff;
}
.under-header2__title {
  font-size: 48px;
  padding-left: 22px;
  line-height: 1.4;
  font-weight: bold;
  letter-spacing: 0.02em;
  color: #fff;
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .under-header2__title {
    font-size: 32px;
  }
}
.under-header2__lead {
  margin-top: 28px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: #fff;
  padding-left: 22px;
}
@media screen and (max-width: 767px) {
  .under-header2__lead {
    margin-top: 20px;
    font-size: 16px;
  }
}
.under-header2__crown {
  margin-top: 40px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .under-header2__crown {
    margin-top: 30px;
  }
}
.under-header2__btns {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}
@media screen and (max-width: 1250px) {
  .under-header2__btns {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .under-header2__btns {
    margin-top: 28px;
  }
}
.under-header2__img {
  position: absolute;
  bottom: -60px;
  right: 0;
  border-radius: 4px 0 0 4px;
  overflow: hidden;
  -webkit-box-shadow: 0 4px 30px 0 rgba(5, 33, 66, 0.2);
          box-shadow: 0 4px 30px 0 rgba(5, 33, 66, 0.2);
  width: 609px;
}
@media screen and (max-width: 1250px) {
  .under-header2__img {
    width: 47%;
  }
}
@media screen and (max-width: 1139px) {
  .under-header2__img {
    position: relative;
    width: 100%;
    border-radius: 4px;
    bottom: -40px;
  }
}
@media screen and (max-width: 1250px) {
  .under-header2__img img {
    height: 559px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 70%;
       object-position: 70%;
  }
}
@media screen and (max-width: 1139px) {
  .under-header2__img img {
    height: unset;
  }
}
@media screen and (max-width: 767px) {
  .under-header2 .cta2__wrap {
    width: 100%;
  }
  .under-header2 .cta2__wrap a.cta2__btn {
    width: 100% !important;
    padding-left: 34px;
  }
  .under-header2 .cta2__wrap a.cta2__btn::before {
    left: 10px;
  }
  .under-header2 .cta2__wrap a.cta2__btn span::after {
    right: 0;
  }
}
.under-header2.business-development .under-header2__crown {
  max-width: 438px;
}

.breadcrumb-list {
  color: #757575;
  font-size: 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
  letter-spacing: 0.04em;
}
.breadcrumb-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}
.breadcrumb-list li::after {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  border-top: 1px solid #757575;
  border-right: 1px solid #757575;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.breadcrumb-list li:last-child::after {
  content: none;
}

.breadcrumbs span {
  color: #1056B2;
}
.breadcrumbs a span {
  color: #757575;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.breadcrumbs a:hover span {
  color: #1056B2;
}
.breadcrumbs-area {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 30px;
}
@media screen and (max-width: 767px) {
  .breadcrumbs-area {
    padding-top: 20px;
  }
}

.tab-content__tab-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.tab-content__tab-menu > * {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.tab-content__tab-btn {
  background: #1056B2;
  color: #fff;
  text-align: center;
  border-radius: 8px 8px 0 0;
  -webkit-box-shadow: 0 -4px 8px 0 rgba(5, 33, 66, 0.12);
          box-shadow: 0 -4px 8px 0 rgba(5, 33, 66, 0.12);
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.04em;
  padding: 16px;
  border: 1px solid #7B9ED7;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .tab-content__tab-btn {
    font-size: 14px;
    padding: 16px 4px;
  }
}
.tab-content__tab-btn.active {
  padding-top: 22px;
  padding-bottom: 22px;
  background: #7B9ED7;
}
.tab-content__tab-body {
  border: 1px solid #7B9ED7;
  border-radius: 0 0 10px 10px;
  padding: 42px 48px 48px;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .tab-content__tab-body {
    padding: 20px 20px 30px 20px;
  }
}
.tab-content__main-item {
  display: none;
}
.tab-content__main-item.active {
  display: block;
}

.js-c-anime-elem[data-anime=mask-curtain] {
  -webkit-mask-image: linear-gradient(135deg, #fff 33%, rgba(255, 255, 255, 0) 66%);
  mask-image: linear-gradient(135deg, #fff 33%, rgba(255, 255, 255, 0) 66%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 300% 300%;
  mask-size: 300% 300%;
  will-change: mask-position;
  -webkit-mask-position: 100% 100%;
  mask-position: 100% 100%;
  transition: -webkit-mask-position 2s ease-out;
  -webkit-transition: -webkit-mask-position 2s ease-out;
  transition: mask-position 2s ease-out;
  transition: mask-position 2s ease-out, -webkit-mask-position 2s ease-out;
}

.js-c-anime-elem.is-animated[data-anime=mask-curtain], .js-c-anime-elem.is-animated [data-anime=mask-curtain] {
  -webkit-mask-position: 0% 0%;
  mask-position: 0% 0%;
}

.message-content {
  background: -webkit-gradient(linear, left top, left bottom, from(rgb(247, 247, 249)), color-stop(50%, rgba(238, 240, 246, 0.93)), to(rgba(229, 234, 244, 0.87)));
  background: linear-gradient(180deg, rgb(247, 247, 249) 0%, rgba(238, 240, 246, 0.93) 50%, rgba(229, 234, 244, 0.87) 100%);
}
.message-content__inner {
  max-width: 1470px;
  padding: 0 20px;
  width: 100%;
  padding-top: 100px;
  padding-bottom: 100px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .message-content__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 767px) {
  .message-content__title {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .message-content__title::after {
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.message-content__parallax01 {
  position: absolute;
  bottom: -210px;
  left: 0;
}
@media screen and (max-width: 1139px) {
  .message-content__parallax01 {
    bottom: 100px;
  }
}
@media screen and (max-width: 767px) {
  .message-content__parallax01 {
    top: 260px;
    right: 0;
    bottom: auto;
    left: auto;
  }
}
.message-content__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 6%;
}
.message-content__img {
  width: 38.3%;
}
@media screen and (max-width: 767px) {
  .message-content__img {
    width: 100%;
    margin-top: 40px;
  }
}
.message-content__box {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-right: 12%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 1139px) {
  .message-content__box {
    margin-right: 4%;
  }
}
@media screen and (max-width: 767px) {
  .message-content__box {
    margin-right: 0;
  }
}
.message-content__text-area {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .message-content__text-area {
    margin-top: 24px;
  }
}
.message-content__text-area > * + * {
  margin-top: 22px;
}
.message-content__text {
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .message-content__text {
    line-height: 1.8;
  }
}
.message-content__sign {
  margin-top: auto;
  text-align: right;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  color: #1056B2;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 1139px) {
  .message-content__sign {
    margin-top: 30px;
  }
}
@media screen and (max-width: 767px) {
  .message-content__sign {
    font-size: 15px;
    margin-top: 30px;
  }
}
.message-content__sign span {
  font-size: 24px;
  margin-left: 1em;
}
@media screen and (max-width: 767px) {
  .message-content__sign span {
    font-size: 20px;
  }
}
.message-content__content2 {
  max-width: 1130px;
  padding: 0 20px;
  width: 100%;
  margin: 100px auto 0;
  background: #fff;
  padding: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .message-content__content2 {
    margin-top: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 30px 20px;
  }
}
.message-content__history {
  width: 57%;
  padding-right: 5%;
}
@media screen and (max-width: 767px) {
  .message-content__history {
    width: 100%;
  }
}
.message-content__books {
  width: 43%;
  padding-left: 5%;
  border-left: 1px solid rgba(123, 158, 215, 0.3);
}
@media screen and (max-width: 767px) {
  .message-content__books {
    border-left: none;
    border-top: 1px solid rgba(123, 158, 215, 0.3);
    width: 100%;
    padding-left: 0;
    margin-top: 30px;
    padding-top: 30px;
  }
}
.message-content__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 8%;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .message-content__wrap {
    margin-top: 20px;
    gap: 9px;
  }
}
.message-content__sub-title {
  font-size: 32px;
  font-weight: 900;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
  color: #1056B2;
}
@media screen and (max-width: 767px) {
  .message-content__sub-title {
    font-size: 24px;
  }
}
.message-content__text2 {
  margin-top: 26px;
  font-weight: 500;
  font-size: 15px;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .message-content__text2 {
    margin-top: 20px;
  }
}
.message-content__book {
  width: 180px;
}
@media screen and (max-width: 767px) {
  .message-content__book {
    width: 100%;
  }
}

.what-content {
  position: relative;
  z-index: 10;
}
.what-content__title {
  color: #fff;
  text-align: center;
}
.what-content__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  color: #fff;
}
.what-content__lead {
  margin-top: 40px;
  font-weight: 500;
  line-height: 2;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .what-content__lead {
    line-height: 1.8;
    text-align: left;
  }
}
.what-content__lead-img {
  margin-top: 40px;
  max-width: 867px;
  margin: 40px auto 0;
}
.what-content__annotation {
  margin-top: 40px;
  line-height: 2;
  font-weight: 500;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .what-content__annotation {
    text-align: left;
    line-height: 1.8;
  }
}
.what-content__box {
  background: #F2F6F8;
  border-radius: 4px;
  padding: 60px 75px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .what-content__box {
    padding: 40px 10px;
  }
}
.what-content__sub-title {
  text-align: center;
}
.what-content__list {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .what-content__list {
    margin-top: 30px;
    gap: 4px 3px;
  }
}
.what-content__item {
  width: calc((100% - 60px) / 4);
  background: #fff;
  border: 1px solid rgba(123, 158, 215, 0.45);
}
@media screen and (max-width: 767px) {
  .what-content__item {
    width: calc((100% - 6px) / 2);
  }
}
.what-content__text {
  text-align: center;
  padding: 12px 6px;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .what-content__text {
    font-size: 14px;
  }
}

.blog-card {
  margin-top: 50px;
  margin-bottom: 0;
}
.blog-card a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
  border: 1px solid #1056B2;
  border-radius: 4px;
  padding: 26px 26px 18px;
}
@media screen and (max-width: 767px) {
  .blog-card a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 20px 16px;
    gap: 18px;
  }
}
.blog-card__img {
  width: 35.419%;
}
@media screen and (max-width: 767px) {
  .blog-card__img {
    width: 100%;
  }
}
.blog-card__img img {
  aspect-ratio: 267/161;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.blog-card__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.blog-card__title {
  margin: 0 !important;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.02em;
}
.blog-card__text {
  margin-top: 16px !important;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .blog-card__text {
    margin-top: 12px !important;
  }
}

.post-column2__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 40px;
  padding-bottom: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8.4%;
}
@media screen and (max-width: 1139px) {
  .post-column2__inner {
    gap: 3%;
  }
}
@media screen and (max-width: 767px) {
  .post-column2__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 20px 0 50px;
  }
}
.post-column2__main {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.post-column2__main .column__list {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-left: -20px;
  gap: 30px 0;
}
@media screen and (max-width: 767px) {
  .post-column2__main .column__list {
    margin-left: 0;
    gap: 0;
  }
}
.post-column2__main .column__annotation {
  font-weight: 500;
  text-align: center;
  margin-top: 100px;
}
.post-column2__main .card02 {
  width: 50% !important;
}
@media screen and (max-width: 767px) {
  .post-column2__main .card02 {
    width: 100% !important;
  }
}
.post-column2__side {
  width: 26.452%;
  padding-top: 20px;
}
@media screen and (max-width: 767px) {
  .post-column2__side {
    width: 100%;
    padding: 0 20px;
    margin-top: 80px;
  }
}
.post-column2__side > * + * {
  margin-top: 30px;
}
.post-column2 .post-column2__main.voice-archive .card02 {
  width: 33.3333333333% !important;
}
@media screen and (max-width: 767px) {
  .post-column2 .post-column2__main.voice-archive .card02 {
    width: 100% !important;
  }
}
.member-archive {
  background: #F2F6F8;
}

.post-page .post-column2__inner {
  padding-top: 60px;
}
.post-page .post-column2__side {
  padding-top: 0;
}

.p-members__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .p-members__list {
    padding: 0 20px;
  }
}
.p-members__list .card03 {
  cursor: pointer;
  width: calc((100% - 40px) / 3);
}
@media screen and (max-width: 1139px) {
  .p-members__list .card03 {
    width: calc((100% - 20px) / 2);
  }
}
@media screen and (max-width: 767px) {
  .p-members__list .card03 {
    width: 100%;
  }
}

.search-box {
  position: relative;
}
.search-box input {
  border: 1px solid #1056B2;
  font-size: 18px;
  width: 100%;
  padding: 21px 21px 21px 46px;
  background: rgba(71, 125, 196, 0.06);
  border-radius: 6px;
  position: relative;
}
.search-box input::-webkit-input-placeholder {
  color: rgba(16, 86, 178, 0.4);
  font-weight: bold;
}
.search-box input::-moz-placeholder {
  color: rgba(16, 86, 178, 0.4);
  font-weight: bold;
}
.search-box input:-ms-input-placeholder {
  color: rgba(16, 86, 178, 0.4);
  font-weight: bold;
}
.search-box input::-ms-input-placeholder {
  color: rgba(16, 86, 178, 0.4);
  font-weight: bold;
}
.search-box input::placeholder {
  color: rgba(16, 86, 178, 0.4);
  font-weight: bold;
}
.search-box span {
  background: url(../img/common/icon-search.svg) no-repeat;
  background-size: contain;
  width: 18px;
  height: 18px;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 16px;
}

.side-title {
  background: #1056B2;
  font-weight: bold;
  color: #fff;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.02em;
  padding: 16px 8px;
  text-align: center;
  border-radius: 6px;
}

.side-post__item {
  border-bottom: 1px solid rgba(16, 86, 178, 0.12);
  padding: 18px 0;
}
.side-post__item:last-child {
  border-bottom: none;
}
.side-post__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
}
.side-post__link:hover {
  color: #1056B2;
}
.side-post__img {
  width: 37.5%;
}
.side-post__img img {
  aspect-ratio: 123/78;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.side-post__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.side-post__time {
  font-size: 12px;
  font-weight: 500;
  color: #757575;
  line-height: 1;
  letter-spacing: 0.04em;
}
.side-post__title {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

.side-cat__list {
  margin-top: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 12px;
}
.side-cat__link {
  color: #1056B2;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  padding: 9px;
  border-radius: 2px;
  border: 1px solid #1056B2;
  display: inline-block;
}
.side-cat__link:hover {
  background: #1056B2;
  color: #fff;
}

.side-bnr {
  position: sticky;
  top: 76px;
}
.side-bnr__list {
  margin-top: 16px;
}
.side-bnr__item + .side-bnr__item {
  margin-top: 20px;
}
.side-bnr__link:hover {
  opacity: 0.7;
}

@media screen and (max-width: 767px) {
  .single .post-column2__side {
    display: none;
  }
}

.post-cat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .post-cat {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 0 15px;
  }
}
.post-cat__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media screen and (max-width: 767px) {
  .post-cat__item {
    width: 50%;
  }
}
.post-cat__item::before {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "";
  width: 1px;
  height: 50%;
  background: #333;
}
@media screen and (max-width: 767px) {
  .post-cat__item::before {
    content: none;
  }
}
.post-cat__item:last-child::after {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "";
  width: 1px;
  height: 50%;
  background: #333;
}
@media screen and (max-width: 767px) {
  .post-cat__item:last-child::after {
    content: none;
  }
}
.post-cat__item a {
  padding: 22px 40px 40px;
  display: inline-block;
  position: relative;
}
@media screen and (max-width: 767px) {
  .post-cat__item a {
    width: 100%;
    padding: 10px 30px 10px 10px;
  }
}
.post-cat__item a::before {
  content: "";
  position: absolute;
  bottom: 20px;
  left: 50%;
  -webkit-transform: translateX(-50%) rotate(-45deg);
      -ms-transform: translateX(-50%) rotate(-45deg);
          transform: translateX(-50%) rotate(-45deg);
  width: 12px;
  height: 12px;
  border: 2px solid;
  border-color: transparent transparent #333 #333;
}
@media screen and (max-width: 767px) {
  .post-cat__item a::before {
    left: auto;
    bottom: auto;
    top: 45%;
    right: 10px;
    -webkit-transform: translateY(-50%) rotate(-45deg);
        -ms-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    width: 10px;
    height: 10px;
  }
}
.post-cat__item a:hover::before {
  border-color: transparent transparent #1056B2 #1056B2;
}

.post-content {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .post-content {
    padding: 0 20px;
  }
}
@media screen and (max-width: 767px) {
  .post-content__head {
    padding: 0 20px;
  }
}
.post-content__title {
  font-weight: bold;
  font-size: 24px;
  line-height: 1.8;
  letter-spacing: 0.02em;
  padding-bottom: 24px;
  border-bottom: 2px solid #1056B2;
}
.post-content h2 {
  margin-top: 50px;
  background: #1056B2;
  color: #fff;
  border-radius: 4px;
  padding: 16px 20px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
  .post-content h2 {
    margin-top: 40px;
    font-size: 20px;
    padding: 8px 12px;
  }
}
.post-content h3 {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.02em;
  padding-bottom: 12px;
  border-bottom: 1px solid #1056B2;
  margin-top: 60px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .post-content h3 {
    margin-top: 40px;
    font-size: 18px;
  }
}
.post-content h4 {
  font-weight: bold;
  font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.02em;
  margin-top: 60px;
  padding-left: 14px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .post-content h4 {
    font-family: 17px;
    margin-top: 40px;
  }
}
.post-content h4::before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  width: 5px;
  height: 71%;
  background: #1056B2;
}
.post-content p {
  margin-top: 30px;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .post-content p {
    margin-top: 20px;
  }
}
.post-content p a {
  line-height: 2;
  letter-spacing: 0.04em;
  color: #1056B2;
  display: inline-block;
  padding-bottom: 2px;
  border-bottom: 1px solid #1056B2;
}
.post-content p a[target=_blank] {
  padding-right: 23px;
  position: relative;
}
.post-content p a[target=_blank]::after {
  content: "";
  position: absolute;
  top: 52%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0;
  background: url(../img/common/link-blank.svg) no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
}
.post-content ul {
  margin-top: 40px;
}
.post-content ul > li {
  position: relative;
  padding-left: 16px;
  line-height: 2;
  letter-spacing: 0.04em;
}
.post-content ul > li::before {
  content: "";
  position: absolute;
  top: 0.8em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 8px;
  background: #1056B2;
}
.post-content ol {
  counter-reset: my-counter;
  margin-top: 40px;
}
.post-content ol > li + li {
  margin-top: 1em;
}
.post-content ol > li {
  counter-increment: my-counter;
  position: relative;
  padding-left: 18px;
  line-height: 2;
  letter-spacing: 0.04em;
}
.post-content ol > li::before {
  content: counter(my-counter);
  position: absolute;
  top: 0;
  left: 0;
  color: #1056B2;
  line-height: 2;
  font-weight: bold;
}
.post-content ol > li > ul {
  margin-top: 0;
}
.post-content p:has(> a:only-child):not(:has(> *:not(a))) {
  margin-top: 50px;
}
.post-content #toc_container {
  background: rgba(16, 86, 178, 0.08);
  padding: 40px;
  border-radius: 10px;
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .post-content #toc_container {
    margin-top: 30px;
    padding: 30px 10px;
  }
}
.post-content #toc_container .toc_title {
  font-size: 28px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.02em;
  color: #1056B2;
  margin: 0;
}
.post-content #toc_container .toc_list {
  margin-left: 10px;
  margin-top: 30px;
}
.post-content #toc_container .toc_list > li {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
  padding-left: 1.2em;
  position: relative;
}
.post-content #toc_container .toc_list > li::before {
  content: "";
  position: absolute;
  top: 0.5em;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 10px;
  background: #1056B2;
}
.post-content #toc_container .toc_list > li + li {
  margin-top: 24px;
}
.post-content #toc_container .toc_list ul {
  margin: 0;
}
.post-content #toc_container .toc_list ul > li {
  margin-top: 6px;
  padding-left: 0;
  font-size: 15px;
}
.post-content #toc_container .toc_list ul > li::before {
  content: none;
}
.post-content blockquote {
  background: rgba(16, 86, 178, 0.08);
  margin: 50px 0 0;
  padding: 50px 40px 35px;
  margin: 40px 0 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .post-content blockquote {
    padding: 40px 14px;
  }
}
.post-content blockquote::before {
  content: "";
  background: url(../img/common/icon-blockquote.svg) no-repeat;
  background-size: contain;
  width: 42px;
  height: 31px;
  position: absolute;
  top: 18px;
  left: 18px;
}
@media screen and (max-width: 767px) {
  .post-content blockquote::before {
    width: 29px;
    height: 21px;
    top: 11px;
    left: 11px;
  }
}
.post-content blockquote p {
  margin-top: 0;
  line-height: 2;
}
.post-content blockquote p:last-child {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .post-content blockquote p:last-child {
    margin-top: 20px;
  }
}

.post-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20%;
  margin-top: 85px;
}
@media screen and (max-width: 767px) {
  .post-nav {
    gap: 10px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 50px;
  }
}
.post-nav__prev, .post-nav__next {
  min-width: 144px;
}
@media screen and (max-width: 767px) {
  .post-nav__prev, .post-nav__next {
    min-width: 97px;
  }
}
.post-nav__prev a, .post-nav__next a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .post-nav__prev a, .post-nav__next a {
    gap: 5px;
    font-size: 15px;
  }
}
.post-nav__prev a:hover .post-nav__icon, .post-nav__next a:hover .post-nav__icon {
  background: #1056B2 url(../img/common/arrow-right_white.svg) no-repeat center;
}
.post-nav__icon {
  border: 1px solid #1056B2;
  border-radius: 4px;
  width: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 29px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background: url(../img/common/arrow-right_blue.svg) no-repeat center;
}
@media screen and (max-width: 767px) {
  .post-nav__icon {
    width: 32px;
    height: 32px;
  }
}
.post-nav__prev .post-nav__icon {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.post-nav__back a {
  font-size: 15px;
}

.post-relatation {
  background: #f2f6f8;
}
.post-relatation__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .post-relatation__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.post-relatation__title {
  text-align: center;
}
.post-relatation__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.post-relatation__content {
  width: calc(100% + 40px);
  margin-left: -20px;
  margin-top: 30px;
}

.post-annotation {
  text-align: center;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .post-annotation {
    margin-top: 50px;
  }
}

.post-voice .post-column2__main,
.post-news .post-column2__main {
  max-width: 900px;
  margin: 0 auto;
}

.pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 4px;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .pagination {
    margin-top: 50px;
  }
}

.page-btn a {
  border: 1px solid #1056B2;
  border-radius: 4px;
  width: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 29px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background: url(../img/common/arrow-right_blue.svg) no-repeat center;
}
@media screen and (max-width: 767px) {
  .page-btn a {
    width: 32px;
    height: 32px;
  }
}
.page-btn a:hover {
  background: #1056B2 url(../img/common/arrow-right_white.svg) no-repeat center;
}
.page-btn.page-prev a {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}

.page-num a {
  color: #7B9ED7;
  width: 33px;
  height: 33px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.page-num.is-current a {
  color: #fff;
  background: #1056B2;
}

.dots {
  color: #7B9ED7;
  width: 33px;
  height: 33px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.floating-bnr {
  display: none;
  position: fixed;
  bottom: 100px;
  right: 0;
  z-index: 6000;
}
.floating-bnr__inner {
  position: relative;
}
.floating-bnr__close {
  width: 40px;
  height: 40px;
  margin: 0 0 0 auto;
  position: relative;
  cursor: pointer;
}
.floating-bnr__close::before, .floating-bnr__close::after {
  content: "";
  position: absolute;
  width: 80%;
  height: 3px;
  border-radius: 10px;
  background: #333;
  top: 18px;
  left: 3px;
}
.floating-bnr__close::before {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.floating-bnr__close::after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.floating-bnr__img {
  width: 30vw;
  max-width: 450px;
}
@media screen and (max-width: 767px) {
  .floating-bnr__img {
    width: 50vw;
  }
}

/* -----------------------------------------------
* Page エントリーポイント
-------------------------------------------------- */
@media screen and (max-width: 1139px) {
  .main--top {
    overflow: hidden;
  }
}

.mv {
  background: #23345A;
  position: relative;
  overflow: hidden;
}
.mv__inner {
  padding: 0;
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .mv__inner {
    padding: 0 10px;
    max-width: 1400px;
  }
}
.mv__img-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4%;
  padding-top: 13%;
  padding-bottom: 50px;
  width: 80%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .mv__img-box {
    display: block;
    position: relative;
    padding-top: 140vw;
    width: 100%;
  }
}
.mv__img {
  -webkit-box-shadow: -2px 0 36px rgba(5, 33, 66, 0.32);
          box-shadow: -2px 0 36px rgba(5, 33, 66, 0.32);
  border-radius: 10px;
  overflow: hidden;
  opacity: 0;
  -webkit-transform: translateY(20px);
      -ms-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-transition: opacity 0.6s ease, -webkit-transform 0.6s ease, -webkit-filter 0.6s ease;
  transition: opacity 0.6s ease, -webkit-transform 0.6s ease, -webkit-filter 0.6s ease;
  transition: opacity 0.6s ease, transform 0.6s ease, filter 0.6s ease;
  transition: opacity 0.6s ease, transform 0.6s ease, filter 0.6s ease, -webkit-transform 0.6s ease, -webkit-filter 0.6s ease;
  -webkit-transition-delay: var(--delay, 0s);
          transition-delay: var(--delay, 0s);
  position: relative;
}
.mv__img.is-animated {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
  -webkit-filter: blur(0);
          filter: blur(0);
}
@media screen and (max-width: 767px) {
  .mv__img {
    width: 100%;
  }
}
.mv__img:nth-child(1) {
  z-index: 100;
  left: -50px;
}
@media screen and (max-width: 767px) {
  .mv__img:nth-child(1) {
    position: absolute;
    bottom: 15vw;
    left: -10px;
    width: 40%;
  }
}
.mv__img:nth-child(2) {
  z-index: 200;
}
@media screen and (max-width: 767px) {
  .mv__img:nth-child(2) {
    position: absolute;
    width: 50%;
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 55vw;
  }
}
.mv__img:nth-child(3) {
  z-index: 300;
  right: -50px;
}
@media screen and (max-width: 767px) {
  .mv__img:nth-child(3) {
    position: absolute;
    width: 40%;
    bottom: 30vw;
    right: -10px;
  }
}
.mv__body {
  width: 100%;
  position: absolute;
  top: clamp(0.625rem, -2.232rem + 5.95vw, 3.125rem);
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1000;
}
@media screen and (max-width: 767px) {
  .mv__body {
    top: 30px;
  }
}
.mv__box {
  position: absolute;
  left: clamp(0.625rem, -5.446rem + 12.65vw, 5.938rem);
}
@media screen and (max-width: 767px) {
  .mv__box {
    left: 20px;
  }
}
.mv__title {
  font-size: clamp(1.375rem, 1.023rem + 1.5vw, 2.375rem);
  font-weight: 700;
  color: #1056B2;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .mv__title {
    line-height: 1.84;
  }
}
.mv__title .wrap {
  padding: clamp(0.563rem, 0.386rem + 0.75vw, 1.063rem) clamp(0.625rem, 0.405rem + 0.94vw, 1.25rem);
  display: inline-block;
  border-radius: 4px;
  -webkit-box-shadow: 0 2px 28px rgba(5, 33, 66, 0.22);
          box-shadow: 0 2px 28px rgba(5, 33, 66, 0.22);
}
@media screen and (max-width: 767px) {
  .mv__title .wrap {
    -webkit-box-decoration-break: clone;
            box-decoration-break: clone;
    display: inline;
  }
}
.mv__title .small {
  font-size: clamp(1.125rem, 0.861rem + 1.13vw, 1.875rem);
}
.mv__title .big {
  font-size: clamp(1.875rem, 1.391rem + 2.07vw, 3.25rem);
  letter-spacing: 0.02em;
}
.mv__wrap {
  overflow: hidden;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
}
.mv__wrap .wrap {
  position: relative;
  z-index: 2;
  opacity: 0;
  -webkit-transform: translateY(20px);
      -ms-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: opacity 0.6s ease 0.4s, -webkit-transform 0.6s ease 0.4s;
  transition: opacity 0.6s ease 0.4s, -webkit-transform 0.6s ease 0.4s;
  transition: opacity 0.6s ease 0.4s, transform 0.6s ease 0.4s;
  transition: opacity 0.6s ease 0.4s, transform 0.6s ease 0.4s, -webkit-transform 0.6s ease 0.4s;
  -webkit-transition-delay: var(--delay-text, 0s);
          transition-delay: var(--delay-text, 0s);
}
.mv__wrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0%;
  height: 100%;
  background: #fff;
  z-index: 1;
  -webkit-transition: width 0.6s ease;
  transition: width 0.6s ease;
  border-radius: 4px;
  -webkit-transition-delay: var(--delay-bg, 0s);
          transition-delay: var(--delay-bg, 0s);
}
.mv__wrap.is-animated::before {
  width: 100%;
}
.mv__wrap.is-animated .wrap {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.mv__wrap + * {
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .mv__wrap + * {
    margin-top: 5px;
  }
}
.mv__parallax01 {
  position: absolute;
  bottom: 0;
  left: -9%;
  z-index: 900;
}
@media screen and (max-width: 767px) {
  .mv__parallax01 {
    width: 50%;
    left: 0;
  }
}
.mv__parallax02 {
  position: absolute;
  bottom: 5%;
  left: 28%;
  z-index: 900;
}
@media screen and (max-width: 767px) {
  .mv__parallax02 {
    width: 30%;
    left: auto;
    right: 30%;
    bottom: 10%;
  }
}
.mv__parallax03 {
  position: absolute;
  bottom: 43%;
  left: 27%;
}
@media screen and (max-width: 767px) {
  .mv__parallax03 {
    width: 30%;
  }
}
.mv__parallax04 {
  position: absolute;
  bottom: 6%;
  right: 0;
}
@media screen and (max-width: 767px) {
  .mv__parallax04 {
    width: 20%;
    bottom: 9%;
  }
}
.mv__parallax05 {
  position: absolute;
  top: 15%;
  right: 26%;
  z-index: 900;
}
@media screen and (max-width: 767px) {
  .mv__parallax05 {
    width: 30%;
    top: 17%;
    right: 20%;
  }
}
.mv__parallax06 {
  position: absolute;
  top: 14%;
  right: 13%;
}
@media screen and (max-width: 767px) {
  .mv__parallax06 {
    width: 15%;
    right: 10%;
  }
}
.mv__parallax07 {
  position: absolute;
  top: 1%;
  right: 0;
}
@media screen and (max-width: 767px) {
  .mv__parallax07 {
    width: 45%;
    z-index: 1100;
    right: -25%;
    top: -3%;
  }
}
.mv [class^=mv__parallax0] {
  position: absolute;
  opacity: 0;
  -webkit-transition: opacity 0.8s ease, -webkit-transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  transition: opacity 0.8s ease, -webkit-transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  transition: opacity 0.8s ease, transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  transition: opacity 0.8s ease, transform 1.2s cubic-bezier(0.22, 1, 0.36, 1), -webkit-transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  -webkit-transition-delay: var(--delay, 0s);
          transition-delay: var(--delay, 0s);
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}
.mv [class^=mv__parallax0].is-animated {
  opacity: 1;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}

.client {
  overflow: hidden;
}
.client__inner {
  max-width: 1470px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding: 70px 0 0 95px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 1139px) {
  .client__inner {
    padding: 60px 0 0 60px;
  }
}
@media screen and (max-width: 767px) {
  .client__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 40px 0;
  }
}
.client__title {
  width: 138px;
}
@media screen and (max-width: 767px) {
  .client__title {
    margin-right: 0;
    text-align: center;
  }
  .client__title::after {
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 100%;
  }
}
.client__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 500px;
}
@media screen and (max-width: 767px) {
  .client__content {
    width: 100%;
    margin-top: 50px;
  }
}
.client__slider + * {
  margin-top: 40px;
}
.client__slider img {
  width: auto;
  height: 50px;
}
@media screen and (max-width: 1139px) {
  .client__slider img {
    height: 80px;
  }
}
@media screen and (max-width: 767px) {
  .client__slider img {
    height: 45px;
  }
}
.client__slider .slick-slide {
  margin-right: 50px;
}
@media screen and (max-width: 767px) {
  .client__slider .slick-slide {
    margin-right: 30px;
  }
}

.com-message {
  height: 100svh;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 1139px) {
  .com-message {
    height: 100svh;
  }
}
.com-message__inner {
  height: 100svh;
  position: sticky;
  top: 76px;
  pointer-events: none;
}
@media screen and (max-width: 1139px) {
  .com-message__inner {
    height: 100svh;
    top: 58px;
  }
}
.com-message__bg {
  background: linear-gradient(60deg, rgb(43, 64, 110) 0%, rgb(46, 69, 119) 6%, rgb(51, 76, 131) 19%, rgb(46, 69, 119) 37%, rgb(43, 64, 110) 47%, rgb(46, 69, 119) 77%, rgb(53, 79, 137) 94%, rgb(60, 89, 154) 100%);
  height: calc(100vh - 76px);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .com-message__bg {
    height: calc(100vh - 58px);
  }
}
.com-message__bg::before, .com-message__bg::after {
  content: "";
  position: absolute;
  mix-blend-mode: luminosity;
}
.com-message__bg::before {
  top: 0;
  right: 0;
  background: url(../img/top/bg-img01.png) no-repeat;
  background-size: contain;
  width: 331px;
  height: 266px;
}
.com-message__bg::after {
  bottom: 0;
  left: 50%;
  background: url(../img/top/bg-img02.png) no-repeat;
  background-size: contain;
  width: 331px;
  height: 266px;
}
.com-message__sp-wrap {
  display: contents;
}
@media screen and (max-width: 1139px) {
  .com-message__sp-wrap {
    display: block;
    overflow: hidden;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .com-message__sp-wrap {
    padding: 0 20px;
  }
}
.com-message__content {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  height: 100%;
  padding-top: 40px;
}
@media screen and (max-width: 767px) {
  .com-message__content {
    padding-top: 30px;
    padding-left: 0;
    padding-right: 0;
  }
}
.com-message__title {
  font-size: 2.7vw;
  line-height: 1.4;
  font-weight: 900;
  font-family: "Zen Old Mincho", serif;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 1139px) {
  .com-message__title {
    font-size: 35px;
  }
}
@media screen and (max-width: 767px) {
  .com-message__title {
    font-size: 5vw;
  }
}
.com-message__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 45px;
  position: relative;
  overflow: hidden;
  margin-top: 0;
}
@media screen and (min-width: 1441px) {
  .com-message__box {
    margin-top: 2%;
  }
}
@media screen and (max-width: 1440px) {
  .com-message__box {
    gap: 30px;
  }
}
@media screen and (max-width: 1250px) {
  .com-message__box {
    gap: 20px;
  }
}
@media screen and (max-width: 1139px) {
  .com-message__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 14px;
    gap: 0;
  }
}
.com-message__img {
  width: 706px;
}
@media screen and (max-width: 1250px) {
  .com-message__img {
    width: 600px;
  }
}
@media screen and (max-width: 1139px) {
  .com-message__img {
    margin: 0 auto;
    width: 500px;
  }
}
@media screen and (max-width: 767px) {
  .com-message__img {
    max-width: 500px;
    width: 65%;
  }
}
.com-message__img svg {
  width: 100%;
}
.com-message__t-area {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-top: 20vh;
}
@media screen and (max-width: 1139px) {
  .com-message__t-area {
    margin-top: 0;
    width: 60%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .com-message__t-area {
    width: 100%;
    margin-top: 20px;
  }
}
.com-message__wrap + .com-message__wrap {
  margin-top: 60vh;
}
@media screen and (min-width: 1440px) {
  .com-message__wrap + .com-message__wrap {
    margin-top: 55vh;
  }
}
@media screen and (max-width: 1139px) {
  .com-message__wrap + .com-message__wrap {
    margin-top: 250px;
  }
}
@media screen and (max-width: 767px) {
  .com-message__wrap + .com-message__wrap {
    margin-top: 30vh;
  }
}
.com-message__sub-title {
  font-weight: 500;
  font-size: 28px;
  line-height: 1.9;
  letter-spacing: 0.04em;
  color: #fff;
}
@media screen and (max-width: 1440px) {
  .com-message__sub-title {
    font-size: 24px;
  }
}
@media screen and (max-width: 1250px) {
  .com-message__sub-title {
    font-size: 20px;
  }
}
.com-message__last-title {
  font-size: 46px;
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.02em;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 1440px) {
  .com-message__last-title {
    font-size: 36px;
  }
}
@media screen and (max-width: 1250px) {
  .com-message__last-title {
    font-size: 26px;
  }
}
.com-message__text {
  color: #fff;
  margin-top: 32px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  .com-message__text {
    font-size: 16px;
  }
}
.com-message .svg-title-area {
  position: absolute;
  z-index: 10;
  -webkit-transform: rotateZ(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotateZ(-45deg);
  bottom: 34%;
  right: 12%;
  text-align: center;
}
.com-message .svg-title {
  width: 100%;
  height: 100%;
  max-width: 104px;
  max-height: 38px;
  z-index: 2;
}
.com-message svg #circle {
  -webkit-transform-origin: center center;
      -ms-transform-origin: center center;
          transform-origin: center center;
  transform-box: fill-box;
}
.com-message .svg-main {
  position: relative;
}
.com-message .svg-main svg {
  max-height: 68vh;
}

.com-message__mid,
.com-message__end {
  height: 1px;
  visibility: hidden;
}

.flip-container {
  position: absolute;
  max-height: 132px;
  height: 20%;
  aspect-ratio: 1/1;
  -webkit-perspective: 1000px;
          perspective: 1000px;
  z-index: 1;
  bottom: 46%;
  right: 46%;
  -webkit-transform: rotateZ(45deg);
      -ms-transform: rotate(45deg);
          transform: rotateZ(45deg);
}

.flip-square {
  position: absolute;
  width: 50%;
  height: 50%;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
}

.flip-square::before {
  background: #1B3C84;
}

.flip-square::after {
  background: white;
  -webkit-transform: rotateY(180deg);
          transform: rotateY(180deg);
}

.face {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

.front {
  background-color: #1B3C84;
}

.back {
  background-color: #fff;
  -webkit-transform: rotateY(180deg) scale(1.02);
          transform: rotateY(180deg) scale(1.02);
}

.sq1 {
  bottom: 0;
  right: 0;
  -webkit-transform-origin: left top;
      -ms-transform-origin: left top;
          transform-origin: left top;
}
@media screen and (max-width: 767px) {
  .sq1 .back {
    bottom: 1px;
    right: 1px;
  }
}

.sq2 {
  bottom: 0;
  left: 0;
  -webkit-transform-origin: right top;
      -ms-transform-origin: right top;
          transform-origin: right top;
}

.sq3 {
  top: 0;
  left: 0;
  -webkit-transform-origin: right bottom;
      -ms-transform-origin: right bottom;
          transform-origin: right bottom;
}

.sq4 {
  top: 0;
  right: 0;
  -webkit-transform-origin: left bottom;
      -ms-transform-origin: left bottom;
          transform-origin: left bottom;
}
@media screen and (max-width: 767px) {
  .sq4 .back {
    top: 1px;
  }
}

.pin-wrap {
  overflow: initial;
}
@media screen and (max-width: 767px) {
  .pin-wrap {
    padding-top: 70px;
  }
}

.first {
  margin-top: -76px;
  overflow: hidden;
}
.first__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding: 196px 38px 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .first__inner {
    padding: 50px 20px 0;
  }
}
.first__title {
  text-align: center;
  margin: 0 auto;
}
.first__title::after {
  width: 100%;
  text-align: center;
}
.first__content {
  margin-top: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 80px;
  position: relative;
}
@media screen and (max-width: 1139px) {
  .first__content {
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .first__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
    margin-top: 40px;
  }
}
.first__img-box {
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.first__img {
  border-radius: 4px;
  overflow: hidden;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.first__img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.first__body {
  width: 428px;
}
@media screen and (max-width: 767px) {
  .first__body {
    width: 100%;
  }
}
.first__text {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .first__text {
    font-size: 16px;
    text-align: justify;
  }
}
.first__text + .first__text {
  margin-top: 1em;
}
.first__btn {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .first__btn {
    margin-top: 30px;
  }
}
.first__sub-title {
  font-size: 36px;
  line-height: 1.9;
  font-weight: bold;
  letter-spacing: 0.04em;
  color: #1056B2;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 767px) {
  .first__sub-title {
    font-size: 24px;
  }
}
.first__parallax01 {
  position: absolute;
  top: 260px;
  right: -50px;
  z-index: 100;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .first__parallax01 {
    top: 640px;
    width: 150px;
  }
}
.first__parallax02 {
  position: absolute;
  top: 140px;
  left: -60px;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .first__parallax02 {
    width: 134px;
    left: -30px;
    top: 230px;
  }
}
.first__parallax03 {
  position: absolute;
  bottom: -610px;
  right: -10px;
  z-index: 100;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .first__parallax03 {
    bottom: -1301px;
    width: 100px;
    right: 40px;
  }
}

.service {
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  .service {
    margin-top: 100px;
  }
}
.service__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 80px;
}
.service__head {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .service__head {
    padding: 0 20px;
  }
}
.service__lead-box {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 110px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .service__lead-box {
    margin-top: 30px;
  }
}
.service__lead {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.9;
  text-align: justify;
}
@media screen and (max-width: 767px) {
  .service__lead {
    font-size: 16px;
  }
}
.service__btn {
  width: 300px;
}
@media screen and (max-width: 767px) {
  .service__btn.sp {
    margin: 0 auto;
    width: 100%;
    max-width: 320px;
    padding: 0 10px;
    margin-top: 40px;
  }
}
.service__text {
  margin-top: 50px;
  text-align: justify;
  font-size: 18px;
  line-height: 1.9;
  letter-spacing: 0.04em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .service__text {
    margin-top: 30px;
  }
}
.service__content {
  margin-top: 50px;
}

.voice {
  position: relative;
  background: #fff;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .voice {
    padding-top: 60px;
    background: none;
  }
}
.voice__inner {
  max-width: 1470px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding: 100px 40px 115px;
}
@media screen and (max-width: 767px) {
  .voice__inner {
    padding: 0 10px;
  }
}
.voice__box {
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(10px);
  border-radius: 12px;
  padding: 70px 35px;
  -webkit-box-shadow: 0 -2px 36px rgba(5, 33, 66, 0.08);
          box-shadow: 0 -2px 36px rgba(5, 33, 66, 0.08);
}
@media screen and (max-width: 767px) {
  .voice__box {
    padding: 40px 0 30px;
  }
}
.voice__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 20px;
}
@media screen and (max-width: 767px) {
  .voice__head {
    width: 100%;
    text-align: center;
  }
}
.voice__head .wow-wrap {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .voice__wrap {
    width: 100%;
    text-align: center;
  }
}
.voice__btn {
  width: 300px;
}
@media screen and (max-width: 767px) {
  .voice__btn.sp {
    margin: 0 auto;
    width: 100%;
    max-width: 320px;
    padding: 0 10px;
    margin-top: 10px;
  }
}
.voice__content {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .voice__content {
    margin-top: 30px;
  }
}
.voice__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .voice__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.voice__list li {
  width: 33.3333333333%;
}
@media screen and (max-width: 767px) {
  .voice__list li {
    width: 100%;
  }
}
.voice__parallax01 {
  position: absolute;
  top: 280px;
  left: 0;
  z-index: -1;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .voice__parallax01 {
    width: 280px;
    top: 520px;
  }
}
.voice__parallax01 img {
  width: 206px;
}
.voice__parallax02 {
  position: absolute;
  bottom: -660px;
  right: 0;
  z-index: 100;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .voice__parallax02 {
    width: 156px;
    bottom: -900px;
  }
}
.voice__parallax03 {
  position: absolute;
  bottom: -312px;
  right: 120px;
  z-index: 0;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .voice__parallax03 {
    width: 156px;
    bottom: -470px;
  }
}

.members {
  background: #F2F6F8;
  padding-top: 120px;
  position: relative;
}
.members::before {
  content: "";
  position: absolute;
  top: -80px;
  left: 0;
  background: #F2F6F8;
  width: 100%;
  height: 100px;
}
.members__inner {
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .members__inner {
    padding-bottom: 50px;
  }
}
.members__head {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .members__head {
    padding: 0 20px;
  }
}
.members__lead-box {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 110px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .members__lead-box {
    margin-top: 30px;
  }
}
.members__lead {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.9;
  text-align: justify;
}
@media screen and (max-width: 767px) {
  .members__lead {
    font-size: 16px;
  }
}
.members__btn {
  width: 300px;
}
@media screen and (max-width: 767px) {
  .members__btn.sp {
    margin: 0 auto;
    width: 100%;
    max-width: 320px;
    padding: 0 10px;
    margin-top: 40px;
  }
}
.members__content {
  max-width: 1470px;
  padding: 0 20px;
  width: 100%;
  margin: 50px auto 0;
}
@media screen and (max-width: 767px) {
  .members__content {
    margin-top: 30px;
  }
}
.members .card03 {
  width: 100%;
}

.column__inner {
  max-width: 1290px;
  margin: 0 auto;
  padding-top: 80px;
}
@media screen and (max-width: 767px) {
  .column__inner {
    padding-top: 50px;
  }
}
.column__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 20px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .column__head {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .column__head .wow-wrap {
    width: 100%;
  }
}
.column__btn {
  width: 300px;
}
@media screen and (max-width: 767px) {
  .column__btn.sp {
    margin: 0 auto;
    width: 100%;
    max-width: 320px;
    padding: 0 10px;
    margin-top: 25px;
  }
}
.column__content {
  margin-top: 30px;
}
.column__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .column__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.column__list li {
  width: 33.3333333333%;
}
@media screen and (max-width: 767px) {
  .column__list li {
    width: 100%;
  }
}
.column__parallax01 {
  position: absolute;
  top: 560px;
  left: 200px;
  z-index: 100;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .column__parallax01 {
    -webkit-transform: scaleX(-1);
        -ms-transform: scaleX(-1);
            transform: scaleX(-1);
    left: -20px;
    top: 750px;
  }
}

.news__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  margin-top: 122px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 80px;
  padding-bottom: 100px;
}
@media screen and (max-width: 1139px) {
  .news__inner {
    margin-top: 80px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px;
    padding: 0 20px 50px;
  }
}
.news__head {
  width: 300px;
}
@media screen and (max-width: 1139px) {
  .news__head {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
  }
}
.news__btn {
  margin-top: 50px;
}
@media screen and (max-width: 1139px) {
  .news__btn {
    margin-top: 40px;
    width: 300px;
  }
}
@media screen and (max-width: 767px) {
  .news__btn.sp {
    margin: 0 auto;
    width: 100%;
    max-width: 320px;
    padding: 0 10px;
    margin-top: 25px;
  }
}
@media screen and (max-width: 767px) {
  .news__btn.sp .util-btn {
    margin: 0 auto;
  }
}
.news__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.about-lead__inner {
  position: relative;
}
.about-lead__content {
  max-width: 1470px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding: 100px 15px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about-lead__content {
    padding: 88px 6px 50px;
  }
}
.about-lead__body {
  position: relative;
}
.about-lead__box {
  background: #fff;
  position: absolute;
  top: -240px;
  padding: 71px 95px;
}
@media screen and (max-width: 1139px) {
  .about-lead__box {
    padding: 50px;
    top: -270px;
  }
}
@media screen and (max-width: 767px) {
  .about-lead__box {
    top: -45vw;
    padding: 32px 14px;
    width: 100%;
  }
}
.about-lead__title {
  font-size: 34px;
  font-weight: 900;
  font-family: "Zen Old Mincho", serif;
  line-height: 1;
}
.about-lead__title .title-wrap > * + * {
  margin-top: 28px;
}
@media screen and (max-width: 767px) {
  .about-lead__title .title-wrap > * + * {
    margin-top: 8px;
  }
}
@media screen and (max-width: 767px) {
  .about-lead__title {
    font-size: 5.86vw;
    letter-spacing: -0.02em;
  }
}
.about-lead__title span {
  background: -webkit-gradient(linear, left bottom, left top, color-stop(30%, rgb(16, 86, 178)), color-stop(69%, rgb(16, 121, 178)));
  background: linear-gradient(0deg, rgb(16, 86, 178) 30%, rgb(16, 121, 178) 69%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: block;
}
.about-lead__wrap {
  width: 717px;
  margin: 0 95px 0 auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1139px) {
  .about-lead__wrap {
    margin: 30px 95px 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .about-lead__wrap {
    width: 100%;
    margin: 0 auto;
    padding: 2vw 14px 0;
  }
}
.about-lead__wrap p {
  font-weight: 500;
  line-height: 2;
}
.about-lead__wrap > * + * {
  margin-top: 22px;
}
.about-lead__parallax01 {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .about-lead__parallax01 {
    -webkit-transform: scale(0.7);
        -ms-transform: scale(0.7);
            transform: scale(0.7);
    right: -40px;
    top: -20px;
  }
}
.about-lead__parallax02 {
  position: absolute;
  top: -350px;
  left: 0;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .about-lead__parallax02 {
    top: -300px;
  }
}
.about-lead__parallax03 {
  position: absolute;
  bottom: -130px;
  right: 0;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .about-lead__parallax03 {
    -webkit-transform: scale(0.7);
        -ms-transform: scale(0.7);
            transform: scale(0.7);
    right: -30px;
    bottom: -110px;
  }
}

.about-strengths {
  background: #23345A;
}
.about-strengths__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 100px;
  padding-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .about-strengths__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.about-strengths__title {
  text-align: center;
}
.about-strengths__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.about-strengths__content {
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .about-strengths__content {
    margin-top: 40px;
  }
}
.about-strengths__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 150px;
}
@media screen and (max-width: 1139px) {
  .about-strengths__list {
    gap: 100px;
  }
}
@media screen and (max-width: 767px) {
  .about-strengths__list {
    gap: 50px;
  }
}

.about-philosophy__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  padding-top: 100px;
  padding-bottom: 100px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .about-philosophy__inner {
    padding-top: 50px;
    padding-bottom: 22px;
  }
}
.about-philosophy__title {
  text-align: center;
}
.about-philosophy__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.about-philosophy__content {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .about-philosophy__content {
    margin-top: 40px;
  }
}

.about-company {
  overflow: hidden;
}
.about-company__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  padding-top: 100px;
  padding-bottom: 100px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about-company__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.about-company__parallax01 {
  position: absolute;
  top: 450px;
  right: -50px;
}
@media screen and (max-width: 767px) {
  .about-company__parallax01 {
    right: auto;
    left: -50px;
    top: 300px;
    -webkit-transform: scale(0.8);
        -ms-transform: scale(0.8);
            transform: scale(0.8);
  }
}
.about-company__title {
  text-align: center;
}
.about-company__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.about-company__content {
  max-width: 780px;
  margin: 70px auto 0;
}
@media screen and (max-width: 767px) {
  .about-company__content {
    margin-top: 28px;
  }
}

.service-top__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
.service-top__lead {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .service-top__lead {
    font-size: 16px;
  }
}
.service-top__content {
  margin-top: 60px;
  padding-bottom: 58px;
}
@media screen and (max-width: 767px) {
  .service-top__content {
    margin-top: 40px;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .service-top__card .card01__body {
    padding-left: 0;
    padding-right: 0;
  }
}

@media screen and (max-width: 1139px) {
  .d-breadcrumbs {
    margin-top: 50px;
  }
}

.development-client__inner {
  padding-top: 70px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .development-client__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.development-client__title {
  text-align: center;
  padding-left: 20px;
  padding-right: 20px;
}
.development-client__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .development-client__title span {
    display: none;
  }
}
.development-client__content {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .development-client__content {
    margin-top: 30px;
  }
}
.development-client__slider + * {
  margin-top: 40px;
}
.development-client__slider img {
  width: auto;
  height: 50px;
}
@media screen and (max-width: 1139px) {
  .development-client__slider img {
    height: 80px;
  }
}
@media screen and (max-width: 767px) {
  .development-client__slider img {
    height: 50px;
  }
}
.development-client__slider .slick-slide {
  margin-right: 50px;
}

.column2 {
  position: relative;
}
@media screen and (max-width: 767px) {
  .column2 {
    overflow: hidden;
  }
}
.column2__sidebar {
  position: absolute;
  top: 0;
  left: calc(95px + max(0px, (100vw - 1440px) * 0.5));
  height: 100%;
  width: 180px;
}
@media screen and (max-width: 1139px) {
  .column2__sidebar {
    left: 10px;
  }
}
@media screen and (max-width: 767px) {
  .column2__sidebar {
    display: none;
  }
}
.column2__sidebar-inner {
  position: sticky;
  top: 0;
  padding-top: 100px;
  padding-bottom: 100px;
  z-index: 1000;
}
.column2__body {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .column2__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 25px;
    padding: 0 20px;
  }
}
.column2__list > * + * {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .column2__list > * + * {
    margin-top: 0;
  }
}
.column2__list li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  position: relative;
  padding-bottom: 12px;
  padding-left: 24px;
}
@media screen and (max-width: 767px) {
  .column2__list li {
    width: calc((100% - 25px) / 2);
  }
}
.column2__list li::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0;
  background: url(../img/common/arrow-right_white.svg) no-repeat;
  background-size: contain;
  width: 16px;
  height: 9px;
}
.column2__list li::after {
  position: absolute;
  content: "";
  width: 10%;
  min-width: 18px;
  left: 0;
  bottom: -1px;
  border-bottom: 1px solid #fff;
}
.column2__list li a {
  color: #fff;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.02em;
}
.column2__list li a:hover {
  opacity: 0.7;
}
.column2__list.pattern02 li {
  border-bottom: 1px solid rgba(123, 158, 215, 0.3);
}
.column2__list.pattern02 li::before {
  content: "";
  background: url(../img/common/arrow-right_blue.svg) no-repeat;
  background-size: contain;
}
.column2__list.pattern02 li::after {
  border-bottom: 1px solid #1056B2;
}
.column2__list.pattern02 li a {
  color: #1B1C1D;
}

.d-section {
  position: relative;
}
.d-section__inner {
  max-width: 1440px;
  margin-right: auto;
  margin-left: auto;
  padding-right: 0;
  padding-left: min(25%, 400px);
}
@media screen and (max-width: 767px) {
  .d-section__inner {
    padding: 0 20px;
  }
}
.d-section__content {
  max-width: 990px;
  position: relative;
  padding-right: 15px;
}
@media screen and (max-width: 767px) {
  .d-section__content {
    padding-right: 0;
  }
}

.d-company {
  padding-top: 100px;
  padding-bottom: 100px;
  background: url(../img/service/sales-support/company-bg.jpg) no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .d-company {
    padding-top: 50px;
    padding-bottom: 50px;
    background: url(../img/service/sales-support/company-bg_sp.jpg) no-repeat;
    background-size: cover;
  }
}
.d-company__title {
  font-size: 32px;
  font-weight: bold;
  font-family: "Zen Old Mincho", serif;
  line-height: 1.6;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .d-company__title {
    font-size: 26px;
    margin-top: 50px;
  }
}
.d-company__img {
  margin-top: 40px;
  max-width: 875px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .d-company__img--pc {
    display: none;
  }
}
.d-company__img--sp {
  display: none;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .d-company__img--sp {
    display: block;
  }
}
.d-company__img--sp svg {
  max-width: 335px;
  margin: 0 auto;
}

.d-strengths {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-strengths {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-strengths__content {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .d-strengths__title {
    text-align: center;
  }
  .d-strengths__title::after {
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.d-strengths--st__lead {
  color: #1056B2;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  font-family: "Zen Old Mincho", serif;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .d-strengths--st__lead {
    margin-bottom: 8px;
    font-size: 16px;
    text-align: center;
  }
}

.d-cta {
  padding-bottom: 80px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .d-cta {
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .d-cta > * {
    padding: 0;
  }
}
.d-cta--st {
  padding-bottom: 0;
}

.d-support {
  padding-top: 100px;
  padding-bottom: 100px;
  background: #F2F6F8;
}
@media screen and (max-width: 767px) {
  .d-support {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 767px) {
  .d-support > * {
    padding: 10px;
  }
}
@media screen and (max-width: 767px) {
  .d-support__title-area {
    padding: 0 10px;
  }
}
.d-support__lead {
  margin-top: 40px;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .d-support__lead {
    font-size: 16px;
    line-height: 1.8;
    padding: 0 10px;
  }
}
.d-support__tab {
  margin-top: 40px;
}
.d-support__tab + .d-support__tab {
  margin-top: 60px;
}
.d-support__title {
  position: relative;
  font-size: 26px;
  font-weight: 900;
  font-family: "Zen Old Mincho", serif;
  color: #1056B2;
  padding-left: 1em;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .d-support__title {
    font-size: 20px;
    padding: 0 10px 0 calc(1em + 10px);
  }
}
.d-support__title::before {
  position: absolute;
  content: "";
  width: 0.7em;
  height: 0.7em;
  background: #1056B2;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
}
@media screen and (max-width: 767px) {
  .d-support__title::before {
    left: 10px;
  }
}
.d-support__box-lead {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.8;
  padding-bottom: 40px;
  margin-bottom: 40px;
  border-bottom: 1px solid rgba(123, 158, 215, 0.3);
}
@media screen and (max-width: 767px) {
  .d-support__box-lead {
    font-size: 16px;
    padding-bottom: 30px;
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 1139px) {
  .d-support .tab-content__tab-btn {
    font-size: 14px;
    padding-top: 12px;
    padding-bottom: 12px;
    min-height: 54px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.d-support .tab-content__tab-btn.active {
  background: #1079B2;
}
@media screen and (max-width: 1139px) {
  .d-support .tab-content__tab-btn.active {
    padding-top: 10px;
    padding-bottom: 10px;
    min-height: 70px;
  }
}
.d-support .tab-content__tab-btn .tab {
  display: none;
}
@media screen and (max-width: 1139px) {
  .d-support .tab-content__tab-btn .tab {
    display: block;
  }
}

.d-case {
  background: #23345A;
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .d-case {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-case > * {
  position: relative;
}
@media screen and (max-width: 767px) {
  .d-case > * {
    padding: 10px;
  }
}
@media screen and (max-width: 767px) {
  .d-case__title-area {
    padding: 0 10px;
  }
}
.d-case__title {
  color: #fff;
  text-align: center;
  margin-bottom: 50px;
}
.d-case__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  color: #fff;
}
.d-case__content {
  position: relative;
  z-index: 10;
}
.d-case__parallax01 {
  position: absolute;
  top: 650px;
  right: 0;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .d-case__parallax01 {
    -webkit-transform: scale(0.3);
        -ms-transform: scale(0.3);
            transform: scale(0.3);
    top: 90px;
    right: -130px;
  }
}
.d-case__parallax01--bd {
  top: 300px;
}
@media screen and (max-width: 767px) {
  .d-case__parallax01--bd {
    top: 0px;
  }
}
.d-case__parallax02 {
  position: absolute;
  bottom: -1020px;
  left: 350px;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .d-case__parallax02 {
    left: 0;
    bottom: -1000px;
    z-index: 10;
    -webkit-transform: scale(0.8);
        -ms-transform: scale(0.8);
            transform: scale(0.8);
  }
}
.d-case__parallax02--bd {
  bottom: -650px;
}

.d-voice {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-voice {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-voice__title {
  text-align: center;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .d-voice__title {
    margin-bottom: 40px;
  }
}
.d-voice__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.d-voice__list li {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .d-voice__list li {
    width: 100%;
  }
}
.d-voice__btn {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .d-voice__btn {
    margin-top: 20px;
  }
}
.d-voice__btn a {
  margin: 0 auto;
}

.d-message {
  background: #f2f6f8;
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-message {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-message__title {
  text-align: center;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .d-message__title {
    margin-bottom: 40px;
  }
}
.d-message__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.d-message__list li {
  width: 50%;
}
.d-message__btn {
  margin-top: 30px;
}
.d-message__btn a {
  margin: 0 auto;
}
.d-message .type02 {
  background: none;
}
.d-message .type02 .message-content__inner {
  padding-top: 0;
}
@media screen and (max-width: 767px) {
  .d-message .type02 .message-content__inner {
    padding: 0;
  }
}
.d-message .type02 .message-content__title,
.d-message .type02 .message-content__content2 {
  display: none;
}
.d-message .type02 .message-content__text-area {
  margin-top: 0;
}
.d-message .type02 .message-content__box {
  margin-right: 0;
}
.d-message .type02 .message-content__sign {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .d-message .type02 .message-content__img {
    margin-top: 0;
    margin-bottom: 24px;
  }
}
.d-message .type02 .message-content__parallax01 {
  display: none;
}

.d-what {
  background: #23345A;
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-what {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-what__parallax01 {
  position: absolute;
  top: 850px;
  right: -100px;
}
@media screen and (max-width: 767px) {
  .d-what__parallax01 {
    display: none;
  }
}
.d-what__parallax01--bd {
  top: 400px;
}
@media screen and (max-width: 767px) {
  .d-what__parallax01--bd {
    top: 700px;
  }
}
.d-what__parallax02 {
  position: absolute;
  bottom: -1190px;
  left: -50px;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  .d-what__parallax02 {
    bottom: -1400px;
  }
}
.d-what__parallax02--bd {
  bottom: -800px;
}
@media screen and (max-width: 767px) {
  .d-what__parallax02--bd {
    bottom: -1000px;
  }
}

.d-worries {
  background: #f2f6f8;
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-worries {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-worries__title {
  font-size: 32px;
  font-weight: bold;
  line-height: 1.6;
  color: #1056B2;
  font-family: "Zen Old Mincho", serif;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .d-worries__title {
    margin-top: 50px;
    font-size: 24px;
  }
}
.d-worries__list {
  padding: 0 20px;
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .d-worries__list {
    padding: 0;
    margin-top: 30px;
  }
}
.d-worries__arrow {
  height: 75px;
  margin-top: 16px;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .d-worries__arrow {
    height: 37px;
  }
}
.d-worries__arrow img {
  height: 100%;
}
.d-worries__answer {
  font-size: 32px;
  color: #1056B2;
  font-family: "Zen Old Mincho", serif;
  font-weight: bold;
  line-height: 1.6;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .d-worries__answer {
    font-size: 21px;
  }
}
.d-worries__list2 {
  margin-top: 50px;
}

.st-head__inner {
  max-width: 1130px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .st-head__inner {
    padding-left: 10px;
    padding-right: 10px;
  }
}
.st-head__content {
  padding-top: 96px;
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .st-head__content {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.st-head__icon {
  width: 92px;
  margin: 0 auto;
}
.st-head__lead {
  margin-top: 25px;
  color: #1056B2;
  font-weight: bold;
  font-size: 32px;
  line-height: 1.7;
  font-family: "Zen Old Mincho", serif;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .st-head__lead {
    margin-top: 8px;
    font-size: 21px;
  }
}
.st-head__lead .orange {
  color: #E87800;
}
.st-head__lead .num {
  font-size: 1.3em;
}

.d-menu {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-menu {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-menu__lead {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.9;
  margin-top: 22px;
}
.d-menu__content {
  margin-top: 60px;
}
.d-menu__content > * + * {
  margin-top: 60px;
}

.d-training {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-training {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-training__content {
  margin-top: 50px;
}
.d-training__title {
  text-align: center;
}
.d-training__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.d-training .card01__box {
  gap: 57px;
}
@media screen and (max-width: 1139px) {
  .d-training .card01__box {
    gap: 3%;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
@media screen and (max-width: 767px) {
  .d-training .card01__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.d-training .card01__img {
  width: 37.231%;
}
@media screen and (max-width: 1139px) {
  .d-training .card01__img {
    aspect-ratio: unset;
  }
}
@media screen and (max-width: 767px) {
  .d-training .card01__img {
    width: 100%;
    aspect-ratio: 355/163;
  }
}
.d-training .card01__label {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .d-training .card01__label {
    font-size: 16px;
  }
}
.d-training .card01__title {
  font-size: 28px;
  margin-top: 21px;
}
@media screen and (max-width: 1139px) {
  .d-training .card01__title {
    margin-top: 12px;
  }
}
@media screen and (max-width: 767px) {
  .d-training .card01__title {
    font-size: 24px;
  }
}
.d-training .card01__wrap {
  display: block;
  margin-top: 50px;
}
@media screen and (max-width: 1139px) {
  .d-training .card01__wrap {
    margin-top: 30px;
  }
}
@media screen and (max-width: 1139px) {
  .d-training .card01__body {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
}

.d-feature {
  background: -webkit-gradient(linear, left top, left bottom, from(#F7F7F9), color-stop(50%, rgba(238, 240, 246, 0.93)), to(rgba(229, 234, 244, 0.87)));
  background: linear-gradient(#F7F7F9, rgba(238, 240, 246, 0.93) 50%, rgba(229, 234, 244, 0.87));
  padding-top: 100px;
  padding-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .d-feature {
    padding-top: 50px;
    padding-bottom: 102px;
  }
}
@media screen and (max-width: 767px) {
  .d-feature__inner {
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .d-feature__content {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .d-feature__content-wrap {
    padding: 0 20px;
  }
}
.d-feature__title {
  font-size: 32px;
  font-weight: 900;
  font-family: "Zen Old Mincho", serif;
  line-height: 1.9;
  color: #1056B2;
}
@media screen and (max-width: 767px) {
  .d-feature__title {
    font-size: 20px;
    text-align: center;
  }
}
.d-feature__title span {
  font-size: 1.3em;
}
.d-feature__lead-box {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .d-feature__lead-box {
    margin-top: 40px;
  }
}
.d-feature__lead-box > * + * {
  margin-top: 24px;
}
.d-feature__lead {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .d-feature__lead {
    font-size: 16px;
  }
}
.d-feature__lead span {
  font-weight: bold;
  color: #1056B2;
}
.d-feature .basic-features__list {
  margin-top: 50px;
}
@media screen and (max-width: 1280px) {
  .d-feature .basic-features__list {
    width: 100%;
  }
}
.d-feature .basic-features__item {
  width: calc((100% + 60px) / 3);
  margin-left: -30px;
}
@media screen and (max-width: 1200px) {
  .d-feature .basic-features__item {
    width: calc((100% + 50px) / 3);
    margin-left: -25px;
  }
}
@media screen and (max-width: 1100px) {
  .d-feature .basic-features__item {
    width: calc((100% + 40px) / 3);
    margin-left: -20px;
  }
}
@media screen and (max-width: 767px) {
  .d-feature .basic-features__item {
    margin-left: 0;
  }
}
@media screen and (max-width: 767px) {
  .d-feature .basic-features__item {
    width: 100%;
  }
}
.d-feature .basic-features__item:nth-child(1) .basic-features__body {
  margin-left: 6px;
}
.d-feature .basic-features__item:nth-child(2) .basic-features__body {
  margin-left: 5%;
}
.d-feature .basic-features__item:nth-child(3) .basic-features__body {
  margin-left: auto;
  margin-right: 6px;
}
.d-feature .basic-features__body {
  width: 90%;
}
.d-feature .basic-features__wrap {
  padding: 24px 16px 40px;
}

.d-plans {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .d-plans {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.d-plans__title {
  text-align: center;
}
.d-plans__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.d-plans__container {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .d-plans__container {
    margin-top: 40px;
  }
}
.d-plans__container > * + * {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .d-plans__container > * + * {
    margin-top: 30px;
  }
}
.d-plans__body {
  padding: 58px 23px 50px;
}
@media screen and (max-width: 767px) {
  .d-plans__body {
    padding: 25px 25px 30px;
  }
}
.d-plans__sub-title {
  background: #7B9ED7;
  color: #fff;
  padding: 18px 10px;
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .d-plans__sub-title {
    letter-spacing: -0.04em;
    padding: 16px 4px;
    font-size: 22px;
  }
}
.d-plans__box {
  border: 1px solid #7B9ED7;
  background: rgba(123, 158, 215, 0.04);
  border-radius: 10px;
  overflow: hidden;
}
.d-plans__box--dark {
  border-color: #145BB6;
  background: rgba(20, 91, 182, 0.04);
}
.d-plans__box--dark .d-plans__sub-title {
  background: -webkit-gradient(linear, left top, right top, from(#1079B2), to(#145BB6));
  background: linear-gradient(90deg, #1079B2, #145BB6);
}
.d-plans__box--dark .d-plans__body {
  padding: 40px 23px 50px;
}

.c-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3%;
}
@media screen and (max-width: 1139px) {
  .c-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 38px;
  }
}
.c-box__item {
  width: 31.3333333333%;
  border: 1px solid #BDBDBD;
  background: #fff;
  padding-bottom: 26px;
  position: relative;
}
@media screen and (max-width: 1139px) {
  .c-box__item {
    width: 100%;
    padding-bottom: 8px;
  }
}
.c-box__item::after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -7%;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 10px solid #7b9ed7;
  border-right: 0;
}
@media screen and (max-width: 1139px) {
  .c-box__item::after {
    top: auto;
    bottom: -30px;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(90deg);
        -ms-transform: translateX(-50%) rotate(90deg);
            transform: translateX(-50%) rotate(90deg);
  }
}
.c-box__item:nth-child(1) .c-box__title {
  background: #7B9ED7;
  width: 88%;
}
.c-box__item:nth-child(2) .c-box__title {
  background: -webkit-gradient(linear, left top, right top, from(#7B9ED7), to(#1056B2));
  background: linear-gradient(90deg, #7B9ED7, #1056B2);
  width: 88%;
}
.c-box__item:nth-child(3)::after {
  content: none;
}
.c-box__item:nth-child(3) .c-box__title {
  background: #1056B2;
}
.c-box__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 4px;
  margin-bottom: 20px;
}
.c-box__head-wrap {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-top: 4px;
}
.c-box__icon {
  width: 81px;
  margin-right: 15px;
  margin-top: 20px;
}
.c-box__num {
  font-family: "Cormorant Garamond", serif;
  color: #7B9ED7;
  font-size: 28px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  padding-left: 35%;
  position: relative;
}
.c-box__num::before {
  content: "";
  position: absolute;
  top: 60%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  max-width: 51px;
  width: 30%;
  height: 1px;
  background: #7B9ED7;
}
.c-box__title {
  color: #fff;
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  padding: 8px 14px 8px 5px;
  width: 100%;
  text-align: center;
  margin-top: 10px;
  clip-path: polygon(0 0, 90% 0, 100% 50%, 90% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
  .c-box__title {
    padding: 8px 10px 8px 2px;
  }
}
.c-box__title span {
  font-size: 15px;
}
.c-box__wrap {
  padding: 0 18px;
  min-height: 110px;
}
@media screen and (max-width: 1139px) {
  .c-box__wrap {
    min-height: unset;
  }
}
.c-box__wrap:last-child {
  margin-top: 30px;
}
@media screen and (max-width: 1139px) {
  .c-box__wrap:last-child {
    min-height: unset;
  }
}
.c-box__sub-title {
  font-weight: 500;
  line-height: 1.3;
  background: rgba(123, 158, 215, 0.24);
  max-width: 83px;
  padding: 2px;
  text-align: center;
}
.c-box__text {
  font-weight: 500;
  line-height: 1.5;
  margin-top: 12px;
}
.c-box__title-bold {
  font-weight: bold;
  line-height: 1.6;
  margin-top: 12px;
}
.c-box__child-list {
  list-style: disc;
  list-style-position: inside;
  margin-top: 12px;
}
.c-box__child-item {
  border-bottom: 1px solid rgba(123, 158, 215, 0.4);
  padding-bottom: 12px;
  padding-left: 1.8em;
  text-indent: -1.4em;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-box__child-item:last-child {
    border: none;
  }
}
.c-box__child-item + .c-box__child-item {
  margin-top: 12px;
}
.c-box__dl {
  width: 90%;
  margin: 28px auto 0;
}
@media screen and (max-width: 767px) {
  .c-box__dl {
    width: 100%;
  }
}
.c-box__content2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
}
@media screen and (max-width: 767px) {
  .c-box__content2 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 50px;
  }
}
.c-box__content2 > * {
  border: 1px solid #BDBDBD;
  width: calc((100% - 24px) / 2);
}
@media screen and (max-width: 767px) {
  .c-box__content2 > * {
    width: 100%;
  }
}

.training-top__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
.training-top__lead {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .training-top__lead {
    font-size: 16px;
  }
}
.training-top__content {
  margin-top: 60px;
  padding-bottom: 58px;
}
@media screen and (max-width: 767px) {
  .training-top__content {
    margin-top: 40px;
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .training-top__card .card01__body {
    padding-left: 0;
    padding-right: 0;
  }
}

.training-menu__inner {
  max-width: 1130px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .training-menu__inner {
    padding: 40px 10px 40px;
  }
}
.training-menu__inner > * + * {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .training-menu__inner > * + * {
    margin-top: 50px;
  }
}
.training-menu__title {
  color: #1056B2;
  font-weight: 900;
  font-size: 32px;
  line-height: 1;
  font-family: "Zen Old Mincho", serif;
  position: relative;
  padding-left: 1em;
}
@media screen and (max-width: 767px) {
  .training-menu__title {
    font-size: 20px;
    margin-left: 10px;
  }
}
.training-menu__title::before {
  position: absolute;
  content: "";
  width: 0.7em;
  height: 0.7em;
  background: #1056B2;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
}
.training-menu__content {
  margin-top: 40px;
}
.training-menu__annotation {
  text-align: center;
  margin-top: 40px;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .training-menu__annotation {
    font-size: 15px;
    text-align: left;
    margin-top: 20px;
  }
}

.basic-top {
  background: #1056B2;
}
.basic-top__inner {
  max-width: 1130px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 80px;
  padding-bottom: 316px;
}
@media screen and (max-width: 767px) {
  .basic-top__inner {
    padding-top: 40px;
    padding-bottom: 229px;
  }
}
.basic-top__title {
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  line-height: 1.5;
  font-family: "Zen Old Mincho", serif;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .basic-top__title {
    font-size: 20px;
  }
}
.basic-top__title span {
  font-size: 42px;
}
@media screen and (max-width: 767px) {
  .basic-top__title span {
    font-size: 30px;
    display: block;
  }
}
.basic-top__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  margin-top: 22px;
}
.basic-top__label {
  background: #fff;
  color: #1056B2;
  font-weight: 500;
  line-height: 1.5;
  padding: 2px 7px;
  min-width: 120px;
}
.basic-top__text {
  color: #fff;
  font-size: 18px;
  line-height: 1.6;
  font-weight: 500;
}

.basic-needs {
  padding-bottom: 568px;
}
@media screen and (max-width: 767px) {
  .basic-needs {
    padding-bottom: 452px;
  }
}
.basic-needs__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .basic-needs__inner {
    padding: 0 10px;
  }
}
.basic-needs__wrap {
  position: relative;
  margin-top: -190px;
}
.basic-needs__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  border-radius: 4px;
}
.basic-needs__bg img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .basic-needs__bg img {
    height: 700px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: top;
       object-position: top;
  }
}
.basic-needs__content {
  position: relative;
  top: 567px;
  z-index: 1;
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(24px);
  -webkit-box-shadow: -2px 0 30px rgba(5, 33, 66, 0.1);
          box-shadow: -2px 0 30px rgba(5, 33, 66, 0.1);
  padding: 70px 20px 100px;
}
@media screen and (max-width: 767px) {
  .basic-needs__content {
    top: 450px;
    padding: 40px 10px;
  }
}
.basic-needs__title {
  color: #1056B2;
  font-weight: 900;
  font-family: "Zen Old Mincho", serif;
  line-height: 1.4;
  font-size: 32px;
  text-align: center;
  position: relative;
  padding-bottom: 28px;
}
@media screen and (max-width: 767px) {
  .basic-needs__title {
    font-size: 26px;
  }
}
.basic-needs__title::after {
  content: attr(data-en);
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #7B9ED7;
}
.basic-needs__img {
  width: 70%;
  margin: 36px auto 0;
}
@media screen and (max-width: 767px) {
  .basic-needs__img {
    width: 100%;
    margin-top: 13px;
  }
}
.basic-needs__img--c4 {
  width: 80%;
}
@media screen and (max-width: 767px) {
  .basic-needs__img--c4 {
    width: 100%;
  }
}
.basic-needs__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 147px;
  margin-top: 86px;
  padding-left: 143px;
  padding-right: 143px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 1139px) {
  .basic-needs__box {
    padding-left: 50px;
    padding-right: 50px;
    gap: 50px;
  }
}
@media screen and (max-width: 767px) {
  .basic-needs__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-left: unset;
    padding-right: unset;
    margin-top: 50px;
    gap: 30px;
  }
}
.basic-needs__sub-title {
  width: 160px;
}
@media screen and (max-width: 767px) {
  .basic-needs__sub-title {
    text-align: center;
    width: 100%;
  }
  .basic-needs__sub-title::after {
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.basic-needs__text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.basic-strengths__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
.basic-strengths__content {
  padding-top: 100px;
}
@media screen and (max-width: 767px) {
  .basic-strengths__content {
    padding-top: 50px;
  }
}

.basic-program__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
}
.basic-program__content {
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .basic-program__content {
    padding-top: 80px;
  }
}

.basic-overview__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  padding-top: 100px;
  padding-bottom: 100px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .basic-overview__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
.basic-overview__title {
  text-align: center;
}
.basic-overview__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.basic-overview__content {
  max-width: 780px;
  margin: 70px auto 0;
}
@media screen and (max-width: 767px) {
  .basic-overview__content {
    margin-top: 28px;
  }
}

.basic-features__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 100px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .basic-features__inner {
    padding: 50px 0 100px;
  }
}
.basic-features__title {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .basic-features__title {
    padding: 0 20px 22px;
  }
}
.basic-features__title::after {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
}
.basic-features__content {
  margin-top: 60px;
}
.basic-features__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
@media screen and (max-width: 1280px) {
  .basic-features__list {
    width: 1000px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 1040px) {
  .basic-features__list {
    width: 728px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .basic-features__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
    position: relative;
  }
}
.basic-features__bg {
  position: relative;
  height: 139px;
}
@media screen and (max-width: 767px) {
  .basic-features__bg {
    position: absolute;
    top: 0;
    left: 0;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: 139px;
  }
}
.basic-features__bg::before {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  top: 26px;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
  .basic-features__bg::before {
    -webkit-writing-mode: vertical-lr;
        -ms-writing-mode: tb-lr;
            writing-mode: vertical-lr;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    top: 50%;
    left: 20px;
    font-size: 20px;
  }
}
.basic-features__item {
  opacity: 0;
  -webkit-transform: translateY(10px);
      -ms-transform: translateY(10px);
          transform: translateY(10px);
  width: calc((100% + 74px) / 3);
  margin-left: -37px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
}
@media screen and (max-width: 1280px) {
  .basic-features__item {
    margin-left: -31px;
    width: calc((100% + 62px) / 3);
  }
}
@media screen and (max-width: 1040px) {
  .basic-features__item {
    margin-left: -20px;
    width: calc((100% + 40px) / 3);
  }
}
@media screen and (max-width: 767px) {
  .basic-features__item {
    width: 100%;
    margin-left: 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-top: 19px;
  }
}
@media screen and (max-width: 767px) and (max-width: 500px) {
  .basic-features__item {
    margin-top: 16px;
  }
}
.basic-features__item:nth-child(1) {
  margin-left: 0;
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(1) {
    margin-top: 0;
  }
}
.basic-features__item:nth-child(1) .basic-features__bg {
  background: -webkit-gradient(linear, left top, right top, from(#CFDEE3), color-stop(17%, #AFCAD7), to(#6FABCB));
  background: linear-gradient(to right, #CFDEE3, #AFCAD7 17%, #6FABCB);
  clip-path: polygon(0 0, 90% 0, 95% 50%, 90% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(1) .basic-features__bg {
    clip-path: polygon(0 0, 100% 0px, 100% 95.3%, 50% 100%, 0 95.3%);
    height: 108%;
  }
}
.basic-features__item:nth-child(1) .basic-features__bg::before {
  content: "研修前";
}
.basic-features__item:nth-child(1) .basic-features__body {
  margin-left: 14px;
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(1) .basic-features__body {
    margin-left: auto;
    top: 14px;
  }
}
.basic-features__item:nth-child(2) .basic-features__bg {
  background: -webkit-gradient(linear, left top, right top, from(#6DA7C6), color-stop(39%, #588FBF), to(#2A70CC));
  background: linear-gradient(to right, #6DA7C6, #588FBF 39%, #2A70CC);
  clip-path: polygon(0% 0%, 95% 0%, 100% 50%, 95% 100%, 0% 100%, 5% 50%);
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(2) .basic-features__bg {
    clip-path: polygon(0 0, 50% 4%, 100% 0px, 100% 95.3%, 50% 100%, 0 95.3%);
    height: 115%;
  }
}
.basic-features__item:nth-child(2) .basic-features__bg::before {
  content: "研修中";
}
.basic-features__item:nth-child(2) .basic-features__body {
  margin-left: 32px;
}
@media screen and (max-width: 1040px) {
  .basic-features__item:nth-child(2) .basic-features__body {
    margin-left: 20px;
  }
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(2) .basic-features__body {
    margin-left: auto;
    top: 35px;
  }
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(3) {
    margin-top: 49px;
  }
}
@media screen and (max-width: 700px) {
  .basic-features__item:nth-child(3) {
    margin-top: 46px;
  }
}
@media screen and (max-width: 600px) {
  .basic-features__item:nth-child(3) {
    margin-top: 42px;
  }
}
@media screen and (max-width: 500px) {
  .basic-features__item:nth-child(3) {
    margin-top: 40px;
  }
}
@media screen and (max-width: 400px) {
  .basic-features__item:nth-child(3) {
    margin-top: 38px;
  }
}
@media screen and (max-width: 386px) {
  .basic-features__item:nth-child(3) {
    margin-top: 41px;
  }
}
@media screen and (max-width: 361px) {
  .basic-features__item:nth-child(3) {
    margin-top: 43px;
  }
}
.basic-features__item:nth-child(3) .basic-features__bg {
  background: -webkit-gradient(linear, left top, right top, from(#2A70CC), to(#1056B2));
  background: linear-gradient(to right, #2A70CC, #1056B2);
  clip-path: polygon(5% 0%, 10% 0%, 100% 0%, 100% 100%, 5% 100%, 10% 50%);
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(3) .basic-features__bg {
    clip-path: polygon(0% 0.3%, 50% 5.2%, 103% 0px, 100% 100%, 0% 100%);
    height: 111%;
  }
}
.basic-features__item:nth-child(3) .basic-features__bg::before {
  content: "研修後";
}
.basic-features__item:nth-child(3) .basic-features__body {
  margin-right: 14px;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .basic-features__item:nth-child(3) .basic-features__body {
    margin-right: auto;
    top: 32px;
  }
}
.basic-features__body {
  width: 84.249%;
  position: relative;
  top: -62px;
  -webkit-box-shadow: -2px 0 30px rgba(5, 33, 66, 0.18);
          box-shadow: -2px 0 30px rgba(5, 33, 66, 0.18);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .basic-features__body {
    margin-left: 70px !important;
    top: 0;
    z-index: 10;
    width: 100%;
  }
}
.basic-features__wrap {
  padding: 24px 24px 30px;
}
@media screen and (max-width: 767px) {
  .basic-features__wrap {
    padding: 24px 16px;
  }
}
.basic-features__sub-title {
  font-size: 21px;
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
@media screen and (max-width: 1280px) {
  .basic-features__sub-title {
    font-size: 19px;
  }
}
@media screen and (max-width: 1040px) {
  .basic-features__sub-title {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .basic-features__sub-title {
    font-size: 20px;
  }
}
.basic-features__text {
  margin-top: 20px;
  font-weight: 500;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .basic-features__text {
    line-height: 1.6;
  }
}
.basic-features__lead {
  text-align: center;
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 40px;
  padding: 0 20px;
}
@media screen and (max-width: 767px) {
  .basic-features__lead {
    margin-bottom: 20px;
    text-align: left;
  }
}

.basic-what {
  background: #23345A;
}
.basic-what__inner {
  max-width: 1280px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .basic-what__inner {
    padding: 50px 10px;
  }
}
.basic-what__parallax01 {
  position: absolute;
  top: 470px;
  right: -80px;
}
@media screen and (max-width: 767px) {
  .basic-what__parallax01 {
    right: auto;
    left: 0;
    top: 540px;
  }
}
.basic-what__parallax02 {
  position: absolute;
  bottom: -650px;
  left: -70px;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  .basic-what__parallax02 {
    bottom: -750px;
  }
}
@media screen and (max-width: 767px) {
  .basic-what .what-content__wrap {
    padding: 0 10px;
  }
}

.not-found {
  background: #F2F6F8;
}
.not-found__inner {
  max-width: 1130px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding-top: 60px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .not-found__inner {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
.not-found__head {
  border-bottom: 1px solid #7B9ED7;
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .not-found__head {
    padding-bottom: 50px;
  }
}
.not-found__title {
  font-size: 70px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  color: #1056B2;
}
@media screen and (max-width: 767px) {
  .not-found__title {
    font-size: 34px;
  }
}
.not-found__sub-title {
  font-size: 24px;
  font-weight: bold;
  color: #1056B2;
  margin-top: 40px;
  text-align: center;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .not-found__sub-title {
    font-size: 18px;
    margin-top: 20px;
  }
}
.not-found__body {
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .not-found__body {
    padding-top: 40px;
  }
}
.not-found__text {
  text-align: center;
  font-weight: 500;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .not-found__text {
    text-align: left;
    line-height: 1.8;
  }
}
.not-found__btn {
  text-align: center;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .not-found__btn {
    margin-top: 40px;
  }
}
.not-found__btn a {
  display: inline-block;
}

.document-archive__term-title {
  font-family: "Zen Old Mincho", serif;
  font-size: 32px;
  font-weight: bold;
  color: #1056B2;
}

.document-archive__section {
  margin-top: 60px;
}

.document-archive__post-list {
  margin-top: 30px;
}

.card02__excerpt {
  margin-top: 10px;
  line-height: 1.6;
}

.news-archive {
  padding: 0 20px;
}

.webinar-c {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 1250px) {
  .webinar-c {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.webinar-c__main {
  max-width: calc(100% - 420px);
  width: 100%;
}
@media screen and (max-width: 1250px) {
  .webinar-c__main {
    max-width: 100%;
  }
}
.webinar-c__main .breadcrumbs-area {
  margin-bottom: 20px;
}
.webinar-c__sidebar {
  width: 420px;
  background: #23345A;
  position: fixed;
  top: 0;
  right: 0;
  height: 100%;
  overflow-y: auto;
}
@media screen and (max-width: 1250px) {
  .webinar-c__sidebar {
    width: 100%;
    height: 100%;
    margin-bottom: 40px;
    position: unset;
  }
}
.webinar-c__sidebar-wrapper {
  padding: 116px 30px 40px;
}
@media screen and (max-width: 1250px) {
  .webinar-c__sidebar-wrapper {
    padding: 40px 30px;
  }
}
@media screen and (max-width: 767px) {
  .webinar-c__sidebar-wrapper {
    padding: 40px 20px 60px;
  }
}
.webinar-c__sidebar-title {
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
.webinar-c__sidebar-content {
  background: #fff;
  padding: 30px 20px;
  margin-top: 40px;
}
.webinar-c__mv {
  background: #1056B2;
}
.webinar-c__mv-inner {
  padding: 30px;
}
@media screen and (max-width: 767px) {
  .webinar-c__mv-inner {
    padding: 10px;
  }
}
.webinar-c__content {
  padding: 50px;
}
@media screen and (max-width: 767px) {
  .webinar-c__content {
    padding: 40px 20px;
  }
}
.webinar-c__post {
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .webinar-c__post {
    padding: 0;
  }
}
.webinar-c__post > * + * {
  margin-top: 30px;
}
.webinar-c__content-title {
  font-family: "Zen Old Mincho", serif;
  font-size: 32px;
  color: #1056B2;
  text-align: center;
  position: relative;
  padding-bottom: 26px;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .webinar-c__content-title {
    font-size: 26px;
    padding-bottom: 24px;
  }
}
.webinar-c__content-title::after {
  content: attr(data-en-title);
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 0;
  color: #7B9ED7;
  font-size: 16px;
  letter-spacing: 0.04em;
  font-weight: bold;
}
.webinar-c__recommended {
  margin-top: 40px;
}
.webinar-c__recommended-title {
  margin-top: 50px;
  background: #1056B2;
  color: #fff;
  border-radius: 4px;
  padding: 16px 20px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.8;
  text-align: center;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
  .webinar-c__recommended-title {
    margin-top: 40px;
    font-size: 20px;
    padding: 22px 12px;
  }
}
.webinar-c__recommended-list {
  background: rgba(123, 158, 215, 0.1);
  padding: 40px 40px 40px 70px;
}
@media screen and (max-width: 767px) {
  .webinar-c__recommended-list {
    padding: 30px 15px 30px 45px;
  }
}
.webinar-c__recommended-item {
  position: relative;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.webinar-c__recommended-item::before {
  content: "";
  position: absolute;
  top: 0.4em;
  left: -1.2em;
  height: 16px;
  width: 16px;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
  background: -webkit-gradient(linear, left top, right bottom, from(#1778F7), color-stop(20%, #1363CC), color-stop(51%, #1056B2), to(#1056B2));
  background: linear-gradient(to bottom right, #1778F7 0%, #1363CC 20%, #1056B2 51%, #1056B2 100%);
}
.webinar-c__recommended-item + .webinar-c__recommended-item {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .webinar-c__recommended-item + .webinar-c__recommended-item {
    margin-top: 20px;
  }
}
.webinar-c__agenda-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
  margin-top: 40px;
  counter-reset: my-counter;
}
@media screen and (max-width: 767px) {
  .webinar-c__agenda-list {
    gap: 32px;
    margin-top: 32px;
  }
}
.webinar-c__agenda-item {
  padding: 33px 20px 20px;
  -webkit-box-shadow: 0 0 20px 0 rgba(16, 86, 178, 0.12);
          box-shadow: 0 0 20px 0 rgba(16, 86, 178, 0.12);
  position: relative;
  counter-increment: my-counter;
}
@media screen and (max-width: 767px) {
  .webinar-c__agenda-item {
    padding: 30px 15px;
  }
}
.webinar-c__agenda-item::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 10px;
  width: 20px;
  height: 1px;
  background: #fff;
  z-index: 2;
}
.webinar-c__agenda-item::after {
  content: "0" counter(my-counter);
  width: 80px;
  clip-path: polygon(0 0, 90% 0, 100% 50%, 90% 100%, 0 100%);
  background: #1056B2;
  display: block;
  color: #fff;
  font-family: "Cormorant Garamond", serif;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1;
  position: absolute;
  top: -0.5em;
  left: 0;
  padding: 2px 3px 4px 40px;
}
.webinar-c__agenda-sub-title {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .webinar-c__agenda-sub-title {
    font-size: 18px;
  }
}
.webinar-c__agenda-text {
  margin-top: 10px;
  font-weight: 400;
  line-height: 1.5;
  font-size: 16px;
}
.webinar-c__overview-box {
  margin-top: 40px;
  background: rgba(123, 158, 215, 0.04);
  padding: 40px;
  -webkit-box-shadow: 0 0 20px 0 rgba(16, 86, 178, 0.12);
          box-shadow: 0 0 20px 0 rgba(16, 86, 178, 0.12);
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .webinar-c__overview-box {
    margin-top: 20px;
    padding: 30px 20px;
  }
}
.webinar-c__overview-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .webinar-c__overview-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.webinar-c__overview-list {
  display: table;
  width: 100%;
}
.webinar-c__overview-list > * + * {
  margin-top: 20px;
}
.webinar-c__overview-list dt {
  width: 150px;
  border-bottom: 1px solid #7B9ED7;
  padding-bottom: 20px;
  font-weight: bold;
  line-height: 1.4;
  padding-right: 10px;
}
@media screen and (max-width: 767px) {
  .webinar-c__overview-list dt {
    width: 100%;
    padding-bottom: 10px;
    padding-right: 6px;
  }
}
.webinar-c__overview-list dd {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  border-bottom: 1px solid rgba(123, 158, 215, 0.3);
  padding-bottom: 20px;
  font-weight: 400;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .webinar-c__overview-list dd {
    padding-top: 10px;
    padding-bottom: 10px;
  }
}
.webinar-c__speaker-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-list {
    margin-top: 20px;
    gap: 20px;
  }
}
.webinar-c__speaker-item {
  -webkit-box-shadow: 0 0 20px 0 rgba(16, 86, 178, 0.12);
          box-shadow: 0 0 20px 0 rgba(16, 86, 178, 0.12);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 25px;
  padding: 30px;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 30px 20px;
  }
}
.webinar-c__speaker-img {
  width: 230px;
  height: 230px;
  border-radius: 300px;
  overflow: hidden;
}
@media screen and (max-width: 1139px) {
  .webinar-c__speaker-img {
    width: 20%;
    height: 20%;
    aspect-ratio: 1/1;
  }
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-img {
    width: 230px;
    height: 230px;
    margin: 0 auto;
  }
}
.webinar-c__speaker-img img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}
.webinar-c__speaker-info {
  width: 205px;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-info {
    width: 100%;
  }
}
.webinar-c__speaker-info > *:first-child {
  margin-top: 0 !important;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-logo {
    max-width: 150px;
    width: 100%;
    margin: 0 auto;
  }
}
.webinar-c__speaker-logo img {
  width: 100%;
}
.webinar-c__speaker-company {
  margin-top: 25px;
  font-size: 18px;
  line-height: 1.5;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-company {
    text-align: center;
    margin-top: 20px;
    font-size: 18px;
  }
}
.webinar-c__speaker-position {
  margin-top: 10px;
  font-size: 14px;
  font-weight: 500;
  color: #757575;
  letter-spacing: 0.04em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-position {
    text-align: center;
  }
}
.webinar-c__speaker-name {
  margin-top: 20px;
  font-weight: bold;
  font-size: 24px;
  line-height: 1;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  .webinar-c__speaker-name {
    text-align: center;
  }
}
.webinar-c__speaker-text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: 16px;
  line-height: 1.6;
  font-weight: 400;
  letter-spacing: 0.04em;
}
.webinar-c__cta {
  background: #F2F6F8;
  padding: 40px 15px;
  display: none;
}
@media screen and (max-width: 1250px) {
  .webinar-c__cta {
    display: block;
  }
}
.webinar-c__cta-text {
  font-family: "Zen Old Mincho", serif;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  color: #23345A;
  margin-bottom: 10px;
}
.webinar-c__cta-text span {
  display: inline-block;
  position: relative;
}
.webinar-c__cta-text span::before, .webinar-c__cta-text span::after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 30px;
  height: 1px;
  background: #23345A;
}
.webinar-c__cta-text span::before {
  left: -45px;
}
.webinar-c__cta-text span:after {
  right: -45px;
}
.webinar-c__cta .util-btn {
  margin: 0 auto;
}

.CF7_table--webinar tr {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.CF7_table--webinar th {
  padding-bottom: 10px !important;
}
.CF7_table--webinar .small {
  color: #a1a1a1;
  font-size: 14px;
  margin-bottom: 10px;
  display: block;
}
/*# sourceMappingURL=style.css.map */