@charset "UTF-8";
/*
 * 参考
 * https://github.com/Andy-set-studio/modern-css-reset/blob/master/src/reset.css
*/
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/*****************************************
 * 数値から単位を取り除く
 * 参考
 * https://css-tricks.com/snippets/sass/
******************************************/
/*****************************************
 * px→remの計算
 * 参考
 * https://webdou.net/sass-rem/
 * Sassではmath.div関数の使用が推奨のため、スラッシュ(/)演算子から変更
******************************************/
/*****************************************
 * vwの計算
 * 参考
 * https://webdou.net/sass-vw/
 * Sassではmath.div関数の使用が推奨のため、スラッシュ(/)演算子から変更
******************************************/
html {
  overflow-x: hidden;
  font-size: 16px;
}
@media (max-width: 1200px) {
  html {
    font-size: 1.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 16px;
  }
}
@media (max-width: 375px) {
  html {
    font-size: 4.2666666667vw;
  }
}

body {
  font-family: "IBM Plex Sans", sans-serif;
  font-weight: 400;
  color: #444;
  margin-inline: auto;
  overflow-x: clip;
}

a {
  text-decoration: none;
  color: inherit;
  transition: opacity 0.3s;
}

.about-business-bg {
  position: relative;
  overflow-x: clip;
}
.about-business-bg::before {
  content: "";
  position: absolute;
  left: -9.375rem;
  top: 11.8125rem;
  width: 103rem;
  height: 159.6875rem;
  background: url(../images/common/avout-bg-03.png) no-repeat var(--about-business-bg-position, center top)/var(--about-business-bg-size, 100% auto);
  z-index: 1;
  pointer-events: none;
  margin-right: calc(50% - 50vw);
  left: 44%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .about-business-bg::before {
    background: url(../images/common/about-bubble-sp-mask.png) no-repeat center center/100% auto;
    width: 28.1875rem;
    height: 76.375rem;
    left: 48%;
    top: 9.625rem;
    transform: translateX(-50%);
  }
}

.abw-bg {
  position: relative;
  overflow-x: clip;
}
.abw-bg::before {
  content: "";
  position: absolute;
  width: 98.30625rem;
  height: 91.193125rem;
  background: url(../images/common/about-work_bg.png) no-repeat center center/contain;
  left: 50%;
  transform: translateX(-50%);
  top: 9.375rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .abw-bg::before {
    background: url(../images/common/abw-sp_bg.png) no-repeat center center/contain;
    width: 27.0625rem;
    height: 100rem;
    left: 42%;
    transform: translateX(-50%);
    top: 16.3125rem;
    z-index: 0;
  }
}

.inner {
  width: 100%;
  max-width: 78.125rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1.5625rem;
  padding-left: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .inner {
    padding-right: 1.25rem;
    padding-left: 1.25rem;
    max-width: 37.5rem;
  }
}

.inner-large {
  width: 100%;
  max-width: 77.5rem;
  margin-right: auto;
  margin-left: auto;
  padding-inline: 1.25rem;
}
@media screen and (max-width: 767px) {
  .inner-large {
    padding-inline: 1.25rem;
    width: 100%;
  }
}

.layout-header {
  position: fixed;
  z-index: 900;
  top: 0;
  right: 0;
  left: 0;
}

.p-wrap {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
}

.top-tc__bg {
  position: relative;
  overflow-x: clip;
  background-color: #1A61AE;
}
.top-tc__bg::before {
  content: "";
  position: absolute;
  width: 94.9375rem;
  height: 94.5rem;
  background: url(../images/common/top-tc-bubble.png) no-repeat center center/contain;
  left: 49%;
  transform: translateX(-50%);
  top: 6.1875rem;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .top-tc__bg::before {
    top: 16.25rem;
    left: 50%;
    transform: translateX(-50%);
    width: 29.75rem;
    height: 29.75rem;
    background: url(../images/common/top-team-sp_bg.png) no-repeat center/contain;
  }
}

.l-inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 25px;
}
@media screen and (max-width: 767px) {
  .l-inner {
    padding: 0 20px;
  }
}

.btn-back-home__wrap {
  text-align: center;
  margin-top: 6.875rem;
}
@media screen and (max-width: 767px) {
  .btn-back-home__wrap {
    margin-top: 3.125rem;
  }
}

.btn-back-home {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(100%, 15.5625rem);
  height: 100%;
  background-color: #002A59;
  border: 1px solid transparent;
  border-radius: 2.25rem;
  padding: 1rem 1.125rem;
  transition: 0.5s;
  color: #fff;
  font-size: 1.25rem;
  line-height: 1.5;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  overflow: hidden;
}
.btn-back-home:hover {
  color: #002A59;
  background-color: #fff;
  border-color: ＄blue-btn;
}
@media screen and (max-width: 767px) {
  .btn-back-home {
    width: min(100%, 14.3125rem);
    padding: 0.75rem 0.875rem;
    font-size: 1rem;
  }
}

.btn-primary {
  display: inline-flex;
  gap: 0.625rem;
  align-items: center;
  justify-content: center;
  width: 100%;
  border: 1px solid #1C387B;
  border-radius: 2.1875rem;
  color: #1C387B;
  font-size: 0.9375rem;
  line-height: 1.4666666667;
  letter-spacing: 0.05em;
  font-weight: 500;
  padding: 0.8125rem 0.625rem;
  transition: background-color 0.5s, color 0.5s, border-color 0.5s;
  background-color: #fff;
}
.btn-primary::after {
  content: "";
  width: 0.46rem;
  height: 0.795625rem;
  -webkit-mask-image: url("../images/common/btn-blue.png");
          mask-image: url("../images/common/btn-blue.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  background: currentColor;
}
.btn-primary:hover {
  background-color: #1C387B;
  color: #fff;
  opacity: 1;
}

.btn-primary--navy {
  background-color: #1C387B;
  color: #fff;
}
.btn-primary--navy:hover {
  background-color: #fff;
  color: #1C387B;
  opacity: 1;
}

.btn-primary02 {
  display: inline-flex;
  gap: 0.625rem;
  align-items: center;
  justify-content: center;
  width: 9.875rem;
  border: 1px solid #1C387B;
  border-radius: 2.1875rem;
  color: #1C387B;
  font-size: 0.9375rem;
  line-height: 1.4666666667;
  letter-spacing: 0.05em;
  font-weight: 500;
  padding: 0.8125rem 0.625rem;
  transition: background-color 0.5s, color 0.5s, border-color 0.5s;
  background-color: #fff;
  opacity: 0.9;
}
.btn-primary02::after {
  content: "";
  width: 0.46rem;
  height: 0.795625rem;
  -webkit-mask-image: url("../images/common/btn-blue.png");
          mask-image: url("../images/common/btn-blue.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  background: currentColor;
}
.btn-primary02:hover {
  background-color: #1C387B;
  color: #fff;
  opacity: 1;
}

.btn-primary02--navy {
  background-color: #1C387B;
  color: #fff;
}
.btn-primary02--navy:hover {
  background-color: #fff;
  color: #1C387B;
  opacity: 1;
}

.btn02 {
  position: relative;
  background-color: #1C387B;
  border-radius: 35px;
  color: #fff;
  cursor: pointer;
  font-family: "Noto Sans JP", sans-serif;
  line-height: normal;
  font-size: 0.9375rem;
  letter-spacing: 0.45px;
  font-weight: 900;
  padding: 0.875rem 0.625rem 0.875rem 2.3125rem;
  display: inline-block;
  transition: background-color 0.5s, color 0.5s, border-color 0.5s, opacity 0.5s;
  width: min(100%, 12.5rem);
  min-width: 12.5rem;
  border: 1px solid transparent;
  box-sizing: border-box;
  opacity: 0.9;
}

.btn02:hover {
  background-color: #fff;
  color: #1C387B;
  opacity: 1;
  border: 1px solid #1C387B;
}
.btn02:hover::before {
  background: #1C387B;
}

.btn02::before {
  position: absolute;
  content: "";
  width: 7.36px;
  height: 12.73px;
  right: 36px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-mask-image: url("../images/common/btn-blue.png");
          mask-image: url("../images/common/btn-blue.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  background: #fff;
  transition: background 0.5s;
}

.btn02__text {
  font-size: 0.9375rem;
  line-height: 1.4666666667;
  letter-spacing: 0.05em;
  font-weight: 500;
  color: #fff;
  transition: color 0.5s;
}

.btn02:hover .btn02__text {
  color: #1C387B;
}

.btn03 {
  position: relative;
  display: inline-block;
  max-width: 17.875rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .btn03 {
    max-width: 13.9375rem;
  }
}

.btn03__text::after {
  content: "";
  position: absolute;
  bottom: 0.1875rem;
  left: 0;
  width: 16.125rem;
  height: 0.125rem;
  background-color: #9F9F9F;
  z-index: 3;
  transition: opacity 0.5s;
}
@media screen and (max-width: 767px) {
  .btn03__text::after {
    width: 13rem;
  }
}

.btn03__icon {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4.625rem;
  height: 4.625rem;
  border-radius: 50%;
  z-index: 1;
  transition: 0.5s;
  background-image: linear-gradient(45deg, #326aff 0%, #44bbff 100%);
}
@media screen and (max-width: 767px) {
  .btn03__icon {
    width: 3.3125rem;
    height: 3.3125rem;
    right: 0.3125rem;
  }
}
.btn03__icon::before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #D2E8F7;
  border-radius: 50%;
  transition: 0.5s;
  opacity: 1;
}
.btn03__icon::after {
  content: "";
  position: absolute;
  right: 1.8125rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.9825rem;
  height: 0.88375rem;
  background-color: #9F9F9F;
  -webkit-mask-image: url("../images/common/btn-gray.png");
          mask-image: url("../images/common/btn-gray.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  z-index: 2;
  transition: background-color 0.5s;
}
@media screen and (max-width: 767px) {
  .btn03__icon::after {
    width: 0.67rem;
    height: 0.57125rem;
    right: 1.3125rem;
  }
}

@media (any-hover: hover) {
  .btn03:hover .btn03__icon::after {
    background-color: #fff;
  }
  .btn03:hover .btn03__icon::before {
    opacity: 0;
  }
}
.btn03__text {
  position: relative;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: #1877B8;
  padding-bottom: 1.3125rem;
  padding-right: 5.625rem;
  z-index: 3;
  width: 100%;
  transition: color 0.5s;
}
@media screen and (max-width: 767px) {
  .btn03__text {
    display: flex;
    align-items: center;
    min-height: 3.3125rem;
    white-space: nowrap;
    font-size: 1rem;
    line-height: 1.5;
    padding-bottom: 0;
    padding-right: 9.3125rem;
  }
}

.btn03__text.btn03--white {
  color: #fff;
}

.btn03__text.btn03--black {
  color: #444;
  padding-right: 11.375rem;
}

.btn03--arrow-black .btn03__icon::after {
  background-color: #444;
}

@media (any-hover: hover) {
  .btn03--arrow-black:hover .btn03__icon::after {
    background-color: #444;
  }
}
.btn04 {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 155px;
  height: 35px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.5s;
}
.btn04::before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 35px;
  height: 35px;
  background-color: #1B386C;
  border-radius: 50%;
  z-index: 1;
  transition: background-color 0.5s;
}
.btn04::after {
  content: "";
  position: absolute;
  right: 29px;
  top: 50%;
  transform: translateY(-50%);
  width: 7.43px;
  height: 6.69px;
  background-color: #fff;
  mask-image: url("../images/common/btn-gray.png");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  -webkit-mask-image: url("../images/common/btn-gray.png");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  z-index: 2;
  transition: background-color 0.5s;
}

.btn05 {
  position: relative;
  display: inline-block;
  max-width: 17.875rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .btn05 {
    max-width: 19.375rem;
  }
}

.btn05.btn05--long {
  max-width: 26.75rem;
}
@media screen and (max-width: 767px) {
  .btn05.btn05--long {
    max-width: 19.375rem;
  }
}

.btn05__text::after {
  content: "";
  position: absolute;
  bottom: 0.1875rem;
  left: 0;
  width: 16.0625rem;
  height: 0.125rem;
  background-color: #9F9F9F;
  z-index: 3;
  transition: opacity 0.5s;
}
@media screen and (max-width: 767px) {
  .btn05__text::after {
    width: 12.625rem;
  }
}

.btn05.btn05--long .btn05__text::after {
  width: 23.75rem;
}
@media screen and (max-width: 767px) {
  .btn05.btn05--long .btn05__text::after {
    width: 17.1875rem;
  }
}

.btn05__icon {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4.625rem;
  height: 4.625rem;
  border-radius: 50%;
  z-index: 1;
  transition: 0.5s;
  background-image: linear-gradient(45deg, #326aff 0%, #44bbff 100%);
}
@media screen and (max-width: 767px) {
  .btn05__icon {
    width: 3.3125rem;
    height: 3.3125rem;
    right: 5.3125rem;
  }
}
.btn05__icon::before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #D2E8F7;
  border-radius: 50%;
  transition: 0.5s;
  opacity: 1;
}
.btn05__icon::after {
  content: "";
  position: absolute;
  right: 1.8125rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.9825rem;
  height: 0.88375rem;
  background-color: #9F9F9F;
  -webkit-mask-image: url("../images/common/btn-gray.png");
          mask-image: url("../images/common/btn-gray.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  z-index: 2;
  transition: background-color 0.5s;
}
@media screen and (max-width: 767px) {
  .btn05__icon::after {
    width: 0.67rem;
    height: 0.57125rem;
    right: 1.3125rem;
  }
}

.btn05--long {
  max-width: 26.75rem;
}
@media screen and (max-width: 767px) {
  .btn05--long {
    max-width: 19.375rem;
  }
}

.btn05.btn05--long .btn05__icon {
  right: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .btn05.btn05--long .btn05__icon {
    right: 1.5625rem;
  }
}

@media (any-hover: hover) {
  .btn05:hover .btn05__icon::after {
    background-color: #fff;
  }
  .btn05:hover .btn05__icon::before {
    opacity: 0;
  }
}
.btn05__text {
  position: relative;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
  padding-bottom: 1.3125rem;
  z-index: 3;
  width: 100%;
  transition: color 0.5s;
}
@media screen and (max-width: 767px) {
  .btn05__text {
    font-size: 1rem;
    line-height: 1.5;
    padding-bottom: 0.8125rem;
  }
}

/* ==================================
  btn06（PCファースト）
  - 右側にアイコンがabsoluteでいるので、その分の余白を確保して崩れ防止
================================== */
.btn06 {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 19.3125rem;
  /* ★重要：アイコンが乗ってくる分の余白を確保
     これで「テキストが長い/親幅が狭い」場合でも重なりにくい */
  padding-right: 4.625rem;
}
@media screen and (max-width: 767px) {
  .btn06 {
    max-width: 14.375rem;
    padding-right: 3.3125rem;
  }
}

/* ==================================
  text
  - 下線はテキスト幅に追従させる（固定幅をやめる）
================================== */
.btn06__text {
  position: relative;
  display: inline-block;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: #D2E8F7;
  padding-bottom: 1.3125rem;
  z-index: 3;
  transition: color 0.5s;
}
@media screen and (max-width: 767px) {
  .btn06__text {
    font-size: 1rem;
    line-height: 1.5;
    padding-bottom: 0.8125rem;
  }
}
.btn06__text {
  /* 下線 */
}
.btn06__text::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.1875rem;
  width: 17.5rem;
  height: 0.125rem;
  background-color: #9F9F9F;
  z-index: 3;
  transition: opacity 0.5s;
}
@media screen and (max-width: 767px) {
  .btn06__text::after {
    width: 10.625rem;
  }
}

/* ==================================
  text modifier（white）
  - SPだけ中央寄せ（要件）
================================== */
.btn06__text--white {
  color: #fff;
}
@media screen and (max-width: 767px) {
  .btn06__text--white {
    /* spanでも中央寄せが崩れないように「箱」にする */
    display: block;
    width: 100%;
    text-align: center;
  }
}

/* ==================================
  icon（absolute）
================================== */
.btn06__icon {
  position: absolute;
  right: 0;
  top: 31%;
  transform: translateY(-50%);
  width: 4.625rem;
  height: 4.625rem;
  border-radius: 50%;
  z-index: 1;
  transition: 0.5s;
  background-image: linear-gradient(45deg, #326aff 0%, #44bbff 100%);
  /* SP */
}
@media screen and (max-width: 767px) {
  .btn06__icon {
    top: 40%;
    width: 3.3125rem;
    height: 3.3125rem;
    right: -0.6875rem;
  }
}
.btn06__icon::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: #D2E8F7;
  border-radius: 50%;
  transition: 0.5s;
  opacity: 1;
}
.btn06__icon::after {
  content: "";
  position: absolute;
  right: 1.8125rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.9825rem;
  height: 0.88375rem;
  background-color: #9F9F9F;
  -webkit-mask-image: url("../images/common/btn-gray.png");
          mask-image: url("../images/common/btn-gray.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  z-index: 2;
  transition: background-color 0.5s;
}
@media screen and (max-width: 767px) {
  .btn06__icon::after {
    width: 0.67rem;
    height: 0.57125rem;
    right: 1.3125rem;
  }
}

/* hover */
@media (any-hover: hover) {
  .btn06:hover .btn06__icon::after {
    background-color: #fff;
  }
  .btn06:hover .btn06__icon::before {
    opacity: 0;
  }
}
.c-scroll-down {
  padding-bottom: 3.75rem;
  position: relative;
  font-size: 0.8125rem;
  font-weight: 400;
  writing-mode: vertical-rl;
  color: #333333;
  font-family: "Plus Jakarta Sans", sans-serif;
}
@media screen and (max-width: 767px) {
  .c-scroll-down {
    font-size: 0.625rem;
  }
}

.c-scroll-down::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 2.1875rem;
  background: #333;
  animation: scroll-down 2s infinite;
}

@keyframes scroll-down {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.display-none {
  display: none;
}

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

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

.header__hamburger {
  display: none;
  margin: 0;
  padding: 0;
  outline: none;
  border: none;
  position: relative;
  z-index: 1001;
  width: 4.0625rem;
  height: 4.0625rem;
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .header__hamburger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
}

.header__hamburger::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background-color: #1A61AE;
}

.header__hamburger span {
  position: absolute;
  top: 50%;
  left: 1.4375rem;
  z-index: 1;
  display: block;
  height: 0.125rem;
  background-color: #fff;
  border-radius: 0.125rem;
  transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
}

.header__hamburger span:nth-child(1) {
  width: 1.25rem;
  transform: translate(0, -0.375rem);
}

.header__hamburger span:nth-child(2) {
  width: 0.9375rem;
  transform: translate(0, -0.0625rem);
}

.header__hamburger span:nth-child(3) {
  width: 0.4375rem;
  transform: translate(0, 0.25rem);
}

.header__hamburger.is-active span {
  width: 1.25rem;
}

.header__hamburger.is-active span:nth-child(1) {
  transform: translate(0, 0) rotate(25deg);
}

.header__hamburger.is-active span:nth-child(2) {
  opacity: 0;
}

.header__hamburger.is-active span:nth-child(3) {
  transform: translate(0, 0) rotate(-205deg);
}

.sidebar__text {
  margin-top: 0.9375rem;
  margin-left: 2.5rem;
  font-size: 1.125rem;
  line-height: 1.6111111111;
  letter-spacing: 0;
  font-weight: 500;
  color: #000;
  max-width: 39.375rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .sidebar__text {
    margin-top: 1.125rem;
    font-size: 1rem;
    line-height: 1.6875;
    width: 100%;
    margin-inline: auto;
  }
}

.sidebar__text--current {
  margin-left: 0;
  max-width: 39.375rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .sidebar__text--current {
    width: 100%;
    margin-left: 0;
    margin-top: 1.5rem;
  }
}

.sidebar__text--aside {
  margin-top: 2.5rem;
  margin-inline: 0;
  font-weight: 700;
  line-height: 1.5;
  font-size: 1.5rem;
  position: relative;
  padding-left: 0.625rem;
}
.sidebar__text--aside::before {
  content: "";
  position: absolute;
  bottom: -1.875rem;
  left: 0;
  width: 18.125rem;
  height: 1px;
  background-image: repeating-linear-gradient(90deg, #1a61ae, #1a61ae 1px, transparent 1px, transparent 2px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 2px;
}
@media screen and (max-width: 767px) {
  .sidebar__text--aside::before {
    width: 12.5rem;
    margin-top: 2.5rem;
    font-size: 1.1875rem;
    line-height: 1.4736842105;
  }
}

.sidebar__text01 {
  font-size: 1.125rem;
  line-height: 1.6111111111;
  letter-spacing: 0;
  font-weight: 500;
  color: #000;
  padding-left: 2.5rem;
}
@media screen and (max-width: 767px) {
  .sidebar__text01 {
    font-size: 1rem;
    line-height: 1.6875;
    padding-left: 1.875rem;
  }
}

.sidebar__title01 {
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #1A61AE;
  width: 100%;
  max-width: 100%;
  margin-right: auto;
  margin-left: 0;
  margin-top: 4.625rem;
}
@media screen and (max-width: 767px) {
  .sidebar__title01 {
    font-size: 1.5rem;
    line-height: 1.5;
    margin-top: 2.5rem;
  }
}

.sidebar__title02 {
  margin-top: 2.5rem;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 600;
  color: #000;
  display: flex;
  gap: 0.9375rem;
}
.sidebar__title02::before {
  content: "";
  width: 1.25rem;
  height: 1.25rem;
  aspect-ratio: 1/1;
  background: url("../images/common/bubble-01.png") no-repeat center center/contain;
  border-radius: 50%;
  transform: translateY(28%);
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .sidebar__title02::before {
    width: 0.9375rem;
    height: 0.9375rem;
  }
}
@media screen and (max-width: 767px) {
  .sidebar__title02 {
    font-size: 1.25rem;
    line-height: 1.35;
  }
}

.sidebar__title02--current::before,
.sidebar__title02--work::before {
  content: none;
}

.sidebar__title02--current {
  margin-top: 1.5rem;
  padding-left: 2.5rem;
}
@media screen and (max-width: 767px) {
  .sidebar__title02--current {
    padding-left: 0;
  }
}

.sidebar__title02--work {
  padding-left: 0;
}

.text-large01 {
  font-size: 1.875rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #000;
}
@media screen and (max-width: 767px) {
  .text-large01 {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}

.text-large01--white {
  color: #fff;
}

.text-medium01 {
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .text-medium01 {
    font-size: 1rem;
    line-height: 1.6875;
    letter-spacing: 0;
  }
}

.text-regular01 {
  font-size: 1rem;
  line-height: 1.4222222222;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #333333;
}

.text-regular01--white {
  color: #fff;
}

.title01_sub {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 1.125rem;
  line-height: 1.2777777778;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #1246C3;
  display: flex;
  align-items: center;
  gap: 5px;
}
.title01_sub::before {
  content: "";
  width: 10px;
  height: 10px;
  aspect-ratio: 1/1;
  background: url("../images/common/title_01.svg") no-repeat center center/contain;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  .title01_sub {
    font-size: 1rem;
    line-height: 1.25;
  }
}

.title01_sub--white {
  color: #fff;
}

.title01_sub--small {
  font-size: 1.1289375rem;
  line-height: 1.2733211537;
}
@media screen and (max-width: 767px) {
  .title01_sub--small {
    font-size: 0.752375rem;
    line-height: 1.2460541618;
  }
}

.title01_main {
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 2.5rem;
  line-height: 1.3;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #3987FD;
  margin-top: 15px;
}
@media screen and (max-width: 767px) {
  .title01_main {
    margin-top: 10px;
    font-size: 2rem;
    line-height: 1.3125;
    letter-spacing: 0;
  }
}

.title01_main--white {
  color: #fff;
}

.title01_main--small {
  font-size: 2.5rem;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .title01_main--small {
    font-size: 1.5625rem;
    line-height: 1.32;
  }
}

.title01_sub--gray {
  color: #A8BACE;
}

.title02__title {
  position: relative;
  display: inline-block;
  padding-left: 3.9375rem;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 4rem;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: 700;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .title02__title {
    padding-left: 0.3125rem;
    font-size: 2.25rem;
    line-height: 1.5;
  }
}
.title02__title::before {
  position: absolute;
  top: 50%;
  left: 0;
  content: "";
  width: 1.875rem;
  height: 1.875rem;
  aspect-ratio: 1/1;
  transform: translateY(-50%);
  background: url("../images/common/title02.png") no-repeat center center/contain;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  .title02__title::before {
    display: none;
  }
}

.work-company__button {
  margin-top: 6.375rem;
  margin-bottom: 6.375rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .work-company__button {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 99999;
    margin-top: 5rem;
    margin-bottom: 3.125rem;
    padding-bottom: env(safe-area-inset-bottom, 0);
  }
}

.work-company__button-link {
  display: block;
  width: 100%;
  max-width: 35.5rem;
  margin-inline: auto;
  padding: 2.3125rem 1.25rem;
  border-radius: 3.75rem;
  background-color: #002A59;
  color: #fff;
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .work-company__button-link {
    max-width: 19.375rem;
    padding: 1.1875rem 1rem;
    font-size: 1rem;
    line-height: 1.5;
  }
}

.about-business {
  position: relative;
  background-color: #1A61AE;
  overflow-x: clip;
}

.about-business--layout {
  padding-top: 4.57875rem;
}
@media screen and (max-width: 767px) {
  .about-business--layout {
    padding-top: 2.8925rem;
  }
}

.about-business__inner {
  position: relative;
  z-index: 1;
}

.about-business__title-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .about-business__title-wrap {
    align-items: flex-start;
  }
}

.about-business__content {
  margin-top: 2.875rem;
}
@media screen and (max-width: 767px) {
  .about-business__content {
    margin-top: 2.0175rem;
  }
}

.about-business__list {
  display: flex;
  justify-content: space-between;
  gap: 6.1875rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .about-business__list {
    flex-direction: column;
    align-items: center;
    gap: 2.5rem;
  }
}

.about-business__item {
  width: 100%;
  max-width: 21.875rem;
}

.about-business__item-title {
  margin: 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .about-business__item-title {
    font-size: 1.5rem;
  }
}

.about-business__item {
  width: 100%;
  max-width: 21.875rem;
}

.about-business__item-title {
  margin: 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .about-business__item-title {
    font-size: 1.5rem;
  }
}

.about-business__item-image {
  position: relative;
  margin-top: 1.5625rem;
  width: 100%;
  max-width: 21.875rem;
  height: 21.875rem;
  overflow: hidden;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  .about-business__item-image {
    max-width: 17.5rem;
    height: 17.5rem;
    margin-inline: auto;
  }
}

.about-business__item-image img,
.about-business__item-overlay {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  transform: scale(1);
  transition: transform 0.3s ease;
  transform-origin: center;
}

/* 画像 */
.about-business__item-image img {
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}

/* オーバーレイ */
.about-business__item-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
  transition: 0.3s ease;
  pointer-events: none;
  opacity: 0;
}

/* hover時は同じ割合で縮小 */
.about-business__item-image:hover img,
.about-business__item-image:hover .about-business__item-overlay {
  transform: scale(0.9);
  opacity: 1;
}

/* hover時に暗さを強める */
.about-business__item-image:hover .about-business__item-overlay {
  background-color: rgba(0, 0, 0, 0.5);
}

.about-business__btn {
  margin-top: 3.75rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .about-business__btn {
    margin-top: 3.625rem;
  }
}

.about-Company--layout {
  margin-top: 5.5625rem;
  margin-bottom: 5.375rem;
}
@media screen and (max-width: 767px) {
  .about-Company--layout {
    margin-top: 1.4375rem;
    margin-bottom: 2.4375rem;
  }
}

.about-Company__inner {
  position: relative;
  z-index: 1;
}

.about-Company__title {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .about-Company__title {
    align-items: flex-start;
    order: 1;
  }
}

.about-Company__content {
  margin-top: 1.96875rem;
  max-width: 77.5rem;
  width: 100%;
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 4.0625rem;
}
@media screen and (max-width: 767px) {
  .about-Company__content {
    flex-direction: column;
    gap: 2rem;
    max-width: 100%;
  }
}

.about-Company__img {
  width: 100%;
  max-width: 38.25rem;
  height: auto;
  aspect-ratio: 612/387;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 767px) {
  .about-Company__img {
    max-width: 100%;
    order: 2;
  }
}

.about-Company__list {
  max-width: 32.625rem;
  width: 100%;
  margin-inline: auto;
  gap: 1rem;
}
@media screen and (max-width: 767px) {
  .about-Company__list {
    max-width: 100%;
    order: 3;
  }
}

.list__row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  border-bottom: 1px solid #ddd;
  padding-block: 1rem;
}
@media screen and (max-width: 767px) {
  .list__row {
    flex-direction: column;
    gap: 0.5rem;
    padding-block: 1.5rem;
    align-items: flex-start;
  }
}

.list__label {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #333333;
  line-height: 1.5;
  width: 11.25rem;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .list__label {
    font-size: 1rem;
    line-height: 1.6;
  }
}

.list__value {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #333333;
  line-height: 1.6;
  flex: 1;
}
@media screen and (max-width: 767px) {
  .list__value {
    font-size: 1rem;
    line-height: 1.6;
  }
}

.about-Company__map {
  position: relative;
  margin-top: 5.375rem;
  width: 100%;
  overflow: hidden;
  /* アスペクト比 1194:614 を維持（padding の % は親の width を基準にする） */
  height: 0;
  padding-bottom: 51.42%;
}
@media screen and (max-width: 767px) {
  .about-Company__map {
    order: 4;
    margin-top: 1.875rem;
  }
}
.about-Company__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.about-message {
  position: relative;
  overflow-x: clip;
  z-index: 1;
}
.about-message::before {
  content: "";
  position: absolute;
  width: 94.625rem;
  height: 34.375rem;
  background: url(../images/common/about-message-bg.png) no-repeat center center/contain;
  left: -3.125rem;
  top: 6.75rem;
  z-index: -1;
  margin-right: calc(50% - 50vw);
  left: 49%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .about-message::before {
    background: url(../images/common/about-message-bgsp.png) no-repeat center center/contain;
    width: 3.84375rem;
    height: 4.40625rem;
    top: 5.8125rem;
    left: 94%;
    transform: translateX(-50%);
  }
}

.about-message--layout {
  margin-top: 10.25rem;
  position: relative;
  padding-bottom: 13.125rem;
}
@media screen and (max-width: 767px) {
  .about-message--layout {
    margin-top: 11.25rem;
    padding-bottom: 0;
  }
}

.about-message__content {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .about-message__content {
    flex-direction: column;
  }
}

@media screen and (max-width: 767px) {
  .about-message__title-wrap {
    margin-top: 0.625rem;
    order: 1;
  }
}

@media screen and (max-width: 767px) {
  .about-message__img {
    order: 2;
  }
}

.about-message__img img {
  max-width: 35.5rem;
  width: 100%;
  height: auto;
  aspect-ratio: 568/432;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767px) {
  .about-message__img img {
    max-width: 100%;
    margin-top: 2.125rem;
  }
}

.about-message__title {
  max-width: 33rem;
  width: 100%;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  .about-message__title {
    max-width: 100%;
    margin-top: 2rem;
    display: contents;
  }
}

.about-message__text {
  margin-top: 1.25rem;
}
@media screen and (max-width: 767px) {
  .about-message__text {
    order: 3;
  }
}

.about-message02 {
  background-color: #1A61AE;
}

.about-message02--layout {
  padding-block: 6.3125rem 4.6875rem;
}
@media screen and (max-width: 767px) {
  .about-message02--layout {
    padding-block: 2.875rem 4.6875rem;
  }
}

.about-message02__inner {
  position: relative;
  z-index: 1;
}

.about-message02__content {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2.5rem;
}
@media screen and (max-width: 767px) {
  .about-message02__content {
    max-width: 100%;
    flex-direction: column;
    gap: 2rem;
  }
}
.about-message02__content .about__map {
  flex: 1 1 auto;
  min-width: 18.75rem;
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .about-message02__content .about__map {
    margin-top: 2rem;
  }
}

.about-message02__list {
  max-width: 34.125rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .about-message02__list {
    display: contents;
    max-width: 100%;
    order: 1;
  }
}

.about-message02__title {
  margin-top: 1.25rem;
}
@media screen and (max-width: 767px) {
  .about-message02__title {
    margin-top: 2.25rem;
    order: 1;
  }
}

.about-message02__text {
  margin-top: 2.375rem;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  .about-message02__text {
    order: 3;
  }
}

.about-message02__lead {
  color: #fff;
  font-size: 1.875rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .about-message02__lead {
    font-size: 1.25rem;
    line-height: 1.5;
    white-space: normal;
  }
}

.about-message02__body {
  margin-top: 1.25rem;
}
.about-message02__img {
  flex: 0 1 39.5625rem;
  min-width: 0;
  height: auto;
}
@media screen and (max-width: 767px) {
  .about-message02__img {
    position: relative;
    flex: initial;
    min-width: initial;
    margin-top: 2rem;
    width: 100%;
    max-width: 21.875rem;
    order: 2;
  }
}
.about-message02__img::before {
  content: "";
  position: absolute;
  top: 5.4375rem;
  left: 50%;
  transform: translateX(-50%);
  width: 26.71875rem;
  height: 9rem;
  background: url(../images/common/about-message-bgsp.png) no-repeat center center/contain;
  z-index: -1;
  display: none;
}
@media screen and (max-width: 767px) {
  .about-message02__img::before {
    display: inline-block;
  }
}

.about-message02__img img {
  aspect-ratio: 633/540;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 767px) {
  .about-message02__img img {
    aspect-ratio: 350/314;
  }
}

.about-mvv {
  position: relative;
  overflow-x: clip;
  background-color: #1A61AE;
  border: 1px solid #A8BACE;
  z-index: 0;
  border: none;
}
.about-mvv::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 13rem;
  background: url(../images/common/bg-daen.png) no-repeat center center/100% 100%;
  left: 0;
  top: -13rem;
}
@media screen and (max-width: 767px) {
  .about-mvv::before {
    top: -3.21875rem;
    height: 3.21875rem;
    background-image: url(../images/common/bg-sp-daen.png);
  }
}

.about-mvv--layout {
  margin-top: 4rem;
  padding-bottom: 5.25rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about-mvv--layout {
    padding-top: 3.0625rem;
    padding-bottom: 2.875rem;
    margin-top: 5.625rem;
  }
}

.about-mvv__inner {
  position: relative;
}
.about-mvv__inner::before {
  content: "";
  display: block;
  position: absolute;
  background: url(../images/common/mvv-bg.png) no-repeat center center/100% 100%;
  left: -7.125rem;
  top: 1.875rem;
  width: 4.90625rem;
  height: 6.25rem;
}
@media screen and (max-width: 767px) {
  .about-mvv__inner::before {
    background-image: url(../images/common/mvv-bg-sp.png);
  }
}
.about-mvv__inner::after {
  content: "";
  position: absolute;
  background: url(../images/common/mvv-bg02.png) no-repeat center center/100% 100%;
  right: -7.3125rem;
  left: auto;
  bottom: -3.21875rem;
  width: 4.90625rem;
  height: 6.25rem;
}
@media screen and (max-width: 767px) {
  .about-mvv__inner::after {
    background: url(../images/common/mvv-bg02-sp.png) no-repeat center center/contain;
    width: 2.03125rem;
    height: 2.03125rem;
    right: 0;
    bottom: -2.3125rem;
    z-index: -1;
  }
}

.about-mvv__list {
  border-radius: 0.625rem;
  border: 1px solid #A8BACE;
  background: #3877BB;
}

.list01 {
  padding: 3.5625rem 1.9375rem 5.625rem;
}
@media screen and (max-width: 767px) {
  .list01 {
    padding: 0.5625rem 1.25rem 2.1875rem 1.25rem;
  }
}

.list01__row {
  display: grid;
  grid-template-columns: 13.75rem 1fr;
  align-items: center;
  -moz-column-gap: 10rem;
       column-gap: 10rem;
  padding: 2.0625rem 1.625rem 1.5625rem 3.5625rem;
  border-bottom: 2px solid rgba(255, 255, 255, 0.28);
}
@media screen and (max-width: 767px) {
  .list01__row {
    grid-template-columns: 1fr;
    -moz-column-gap: 0;
         column-gap: 0;
    row-gap: 0.625rem;
    padding-bottom: 0;
    padding: 1.5rem 0rem 0.625rem 0rem;
  }
}

.list01__headline {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  margin: 0;
}

.list01__dot {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: url(../images/common/about-mvv.png) no-repeat center/contain;
  opacity: 0.9;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .list01__dot {
    width: 0.75rem;
    height: 0.75rem;
  }
}

.list01__label {
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: linear-gradient(182deg, #FFF 1.73%, #FFF 60.84%, #6AD9FF 80.9%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .list01__label {
    font-size: 1.125rem;
  }
}

.list01__body {
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #fff;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .list01__body {
    font-size: 1rem;
  }
}

.archive-interview {
  position: relative;
  overflow-x: clip;
}
.archive-interview::before {
  content: "";
  position: absolute;
  width: 106.25rem;
  height: 87.5rem;
  background: url(../images/common/interview-bg.png) no-repeat center center/contain;
  z-index: 0;
  left: 53%;
  transform: translateX(-50%);
  top: 7.75rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .archive-interview::before {
    width: 32.375rem;
    height: 74.6875rem;
    top: 5.125rem;
    background: url(../images/common/interview-bg-sp.png) no-repeat center center/contain;
    transform: translateX(-50%);
    left: 56%;
  }
}

.archive-interview--layout {
  margin-top: 7.625rem;
}
@media screen and (max-width: 767px) {
  .archive-interview--layout {
    margin-top: 15rem;
  }
}

.archive-interview__list {
  margin-top: 3.875rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  justify-content: space-between;
  gap: 3.125rem;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .archive-interview__list {
    margin-top: 1.5625rem;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}

.archive-interview__item {
  position: relative;
  padding: 0.625rem;
}

.archive-interview__item:hover .archive-interview__card {
  background-color: #E7F2FF;
}

.archive-interview__card {
  position: relative;
  display: block;
  text-decoration: none;
  background-color: transparent;
  height: 100%;
  transition: box-shadow 0.3s;
  transition: background-color 0.5s ease;
  z-index: 1;
  border-radius: 0.75rem;
}

.archive-interview__card::before {
  content: "";
  position: absolute;
  top: -0.625rem;
  left: -0.625rem;
  right: -0.625rem;
  bottom: -0.625rem;
  border-radius: 0.75rem;
  background-color: #E7F2FF;
  z-index: -1;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.archive-interview__card:hover::before {
  opacity: 1;
}

.archive-interview__card:hover .archive-interview__img {
  transform: scale(1.1);
}

.archive-interview__image {
  border-radius: 0.75rem;
  width: 100%;
  aspect-ratio: 320/406;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .archive-interview__image {
    aspect-ratio: 167/212;
  }
}

.archive-interview__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.archive-interview__text {
  margin-top: 3.125rem;
  font-size: 1.25rem;
  line-height: 1.5;
  color: #1A61AE;
  text-align: center;
  font-weight: 500;
}

.archive-interview__card-title {
  margin-top: 3.125rem;
  font-size: 1.25rem;
  line-height: 1.5;
  font-weight: 500;
  color: #1A61AE;
  padding-bottom: 1.375rem;
  border-bottom: 0.1125rem dotted #1A61AE;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .archive-interview__card-title {
    font-size: 1rem;
    line-height: 1.6875;
    margin-top: 1.5rem;
  }
}

.archive-interview__name {
  margin-top: 1.25rem;
  font-size: 1.5rem;
  font-weight: 600;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .archive-interview__name {
    font-size: 1rem;
    line-height: 1.5;
    margin-top: 1.25rem;
  }
}

.archive-interview__position {
  margin-top: 0.9375rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #1A61AE;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .archive-interview__position {
    font-size: 0.875rem;
    line-height: 1.5;
    margin-top: 0.5rem;
  }
}

.archive-interview__text + .archive-interview__text {
  margin-top: 0.625rem;
}

.archive-interview__empty {
  margin-top: 3.75rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #707070;
  text-align: center;
}

.archive-interview__pagination {
  margin-top: 3.75rem;
  text-align: center;
}

.archive-interview__pagination .page-numbers {
  display: inline-block;
  min-width: 2.25rem;
  padding-block: 0.375rem;
  padding-inline: 0.5rem;
  margin-inline: 0.375rem;
  border-radius: 0.375rem;
  color: #1C387B;
  text-decoration: none;
  border: 0.0625rem solid #ddd;
}

.archive-interview__pagination .current {
  background-color: #1C387B;
  color: #fff;
  border-color: #1C387B;
}

.benefits {
  position: relative;
  background-color: #1A61AE;
  overflow-x: clip;
}
.benefits::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 13rem;
  background: url(../images/common/bg-daen.png) no-repeat center center/100% 100%;
  left: 0;
  top: -13rem;
}
@media screen and (max-width: 767px) {
  .benefits::before {
    top: -3.15625rem;
    height: 3.21875rem;
    background-image: url(../images/common/bg-sp-daen.png);
  }
}
.benefits::after {
  content: "";
  position: absolute;
  width: 95.84375rem;
  height: 27.5625rem;
  background: url(../images/common/benefits-bubble.png) no-repeat center center/contain;
  z-index: 0;
  left: 50%;
  transform: translateX(-49%);
  top: 6.125rem;
}
@media screen and (max-width: 767px) {
  .benefits::after {
    width: 43.875rem;
    height: 57.625rem;
    top: 13.75rem;
    background: url(../images/common/benefits-sp.png) no-repeat center center/contain;
    transform: translateX(-50%);
    left: 51%;
  }
}

.benefits--layout {
  margin-top: 18.5625rem;
  padding-bottom: 6.375rem;
}
@media screen and (max-width: 767px) {
  .benefits--layout {
    margin-top: 6.5625rem;
    padding-bottom: 0rem;
  }
}

.benefits__items {
  position: relative;
  z-index: 1;
  margin-top: 3.5rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -moz-column-gap: 2.5rem;
       column-gap: 2.5rem;
  row-gap: 2rem;
}
@media screen and (max-width: 767px) {
  .benefits__items {
    margin-top: 2.5rem;
    grid-template-columns: repeat(1, 1fr);
  }
}

.benefits__item {
  border-radius: 9999px;
  aspect-ratio: 1/1;
  box-sizing: border-box;
  padding-block: 2.375rem;
  padding-inline: 1.5rem;
  background: #fff;
  box-shadow: inset 0 0 0.6409375rem 0 rgba(93, 126, 191, 0.2), inset 0 0 0 0.5rem #f0f0f0;
}
@media screen and (max-width: 767px) {
  .benefits__item {
    width: min(100%, 20rem);
    margin-inline: auto;
    padding-block: 1.75rem;
    padding-inline: 1.25rem;
  }
}

.benefits__item-img {
  width: 8.0625rem;
  height: 8.0625rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .benefits__item-img {
    width: 6.75rem;
    height: 6.75rem;
  }
}

.benefits__item-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}

.benefits__item-title {
  margin-top: 0.0625rem;
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 700;
  color: #1A61AE;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .benefits__item-title {
    font-size: 1.5rem;
  }
}

.benefits__item-text {
  margin-top: 1rem;
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 400;
  color: #333333;
  text-align: center;
  padding-inline: 2vw;
  max-width: 18.8125rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .benefits__item-text {
    font-size: 0.875rem;
    margin-top: 0.625rem;
    max-width: 15rem;
  }
}

.business-technology {
  position: relative;
  overflow-x: clip;
}
.business-technology::before {
  content: "";
  position: absolute;
  width: 6.71875rem;
  height: 8.6875rem;
  background: url(../images/common/business-technology-bubble01.png) no-repeat center center/contain;
  z-index: 1;
  top: 0rem;
  right: -1.5625rem;
}
.business-technology::after {
  content: "";
  position: absolute;
  width: 10.3125rem;
  height: 13.34375rem;
  background: url(../images/common/business-technology-bubble02.png) no-repeat center center/contain;
  z-index: 1;
  bottom: -8rem;
  left: -2.1875rem;
}
@media screen and (max-width: 767px) {
  .business-technology::before, .business-technology::after {
    display: none;
  }
}

.business-technology--layout {
  margin-bottom: 6.4375rem;
}
@media screen and (max-width: 767px) {
  .business-technology--layout {
    margin-top: 2.5rem;
  }
}

.business-technology__content {
  margin-top: 7.8125rem;
  max-width: 41.875rem;
  width: 100%;
  margin-inline: auto;
}

.section-title {
  font-size: 2.5rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #3987FD;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .section-title {
    font-size: 2rem;
    line-height: 1.3125;
  }
}

.business-technology__text {
  margin-top: 1.25rem;
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 0;
  font-weight: 700;
  color: #333333;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .business-technology__text {
    margin-top: 1.875rem;
  }
}

.business-work01 {
  background-color: #1A61AE;
  position: relative;
  overflow: visible;
  z-index: 0;
}
.business-work01::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 13rem;
  background: url(../images/common/bg-daen.png) no-repeat center center/100% 100%;
  left: 0;
  top: -13rem;
  top: calc(-13rem + 1px);
}
@media screen and (max-width: 767px) {
  .business-work01::before {
    top: -3.21875rem;
    height: 3.21875rem;
    top: calc(-3.21875rem + 1px);
    background-image: url(../images/common/bg-sp-daen.png);
  }
}
.business-work01::after {
  content: "";
  position: absolute;
  width: 92.5rem;
  height: 112.5rem;
  background: url(../images/common/business-work01-bubble.png) no-repeat center center/contain;
  left: 52.5%;
  top: -15.9375rem;
  z-index: 0;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .business-work01::after {
    background: url(../images/common/business-work01-bubble-sp.png) no-repeat center center/contain;
    width: 26.46875rem;
    height: 71.3125rem;
    top: 28.125rem;
    left: 50%;
    transform: translateX(-50%);
  }
}

.business-work01--layout {
  margin-top: 18.25rem;
  padding-bottom: 11.8125rem;
}
@media screen and (max-width: 767px) {
  .business-work01--layout {
    margin-top: 6.5rem;
    padding-bottom: 0;
  }
}

.business-work01__inner {
  position: relative;
  z-index: 1;
  max-width: 84.375rem;
  padding-inline: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .business-work01__inner {
    max-width: 37.5rem;
    padding-inline: 0.625rem;
  }
}

.business-work01__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.business-work01__items + .business-work01__items {
  margin-top: 6.25rem;
}

.business-work01__item-wrap {
  display: flex;
  align-items: center;
  gap: 9.375rem;
  margin-inline: auto;
  width: 100%;
  max-width: 74.5625rem;
  padding-inline: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .business-work01__item-wrap {
    flex-direction: column;
    gap: 0.625rem;
    padding-inline: 0;
  }
}

.business-work01__items--dark {
  background-color: #105096;
  border-radius: 3.75rem;
  padding-block: 3.1875rem;
}
@media screen and (max-width: 767px) {
  .business-work01__items--dark {
    background-color: transparent;
    border: radius 0;
    padding-block: 0;
  }
}

.business-work01__items--reverse .business-work01__item-wrap {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .business-work01__items--reverse .business-work01__item-wrap {
    flex-direction: column;
  }
}

.business-work01__img {
  width: 25rem;
  max-width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .business-work01__img {
    margin-top: 0.625rem;
    order: 2;
  }
}

.business-work01__img img {
  width: 100%;
  height: 100%;
  aspect-ratio: 400/400;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
@media screen and (max-width: 767px) {
  .business-work01__img img {
    aspect-ratio: 280/280;
  }
}

.business-work01__text-wrap {
  width: 100%;
  max-width: 37.0625rem;
}
@media screen and (max-width: 767px) {
  .business-work01__text-wrap {
    order: 3;
    display: flex;
    flex-direction: column;
    display: contents;
  }
}

.text-wrap__large {
  display: flex;
  align-items: center;
  gap: 1.375rem;
}
@media screen and (max-width: 767px) {
  .text-wrap__large {
    margin-top: 2rem;
    order: 1;
  }
}

.text-wrap__number {
  font-size: 3.125rem;
  font-weight: 700;
  line-height: 1.26;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .text-wrap__number {
    font-size: 1.875rem;
  }
}

.text-wrap__title {
  margin: 0;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.5;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .text-wrap__title {
    font-size: 1.875rem;
  }
}

@media screen and (max-width: 767px) {
  .text__wrapper {
    order: 3;
  }
}

.text-wrap__regular {
  margin-top: 1.5rem;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.5;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .text-wrap__regular {
    font-size: 1.25rem;
    margin-top: 2rem;
  }
}

.text-wrap__small {
  margin-top: 1.5rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.6;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .text-wrap__small {
    margin-top: 1.125rem;
    font-size: 1rem;
    font-weight: 500;
  }
}

@media screen and (max-width: 767px) {
  .business-work01__items + .business-work01__items {
    margin-top: 2.5rem;
  }
  .business-work01__items--dark {
    padding-block: 2rem;
    padding-inline: 1.25rem;
    margin-inline: 0;
    width: 100%;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .business-work01__items--dark {
    margin: 0;
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .business-work01__img {
    max-width: 21.875rem;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .business-work01__img {
    order: 2;
  }
}
@media screen and (max-width: 767px) {
  .business-work01__item-title {
    font-size: 1.75rem;
  }
  .business-work01__itemLead {
    font-size: 1.5rem;
  }
}
.work__service-area {
  position: relative;
}
.work__service-area::before {
  content: "";
  position: absolute;
  width: 87.5rem;
  height: 31.0625rem;
  background: url(../images/common/service-bg-pc.png) no-repeat center center/contain;
  left: 50%;
  top: 10.625rem;
  z-index: -1;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .work__service-area::before {
    background: url(../images/common/service-bg-sp.png) no-repeat center center/contain;
    width: 34.0625rem;
    height: 46.6875rem;
    top: 6.25rem;
    left: 50%;
    transform: translateX(-50%);
  }
}

.work__service-area--layout {
  margin-bottom: 1.25rem;
}
@media screen and (max-width: 767px) {
  .work__service-area--layout {
    margin-bottom: 0;
  }
}

.work__service-area__content {
  margin-top: 3.125rem;
  max-width: 75.1875rem;
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 4.8125rem;
}
@media screen and (max-width: 767px) {
  .work__service-area__content {
    margin-top: 1.8125rem;
    flex-direction: column;
    gap: 1.5rem;
  }
}

.service-area__img01 {
  margin-top: 4.5rem;
}
@media screen and (max-width: 767px) {
  .service-area__img01 {
    width: 13.75rem;
    height: 13.75rem;
    margin-right: auto;
  }
}

.service-area__img02 {
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .service-area__img02 {
    width: 13.75rem;
    height: 13.75rem;
    margin-left: auto;
  }
}

.service-area__img03 {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767px) {
  .service-area__img03 {
    width: 13.75rem;
    height: 13.75rem;
    margin-right: auto;
  }
}

.business {
  margin-top: 10.4375rem;
}

/* prettier-ignore */
.cta {
  position: relative;
  padding-bottom: 6.25rem;
  background-color: #1A61AE;
  overflow: hidden;
  overflow-x: clip;
}
@media screen and (max-width: 767px) {
  .cta {
    padding-top: 3.1875rem;
    padding-bottom: 5rem;
  }
}
.cta::before {
  content: "";
  position: absolute;
  top: 1rem;
  left: calc(50% - 45rem);
  width: 91.75rem;
  height: 54.82625rem;
  background: url(../images/common/top-backview-pc.png) no-repeat center top/cover;
  z-index: 0;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .cta::before {
    background: url(../images/common/top-backview.png) no-repeat center top/cover;
    width: 100%;
    height: auto;
    aspect-ratio: 390/260;
    top: 0.83125rem;
    left: 0.25rem;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
  }
}

.cta--layout {
  padding-top: 4.5625rem;
}

.cta__inner {
  position: relative;
  z-index: 1;
}

.cta__marquee-track {
  overflow: hidden;
  display: flex;
}
@media screen and (max-width: 767px) {
  .cta__marquee-track {
    margin-top: -3.125rem;
  }
}

.cta__marquee {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 8.75rem;
  line-height: 1.2571428571;
  letter-spacing: -2%;
  font-weight: 800;
  color: #0B75BA;
  flex-shrink: 0;
  white-space: nowrap;
  animation: marquee-scroll 20s linear infinite;
  mix-blend-mode: multiply;
}
@media screen and (max-width: 767px) {
  .cta__marquee {
    font-size: 2.9375rem;
    line-height: 1.4468085106;
    letter-spacing: -0.02em;
  }
}

@keyframes marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.cta__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5.8125rem;
  margin-top: 13.6875rem;
}
@media screen and (max-width: 767px) {
  .cta__cards {
    grid-template-columns: 1fr;
    margin-inline: auto;
    gap: 3.3125rem;
    max-width: 25rem;
    margin-inline: auto;
    margin-top: 12.1875rem;
  }
}

.cta__card:last-child .cta__card-wrap {
  margin-top: 0.625rem;
}

.cta__card-link {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 2.90625rem 1.306875rem 3.32625rem 2.59375rem;
  background: #fff;
  border-radius: 1.8815rem;
  transition: 0.5s;
}
.cta__card-link:hover {
  transform: translateY(-15px);
}
@media screen and (max-width: 767px) {
  .cta__card-link {
    padding: 1.8125rem 0.875rem 1.625rem 1.625rem;
  }
}
.cta__card-link::before {
  position: absolute;
  content: "";
  width: 5.16875rem;
  height: 5.844375rem;
  top: 2.5rem;
  right: 3.125rem;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .cta__card-link::before {
    width: min(100%, 3.125rem);
    height: 4.1875rem;
    aspect-ratio: 50/60;
    top: 0.83125rem;
    right: 1.125rem;
  }
}

.cta__card01-link::before {
  background-image: url(../images/common/contact-card-bubble.png);
  transform: scaleY(-1) rotate(-90deg);
}

.cta__card02-link::before {
  background-image: url(../images/common/contact-card-bubble.png);
}

.cta__img01 {
  position: absolute;
  left: 1.844375rem;
  bottom: 2.5rem;
  width: 19.0625rem;
}
@media screen and (max-width: 767px) {
  .cta__img01 {
    left: 0.75rem;
    bottom: 0.875rem;
    width: 12.0625rem;
  }
}

.cta__img02 {
  position: absolute;
  left: 1.844375rem;
  bottom: 5.625rem;
  width: 19.0625rem;
}
@media screen and (max-width: 767px) {
  .cta__img02 {
    left: 2rem;
    bottom: 4.375rem;
    width: 12.0625rem;
  }
}

.cta__img01 img {
  aspect-ratio: 305/298;
  -o-object-fit: contain;
     object-fit: contain;
  height: auto;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .cta__img01 img {
    aspect-ratio: 193/189;
  }
}

.cta__text {
  margin-top: 16.375rem;
  max-width: 13.75rem;
  margin-left: auto;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #1246C3;
}
@media screen and (max-width: 767px) {
  .cta__text {
    margin-top: 10.36375rem;
    font-size: 0.7775rem;
    line-height: 1.4469453376;
    letter-spacing: 0.04em;
    max-width: 9.375rem;
  }
}

.cta__text--01 {
  max-width: 14.8125rem;
}
@media screen and (max-width: 767px) {
  .cta__text--01 {
    max-width: 9.0625rem;
  }
}

body.is-drawer-open {
  overflow: hidden;
}

.header__drawer {
  position: fixed;
  z-index: 1000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  padding: 6.25rem 2rem 2.5rem;
  background: url(../images/common/drawer_bg.png) no-repeat center center/100% 100%;
  overflow-y: auto;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.header__drawer.is-active {
  opacity: 1;
  visibility: visible;
}

.drawer__btn-wrap {
  margin-top: 3.1875rem;
  display: flex;
  gap: 0.75rem;
}

.drawer__wrap {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-top: 2.6875rem;
}

.drawer-menu__items {
  margin-top: 2.6875rem;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.drawer-menu__link a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 2.1875rem;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #333333;
  line-height: 1.4666666667;
  text-transform: uppercase;
  padding: 0.96875rem 0;
  width: 100%;
  gap: 0.9375rem;
}
.drawer-menu__link a::before {
  content: "";
  display: inline-block;
  flex: 0 0 2.1875rem;
  width: 2.1875rem;
  height: 2.1875rem;
  background-color: #1B386C;
  border-radius: 50%;
}
.drawer-menu__link a::after {
  content: "";
  position: absolute;
  left: 1.09375rem;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 0.464375rem;
  height: 0.418125rem;
  background-color: #fff;
  mask-image: url("../images/common/btn-gray.png");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  -webkit-mask-image: url("../images/common/btn-gray.png");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
}

.drawer-menu__link a:focus-visible,
.drawer-menu__link a:hover {
  opacity: 0.8;
}

.form {
  background-color: #1A61AE;
  position: relative;
  overflow: visible;
  z-index: 0;
}
.form::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 13rem;
  background: url(../images/common/bg-daen.png) no-repeat center center/100% 100%;
  left: 0;
  top: -12.875rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .form::before {
    height: 3.21875rem;
    background-image: url(../images/common/bg-sp-daen.png);
    top: -3.1875rem;
  }
}

.form--layout {
  padding-top: 2.5rem;
  padding-bottom: 5rem;
  margin-top: 17.5rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .form--layout {
    margin-top: 9.375rem;
    padding-top: 1.875rem;
  }
}

.form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap),
.form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 0.9375rem;
}
.form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap) .form__label,
.form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) .form__label {
  flex-shrink: 0;
  margin-bottom: 0;
  margin-right: 1.25rem;
}
.form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap) .wpcf7-form-control-wrap,
.form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap) .contact-home-form__field,
.form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) .wpcf7-form-control-wrap,
.form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) .contact-home-form__field {
  flex: 1;
  min-width: 0;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap),
  .form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) {
    flex-direction: column;
  }
  .form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap) .form__label,
  .form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) .form__label {
    margin-right: 0;
  }
  .form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap) .wpcf7-form-control-wrap,
  .form .wpcf7-form > p:has(.form__label):has(.wpcf7-form-control-wrap) .contact-home-form__field,
  .form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) .wpcf7-form-control-wrap,
  .form .wpcf7-form > p:has(.form__label):has(.contact-home-form__field) .contact-home-form__field {
    margin-left: 0;
  }
}

.contact-home--layout {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .contact-home--layout {
    margin-top: 30px;
  }
}

.contact-home__content {
  max-width: 640px;
  width: 100%;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .contact-home__content {
    max-width: none;
  }
}

.form__data-select {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 24px;
  align-items: center;
}
.form__data-select label {
  position: relative;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
}
.form__data-select input[type=checkbox] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.form__data-select .form__select {
  position: relative;
  padding-left: 1.8em;
  line-height: 1.2;
}
.form__data-select input[type=checkbox] + .form__select::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1.1em;
  height: 1.1em;
  transform: translateY(-50%);
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 2px;
}
.form__data-select input[type=checkbox] + .form__select::after {
  content: "";
  position: absolute;
  left: 0.2em;
  top: 50%;
  width: 0.7em;
  height: 0.4em;
  transform: translateY(-50%) rotate(-45deg);
  border-left: 3px solid #333;
  border-bottom: 3px solid #333;
  opacity: 0;
  transition: 0.2s ease;
}
.form__data-select input[type=checkbox]:checked + .form__select::after {
  opacity: 1;
}
.form__data-select input[type=checkbox]:focus-visible + .form__select::before {
  outline: 3px solid rgba(0, 120, 255, 0.4);
  outline-offset: 2px;
}

.contact-home-form__text {
  font-family: "Noto Sans JP";
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #A9A9A9;
  background-color: #fff;
  border: 1px solid #D6D6D6;
  padding: 0.9375rem;
  border-radius: 0.375rem;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .contact-home-form__text {
    font-size: 0.875rem;
    line-height: 1.5;
    font-weight: 700;
    color: #A9A9A9;
    border-color: #D6D6D6;
    padding: 1rem;
    border-radius: 0.25rem;
    overflow-y: auto;
    max-height: 22.1875rem;
  }
}
.contact-home-form__text p + p {
  margin-top: 0.75rem;
}

.contact-home-form__body {
  position: relative;
  max-width: 75rem;
  margin-inline: auto;
}
.contact-home-form__body::before {
  content: "";
  position: absolute;
  width: 8.25rem;
  height: 9.4375rem;
  background: url(../images/common/ently-bg-bubble02.png) no-repeat center center/contain;
  left: 99%;
  top: 42.125rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .contact-home-form__body::before {
    background: url(../images/common/ently-bg-bubble02-sp.png) no-repeat center center/contain;
    top: 22.1875rem;
    left: 96%;
    width: 2rem;
    height: 2rem;
  }
}
.contact-home-form__body::after {
  content: "";
  position: absolute;
  width: 6.625rem;
  height: 8.5625rem;
  bottom: -10.625rem;
  left: -7.625rem;
  z-index: -1;
  background: url(../images/common/ently-bg-bubble03.png) no-repeat center center/contain;
}
@media screen and (max-width: 767px) {
  .contact-home-form__body::after {
    background: url(../images/common/ently-bg-bubble03-sp.png) no-repeat center center/contain;
    top: -0.625rem;
    right: -0.625rem;
    width: 3.03125rem;
    height: 3.90625rem;
  }
}
@media screen and (max-width: 767px) {
  .contact-home-form__body {
    margin-top: 0;
  }
}

.form__label {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.9375rem;
  flex-wrap: nowrap;
}
@media screen and (max-width: 767px) {
  .form__label {
    flex-wrap: wrap;
  }
}
.form__label label,
.form__label .form__label-text {
  font-size: 1.125rem;
  font-weight: 700;
  color: #000;
  line-height: 1;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .form__label label,
  .form__label .form__label-text {
    font-size: 0.875rem;
  }
}

.form__required {
  flex-shrink: 0;
  display: inline-block;
  padding: 0.3125rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
  background-color: #1A61AE;
  border-radius: 0.3125rem;
}

.form__note {
  display: block;
  width: 100%;
  font-size: 1.125rem;
  line-height: 1.4;
  color: #000;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .form__note {
    font-size: 0.75rem;
  }
}

.contact-home-form__list01 {
  padding: 5rem 3.875rem 2.8125rem 4.0625rem;
  background-color: #FAFAFA;
  border-radius: 0.625rem;
}
@media screen and (max-width: 767px) {
  .contact-home-form__list01 {
    padding: 4.0625rem 0.8125rem 5.5rem;
  }
}
.contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) {
  display: grid;
  grid-template-columns: minmax(240px, auto) 1fr;
  grid-template-rows: auto auto;
  gap: 0.25rem 1.5rem;
  align-items: flex-start;
}
.contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) .form__label {
  grid-column: 1;
  grid-row: 1;
  flex-shrink: 0;
}
.contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) .form__note {
  grid-column: 1;
  grid-row: 2;
  width: auto;
  margin-top: 0.25rem;
}
.contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) .wpcf7-form-control-wrap {
  grid-column: 2;
  grid-row: 1/-1;
  align-self: start;
  min-width: 0;
}
@media screen and (max-width: 767px) {
  .contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) .form__label {
    margin-bottom: 0.625rem;
  }
  .contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) .form__note {
    margin-top: 0.25rem;
  }
  .contact-home-form__list01 .wpcf7-form > p:has(.form__label):has(.form__note):has(.wpcf7-form-control-wrap) .wpcf7-form-control-wrap {
    width: 100%;
  }
}

.wpcf7-form-control-wrap:has(.wpcf7-list-item) {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
  justify-content: space-between;
  align-self: start;
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap:has(.wpcf7-list-item) {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.9375rem;
  }
}

.wpcf7-form-control-wrap .wpcf7-list-item {
  display: inline-flex;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap .wpcf7-list-item:first-child {
    margin-left: 0;
  }
}
.wpcf7-form-control-wrap .wpcf7-list-item label {
  position: relative;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
}
.wpcf7-form-control-wrap .wpcf7-list-item input[type=checkbox] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.wpcf7-form-control-wrap .wpcf7-list-item .wpcf7-list-item-label {
  position: relative;
  padding-left: 1.8em;
  line-height: 1.2;
}
.wpcf7-form-control-wrap .wpcf7-list-item .form__label {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.9375rem;
}
.wpcf7-form-control-wrap .wpcf7-list-item .form__label label,
.wpcf7-form-control-wrap .wpcf7-list-item .form__label .form__label-text {
  font-size: 1.125rem;
  font-weight: 700;
  color: #000;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap .wpcf7-list-item .form__label label,
  .wpcf7-form-control-wrap .wpcf7-list-item .form__label .form__label-text {
    font-size: 0.875rem;
  }
}
.wpcf7-form-control-wrap .wpcf7-list-item input[type=checkbox] + .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1.1em;
  height: 1.1em;
  transform: translateY(-50%);
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 2px;
}
.wpcf7-form-control-wrap .wpcf7-list-item input[type=checkbox] + .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  left: 0.2em;
  top: 50%;
  width: 0.7em;
  height: 0.4em;
  transform: translateY(-50%) rotate(-45deg);
  border-left: 3px solid #000;
  border-bottom: 3px solid #000;
  opacity: 0;
  transition: 0.2s ease;
}
.wpcf7-form-control-wrap .wpcf7-list-item input[type=checkbox]:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}
.wpcf7-form-control-wrap .wpcf7-list-item input[type=checkbox]:focus-visible + .wpcf7-list-item-label::before {
  outline: 3px solid rgba(0, 120, 255, 0.4);
  outline-offset: 2px;
}

.wpcf7-form-control-wrap[data-name=job-category] .wpcf7-list-item input[type=checkbox] + .wpcf7-list-item-label::before {
  border-color: #000;
}

.wpcf7-form-control-wrap[data-name=job-category] {
  flex-wrap: nowrap;
}
@media screen and (max-width: 767px) {
  .wpcf7-form-control-wrap[data-name=job-category] {
    flex-wrap: wrap;
  }
}

.contact-home-form__checkbox-group {
  margin-top: 2.5rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
}

.contact-home-form__checkbox-group .contact-home-form__field {
  display: flex;
  width: 100%;
}

.contact-home-form__checkbox-group .contact-home-form__checkbox-label {
  justify-content: flex-start;
  width: 100%;
}

.contact-home-form__group {
  margin-top: 2.5rem;
  display: flex;
  gap: 0.9375rem;
  align-items: flex-start;
}
.contact-home-form__group .contact-home-form__label {
  margin-right: 1.25rem;
}
.contact-home-form__group .contact-home-form__field {
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .contact-home-form__group {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.9375rem;
    margin-top: 2.5rem;
  }
  .contact-home-form__group .contact-home-form__label {
    margin-right: 0;
  }
  .contact-home-form__group .contact-home-form__field {
    margin-left: 0;
  }
}

.contact-home-form__group:first-child {
  margin-top: 0;
}

.contact-home-form__label {
  width: -moz-fit-content;
  width: fit-content;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 0.9375rem;
}
@media screen and (max-width: 767px) {
  .contact-home-form__label {
    gap: 0.625rem;
  }
}

.contact-home-form__01 {
  display: flex;
  align-items: center;
  gap: 0.9375rem;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #444;
}
@media screen and (max-width: 767px) {
  .contact-home-form__01 {
    font-size: 0.875rem;
    gap: 0.625rem;
  }
}

.contact-home-form__required {
  font-size: 0.75rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #fff;
  background-color: #1A61AE;
  border-radius: 0.3125rem;
  padding: 0.3125rem 0.5rem;
}
@media screen and (max-width: 767px) {
  .contact-home-form__required {
    padding: 0.375rem 0.8125rem;
  }
}

.contact-home-form__field {
  max-width: 46.25rem;
  width: 100%;
  flex: 1;
  margin-left: auto;
  font-weight: 700;
  color: #000;
  font-size: 1.125rem;
}
@media screen and (max-width: 767px) {
  .contact-home-form__field {
    max-width: initial;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    font-size: 0.875rem;
  }
}

.contact-home-form__input {
  font-family: "Noto Sans JP";
  font-size: 14px;
  line-height: 1.2142857143;
  letter-spacing: 0;
  font-weight: 400;
  color: #444;
  border: 1px solid #D6D6D6;
  padding: 15px;
  border-radius: 8px;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
}
.contact-home-form__input::-moz-placeholder {
  color: #9F9F9F;
}
.contact-home-form__input::placeholder {
  color: #9F9F9F;
}
.contact-home-form__input:focus {
  outline: none;
  border-color: #1C387B;
}
@media screen and (max-width: 767px) {
  .contact-home-form__input {
    border-color: #DCDCDC;
    padding: 0.9375rem;
    border-radius: 0.25rem;
  }
}

.contact-home-form__select-wrap select {
  font-family: "Noto Sans JP";
  font-size: 14px;
  line-height: 1.2142857143;
  letter-spacing: 0;
  font-weight: 400;
  color: #444;
  border: 1px solid #D6D6D6;
  padding: 15px;
  border-radius: 8px;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
}
.contact-home-form__select-wrap select:focus {
  outline: none;
  border-color: #1C387B;
}
@media screen and (max-width: 767px) {
  .contact-home-form__select-wrap select {
    border-color: #DCDCDC;
    padding: 0.9375rem;
    border-radius: 0.25rem;
  }
}

.contact-home-form__select-wrap {
  position: relative;
}
.contact-home-form__select-wrap::after {
  content: "";
  position: absolute;
  background-image: url(../images/common/icon-01.svg);
  background-repeat: no-repeat;
  width: 12px;
  height: 6px;
  display: inline-block;
  top: 50%;
  transform: translateY(-50%);
  right: 14px;
  pointer-events: none;
}

.contact-home-form__textarea {
  font-size: 0.875rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #000;
  border: 1px solid #D6D6D6;
  padding: 0.9375rem;
  border-radius: 0.5rem;
  display: inline-block;
  width: 100%;
  min-height: 10rem;
  height: 10rem;
  resize: vertical;
  box-sizing: border-box;
}
.contact-home-form__textarea::-moz-placeholder {
  color: #A9A9A9;
}
.contact-home-form__textarea::placeholder {
  color: #A9A9A9;
}

.contact-home-form__checkbox-label {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-family: "Noto Sans JP";
  color: #333333;
}

.contact-home-form__checkbox-text {
  flex: 1;
  display: flex;
}

.contact-home-form__required {
  font-size: 0.875rem;
}

.contact-home-form__required-mark {
  font-weight: bold;
}

.contact-home-form__checkbox {
  display: none;
}

.contact-home-form__custom-checkbox {
  width: 16px;
  height: 16px;
  border: 1px solid #fff;
  border-radius: 1px;
  background-color: #fff;
  position: relative;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .contact-home-form__custom-checkbox {
    width: 1.25rem;
    height: 1.25rem;
    border-color: #DCDCDC;
    border-radius: 0.125rem;
  }
}

.contact-home-form__checkbox:checked + .contact-home-form__custom-checkbox::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 0px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .contact-home-form__checkbox:checked + .contact-home-form__custom-checkbox::after {
    left: 0.375rem;
    top: 0.125rem;
    border-color: #333333;
  }
}

.wpcf7-form-control-wrap[data-name=privacy] {
  width: 100%;
  display: flex;
}

.wpcf7-form-control-wrap[data-name=privacy] .wpcf7-list-item-label {
  position: relative;
  display: inline-block;
  padding-left: 1.75rem;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.4;
  font-family: "Noto Sans JP", sans-serif;
  color: #333333;
  cursor: pointer;
}

.wpcf7-form-control-wrap[data-name=privacy] .wpcf7-list-item-label::before {
  position: absolute;
  top: 0.125rem;
  left: 0;
  width: 1.25rem;
  height: 1.25rem;
  content: "";
  border: 1px solid #000;
  border-radius: 0.125rem;
  background-color: #fff;
}

.contact-home-form__checkbox-group .wpcf7-form-control-wrap[data-name=privacy] .wpcf7-list-item-label::before {
  border-color: #ddd;
}

.wpcf7-form-control-wrap[data-name=privacy] .wpcf7-list-item-label::after {
  position: absolute;
  top: 0.4375rem;
  left: 0.375rem;
  width: 0.625rem;
  height: 0.3125rem;
  content: "";
  transform: rotate(-45deg);
  opacity: 0;
  border-bottom: 2px solid #333333;
  border-left: 2px solid #333333;
}

.wpcf7-form-control-wrap[data-name=privacy] input:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}

.form__submit-button {
  margin-top: 2.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.form__submit-input {
  display: inline-block;
  width: 14.25rem;
  padding: 1rem 2rem;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.4;
  color: #fff;
  text-align: center;
  background-color: #002A59;
  border: none;
  border-radius: 2.25rem;
  cursor: pointer;
  transition: opacity 0.3s;
}
@media screen and (max-width: 767px) {
  .form__submit-input {
    width: 19.375rem;
  }
}
.form__submit-input:hover {
  opacity: 0.85;
}

.contact-home-form__button-wrap {
  margin-top: 2.5625rem;
  text-align: center;
  margin-bottom: 7.5rem;
}

.contact-home-form__button {
  display: inline-block;
  width: min(100%, 446px);
  text-align: center;
  background: #1C387B;
  position: relative;
  border-radius: 4px;
  padding: 20px;
  transition: 0.5s;
  font-family: "Noto Sans JP";
  font-size: 18px;
  line-height: 1.4444444444;
  letter-spacing: 0;
  font-weight: 500;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .contact-home-form__button {
    width: min(100%, 260px);
    font-size: 14px;
    line-height: 1.4285714286;
    padding: 12px;
  }
}
.contact-home-form__button::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  top: 5px;
  background: #1C387B;
  border-radius: 4px;
  transition: 0.5s;
  z-index: -1;
}

.contact-confirm--layout {
  margin-top: 60px;
}

.contact-confirm__content {
  max-width: 680px;
  width: 100%;
  margin: 0 auto;
}

.contact-confirm__intro {
  text-align: left;
}

.contact-confirm__text {
  font-family: "Noto Sans JP";
  font-size: 16px;
  line-height: 1.1875;
  letter-spacing: 0;
  font-weight: 400;
  color: #444;
}

.contact-confirm__body {
  margin-top: 120px;
}

.confirm-list__item {
  display: flex;
  gap: 46px;
  width: 100%;
  padding-top: 21px;
  padding-bottom: 21px;
}
@media screen and (max-width: 767px) {
  .confirm-list__item {
    flex-direction: column;
    align-items: flex-start;
    padding: 15px 0;
    gap: 10px;
  }
}

.confirm-list__item:first-child {
  padding-top: 0;
}

.confirm-list__item:last-child {
  padding-bottom: 0;
}

.confirm-list__label {
  width: 146px;
  font-family: "Noto Sans JP";
  font-size: 15px;
  line-height: 1.4666666667;
  letter-spacing: 0;
  font-weight: 500;
  color: #444;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .confirm-list__label {
    width: 100%;
  }
}

.confirm-list__value {
  font-family: "Noto Sans JP";
  font-size: 14px;
  line-height: 2.2857142857;
  letter-spacing: 0;
  font-weight: 400;
  color: #444;
}

.contact-home-form__footer {
  margin-top: 2.5rem;
  text-align: center;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .contact-home-form__footer {
    margin-top: 2rem;
  }
}
.contact-home-form__footer .contact-home-form__checkbox-group {
  width: auto;
  align-items: center;
}
.contact-home-form__footer .contact-home-form__checkbox-group .contact-home-form__field {
  justify-content: center;
}
.contact-home-form__footer .contact-home-form__checkbox-group .contact-home-form__checkbox-label {
  justify-content: center;
}
.contact-home-form__footer .form__submit-button {
  width: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.form__submit-button .wpcf7-spinner {
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
}

.contact__button--submit {
  background: #002A59;
  color: #fff;
  border-radius: 2.25rem;
  padding: 1rem 2rem;
  font-size: 1.25rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 600;
  width: 14.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .contact__button--submit {
    width: 19.375rem;
  }
}
.contact__button--submit:hover {
  opacity: 0.85;
}

.wpcf7-form-control.wpcf7-checkbox {
  display: flex;
  gap: 1.25rem;
}

.footer {
  position: relative;
  background: url(../images/common/footer_mask.png) no-repeat center center/100% 100%;
  padding: 12.9375rem 0 4.875rem;
  background-color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .footer {
    padding: 4.125rem 0 4rem;
    background-image: url(../images/common/footer-bg.png);
  }
}

.footer::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 4.375rem;
  background: #002A59;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .footer--layout {
    margin-bottom: 4.0625rem;
  }
}

.footer__inner {
  width: 100%;
  max-width: 77.9375rem;
  margin-right: auto;
  margin-left: auto;
  padding-inline: 1.5625rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .footer__inner {
    padding-inline: 1.25rem;
    max-width: 37.5rem;
  }
}

.footer__main {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .footer__main {
    flex-direction: column;
    gap: 1.5rem;
  }
}

.footer__left {
  max-width: 19.8125rem;
  width: 100%;
}

.footer__logo {
  display: block;
  max-width: 11.34375rem;
  width: 100%;
  margin-bottom: 1rem;
}

.footer__logo img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer__name {
  font-family: "IBM Plex Sans", sans-serif;
  line-height: 1.2857142857;
  letter-spacing: 0.56px;
  font-weight: 500;
  color: #333333;
  font-size: 0.875rem;
  margin-top: 0.625rem;
}

.footer__address {
  font-family: "IBM Plex Sans", sans-serif;
  line-height: normal;
  letter-spacing: 0.56px;
  font-weight: 500;
  color: #333333;
  font-size: 0.875rem;
  line-height: 1.6;
  margin-top: 1.25rem;
  font-style: normal;
}

.footer__tel a {
  display: block;
  font-family: "IBM Plex Sans", sans-serif;
  line-height: normal;
  letter-spacing: 0.56px;
  font-weight: 500;
  color: #333333;
  font-size: 1.5rem;
  line-height: normal;
  margin-top: 1.5625rem;
}

.footer__right {
  width: -moz-fit-content;
  width: fit-content;
}

.footer__nav-columns {
  display: flex;
  gap: 2.5rem;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .footer__nav-columns {
    flex-direction: column;
    gap: 1.5rem;
  }
}

.footer__nav-col {
  min-width: 7.5rem;
}

.footer__nav-title {
  color: #333333;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.125rem;
  line-height: normal;
  letter-spacing: 0.72px;
  font-weight: 700;
}
.footer__nav-title a {
  color: inherit;
  text-decoration: none;
}

.footer__nav-sublist {
  display: flex;
  flex-direction: column;
  row-gap: 1rem;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  .footer__nav-sublist {
    row-gap: 1.5rem;
  }
}

.footer__nav-subitem a {
  font-family: "IBM Plex Sans", sans-serif;
  line-height: normal;
  letter-spacing: 0.56px;
  font-weight: 500;
  font-size: 1.125rem;
  font-weight: 500;
  color: #333333;
}

.footer__nav-subitem--strong a {
  font-weight: 700;
}

.footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
  text-align: center;
  margin-top: 3.0625rem;
  padding-bottom: 4.875rem;
}
@media screen and (max-width: 767px) {
  .footer__links {
    margin-top: 1.875rem;
    flex-direction: column;
    gap: 0.9375rem;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    padding-bottom: 4rem;
  }
}

.footer__policy {
  color: #333333;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 0.75rem;
  line-height: normal;
  letter-spacing: 0.48px;
  font-weight: 400;
}

.footer--completion {
  background: #002A59;
  background-image: none;
  background: url(../images/common/footer-mask-blue.png) no-repeat center center/100% 100%;
}
.footer--completion .footer__name,
.footer--completion .footer__address,
.footer--completion .footer__tel a,
.footer--completion .footer__nav-title,
.footer--completion .footer__nav-subitem a,
.footer--completion .footer__policy {
  color: #fff;
}
@media screen and (max-width: 767px) {
  .footer--completion {
    padding: 4.125rem 0 4rem;
    background-image: url(../images/common/footer-mask-blue-sp.png);
  }
  .footer--completion::after {
    display: none;
  }
  .footer--completion .footer__nav-subitem a:hover,
  .footer--completion .footer__policy:hover {
    opacity: 0.8;
  }
}

.fv {
  position: relative;
  overflow-x: clip;
  height: 100dvh;
  max-height: 60.8125rem;
}
.fv::before {
  content: "";
  position: absolute;
  width: 119.324375rem;
  height: 71.485625rem;
  background: url(../images/common/fv-top.png) no-repeat center center/contain;
  left: calc(50% - 54.25rem);
  top: -11.875rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .fv::before {
    width: 37.5625rem;
    height: 50.005625rem;
    left: calc(50% - 17.625rem);
    top: -8.8125rem;
    background: url(../images/common/fv-sp_bg.png) no-repeat center center/contain;
  }
}

.fv__inner {
  position: relative;
  display: grid;
  width: 100%;
  max-width: 90rem;
  margin-inline: auto;
  place-items: center;
  height: inherit;
  max-height: inherit;
}
@media screen and (max-width: 767px) {
  .fv__inner {
    min-height: 44.6875rem;
    width: 100%;
  }
}

.fv__image {
  position: absolute;
  aspect-ratio: 1/1;
  border-radius: 50%;
  height: auto;
  opacity: 0;
  animation: fvImageIn 0.8s ease forwards;
}

.fv__image img {
  width: 100%;
  height: auto;
  display: block;
}

.fv__image-01 {
  position: absolute;
  top: 11.1875rem;
  left: 6.4583333333%;
  animation-delay: 0.2s;
  aspect-ratio: 1/1;
  max-width: 18.75rem;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .fv__image-01 {
    top: 6.5rem;
    left: 1.0625rem;
    max-width: 7.3125rem;
  }
}

.fv__image-02 {
  position: absolute;
  z-index: 1;
  top: 35rem;
  left: 25.9722222222%;
  animation-delay: 0.8s;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  max-width: 15.625rem;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .fv__image-02 {
    right: 0;
    left: unset;
    bottom: -6.25rem;
    max-width: 5.625rem;
  }
}

.fv__image-03 {
  position: absolute;
  z-index: 1;
  top: 21.9375rem;
  right: 0.5555555556%;
  animation-delay: 1.4s;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  max-width: 25rem;
  width: 100%;
  height: auto;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  .fv__image-03 {
    top: 10rem;
    right: -5.9375rem;
    max-width: 22.75rem;
  }
}

.fv__title {
  z-index: 3;
  text-align: center;
  display: inline-block;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .fv__title {
    position: absolute;
    left: 1.4375rem;
    bottom: 5.1875rem;
    max-width: 16.25rem;
    width: 100%;
  }
}

.fv__title_large {
  font-size: 4.255rem;
  line-height: normal;
  letter-spacing: 0.0567px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .fv__title_large {
    font-size: 2.25rem;
  }
}

.fv__title_large01 {
  margin-left: -1.875rem;
}
@media screen and (max-width: 767px) {
  .fv__title_large01 {
    margin-left: -1.25rem;
  }
}

.fv__title_small {
  font-size: 3.545625rem;
  line-height: normal;
  letter-spacing: 0.0567px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .fv__title_small {
    font-size: 1.875rem;
    letter-spacing: -0.05em;
    margin-left: -0.3125rem;
  }
}

.fv__scroll-down {
  position: absolute;
  left: 3.375rem;
  bottom: -0.4375rem;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .fv__scroll-down {
    left: 0.8125rem;
    bottom: -5rem;
  }
}

@keyframes fvImageIn {
  0% {
    opacity: 0;
    transform: scale(0.98);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.header {
  height: 3.38375rem;
  background-color: transparent;
}
@media screen and (max-width: 767px) {
  .header {
    height: 4.375rem;
  }
}

.header--layout {
  position: fixed;
  z-index: 1500;
  top: 1.175625rem;
  right: 0;
  left: 0;
}

.header__inner {
  padding-left: clamp(0.75rem, 2vw, 2rem);
  padding-right: clamp(0.75rem, 1.4vw, 1.25rem);
  height: inherit;
  display: flex;
  justify-content: space-between;
  max-width: 90rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .header__inner {
    padding: 0 1.25rem;
  }
}

.header__logo {
  width: min(18.75rem, 20.83vw);
  height: inherit;
  flex-shrink: 0;
  position: relative;
  z-index: 1500;
  background-color: rgb(255, 255, 255);
  border-radius: 2.1875rem;
  padding-inline: min(2.1875rem, 1.5vw);
}
@media screen and (max-width: 767px) {
  .header__logo {
    width: 13.875rem;
    padding-inline: 2vw;
  }
}

.header__logo a {
  height: inherit;
  display: flex;
  align-items: center;
}

.header__logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.header__nav-wrap {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  max-width: 69.5rem;
  justify-content: space-between;
}

.header__nav {
  display: flex;
  height: inherit;
  align-items: center;
  flex: 1;
  background-color: rgba(255, 255, 255, 0.8);
  border-radius: 2.1875rem;
  padding-inline: min(2.1875rem, 0.5vw);
}
@media screen and (max-width: 1240px) {
  .header__nav {
    padding-inline: 0.625rem;
  }
}
@media screen and (max-width: 767px) {
  .header__nav {
    display: none;
  }
}

.header__nav-list {
  display: flex;
  height: inherit;
}

.header__nav-item {
  height: inherit;
}

.header__nav-item--contact {
  margin-left: 0.9375rem;
  display: flex;
  align-items: center;
}

.header__nav-item a {
  padding: min(0.9375rem, 1.04vw);
  height: inherit;
  display: flex;
  align-items: center;
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.4666666667;
  letter-spacing: 0.03em;
  font-size: 0.9375rem;
  font-weight: 900;
  color: #444;
  white-space: nowrap;
}
@media screen and (max-width: 1240px) {
  .header__nav-item a {
    padding-inline: 0.625rem;
  }
}

.header__nav-item a::after {
  content: "";
  position: absolute;
  left: 0.9375rem;
  right: 0.9375rem;
  bottom: -0.125rem;
  height: 1px;
  background-color: #000;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease;
  display: block;
}

.header__nav-item a:hover::after,
.header__nav-item a:focus-visible::after {
  transform: scaleX(1);
}

.header__btn-wrap {
  display: flex;
  gap: 10px;
  height: inherit;
}

.header__btn {
  height: inherit;
  width: min(12.5rem, 13.89vw);
}
@media screen and (max-width: 1350px) {
  .header__btn {
    width: 10rem;
  }
}

.header__hamburger {
  display: none;
  margin: 0;
  padding: 0;
  outline: none;
  border: none;
  position: relative;
  z-index: 1001;
  width: 4.0625rem;
  height: 4.0625rem;
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .header__hamburger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
}

.header__hamburger::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background-color: #1A61AE;
}

.header__hamburger span {
  position: absolute;
  top: 50%;
  left: 1.4375rem;
  z-index: 1;
  display: block;
  height: 0.125rem;
  background-color: #fff;
  border-radius: 0.125rem;
  transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
}

.header__hamburger span:nth-child(1) {
  width: 1.25rem;
  transform: translate(0, -0.375rem);
}

.header__hamburger span:nth-child(2) {
  width: 0.9375rem;
  transform: translate(0, -0.0625rem);
}

.header__hamburger span:nth-child(3) {
  width: 0.4375rem;
  transform: translate(0, 0.25rem);
}

.header__hamburger.is-active span {
  width: 1.25rem;
}

.header__hamburger.is-active span:nth-child(1) {
  transform: translate(0, 0) rotate(25deg);
}

.header__hamburger.is-active span:nth-child(2) {
  opacity: 0;
}

.header__hamburger.is-active span:nth-child(3) {
  transform: translate(0, 0) rotate(-205deg);
}

.interview__fv--layout {
  margin-top: 3.6875rem;
  background-color: #F1FAFF;
}
@media screen and (max-width: 767px) {
  .interview__fv--layout {
    margin-top: 0;
  }
}

.interview__fv-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .interview__fv-content {
    flex-direction: column;
  }
}

.interview__fv-title-wrapper {
  max-width: 36rem;
  width: 100%;
}

.interview__fv-title {
  font-size: 4rem;
  line-height: 1.5;
  letter-spacing: 0.0567px;
  font-weight: 700;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .interview__fv-title {
    font-size: 2.25rem;
    line-height: 1.5;
  }
}

.interview__fv-title-sub {
  font-size: 1.875rem;
  line-height: 1.5;
  letter-spacing: 0.0567px;
  font-weight: 700;
  color: #000;
  color: #1A61AE;
  padding-bottom: 2.8125rem;
  border-bottom: 0.1125rem dotted #1A61AE;
  max-width: 20rem;
}
@media screen and (max-width: 767px) {
  .interview__fv-title-sub {
    font-size: 1.1875rem;
    line-height: 1.4736842105;
    padding-bottom: 1.8125rem;
    max-width: 12.5rem;
  }
}

.interview__name {
  margin-top: 2.8125rem;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0.0567px;
  font-weight: 700;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .interview__name {
    margin-top: 1.875rem;
    font-size: 1.0625rem;
    line-height: 1.4705882353;
  }
}

.interview__position {
  margin-top: 0.9375rem;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.0567px;
  font-weight: 700;
  color: #000;
}
@media screen and (max-width: 767px) {
  .interview__position {
    font-size: 0.8125rem;
    line-height: 1.5384615385;
    margin-top: 0.5625rem;
  }
}

.interview__fv-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .interview__fv-content {
    flex-direction: column;
  }
}

.interview {
  background-color: #F1FAFF;
  position: relative;
  width: 100%;
  overflow-x: clip;
  isolation: isolate;
}
.interview::before {
  content: "";
  position: absolute;
  top: -19.25rem;
  width: 88.1875rem;
  height: 72.5625rem;
  background: url(../images/common/interview-fv-bg.png) no-repeat center center/contain;
  left: 82%;
  transform: translateX(-50%);
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .interview::before {
    background: url(../images/common/interview-fv-bg-sp01.png) no-repeat center center/contain;
    top: -10rem;
    width: 17.625rem;
    height: 17.625rem;
    left: 95%;
    transform: translateX(-50%);
  }
}
@media screen and (max-width: 767px) {
  .interview::after {
    content: "";
    position: absolute;
    background: url(../images/common/interview-fv-bg-sp02.png) no-repeat center center/contain;
    top: -9.8125rem;
    width: 8.6875rem;
    height: 8.6875rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
  }
}

.interview__inner {
  position: relative;
  z-index: 2;
}

.interview--layout {
  position: relative;
  padding-bottom: 8.4375rem;
}
@media screen and (max-width: 767px) {
  .interview--layout {
    padding-bottom: 0;
    padding-top: 6.6875rem;
  }
}

.interview__content {
  padding-top: 10.125rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
}
@media screen and (max-width: 767px) {
  .interview__content {
    padding-top: 2.8125rem;
    flex-direction: column;
  }
}

.interview__title-wrapper {
  max-width: 36rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .interview__title-wrapper {
    display: contents;
  }
}

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

.interview__title {
  font-size: 4rem;
  line-height: 1.5;
  letter-spacing: 0.64px;
  font-weight: 700;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 767px) {
  .interview__title {
    font-size: 2.25rem;
    line-height: 1.5;
    letter-spacing: 0.36px;
    order: 1;
    align-self: flex-start;
  }
}

.interview__title-sub {
  position: relative;
  margin-top: 1.875rem;
  font-size: 1.875rem;
  line-height: 1.5;
  letter-spacing: 0.0567px;
  font-weight: 700;
  color: #000;
  padding-bottom: 2.8125rem;
}
.interview__title-sub::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 20rem;
  height: 1px;
  background-image: repeating-linear-gradient(90deg, #1a61ae, #1a61ae 1px, transparent 1px, transparent 2px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 2px;
}
@media screen and (max-width: 767px) {
  .interview__title-sub {
    margin-top: 2.5rem;
    font-size: 1.1875rem;
    line-height: 1.4736842105;
    letter-spacing: 0.28px;
    order: 3;
  }
}

@media screen and (max-width: 767px) {
  .interview__name-wrapper {
    order: 4;
    align-self: flex-start;
    width: 100%;
    text-align: left;
  }
}

.interview__name {
  margin-top: 2.8125rem;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0.0567px;
  font-weight: 700;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .interview__name {
    margin-top: 1.875rem;
    font-size: 1.0625rem;
    line-height: 1.4705882353;
    letter-spacing: 0.28px;
  }
}

.interview__position {
  margin-top: 0.9375rem;
  font-size: 1.125rem;
  line-height: 1.5;
  font-weight: 700;
  color: #000;
}
@media screen and (max-width: 767px) {
  .interview__position {
    margin-top: 0.5625rem;
    font-size: 0.8125rem;
    line-height: 1.5384615385;
  }
}

.interview__image {
  max-width: 28.625rem;
  width: 100%;
  border-radius: 0.625rem;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .interview__image {
    max-width: 20.625rem;
    display: none;
  }
}

.interview__image-item {
  width: 100%;
  height: 100%;
  aspect-ratio: 458/582;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
@media screen and (max-width: 767px) {
  .interview__image-item {
    aspect-ratio: 330/415;
  }
}

.interview__section-title {
  margin-top: 0.75rem;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0.02em;
  font-weight: 600;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .interview__section-title {
    margin-top: 0.5rem;
    font-size: 1.125rem;
  }
}

.interview__section-body {
  margin-top: 2rem;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .interview__section-body {
    margin-top: 1.5rem;
    display: block;
  }
}

.interview__section-body--single {
  display: block;
}

.interview__section-text {
  max-width: 41.25rem;
  width: 100%;
}

.interview__section-body-text {
  font-size: 1.125rem;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .interview__section-body-text {
    font-size: 0.875rem;
  }
}

.interview__section-body-text + .interview__section-body-text {
  margin-top: 0.75rem;
}

.interview__section-image {
  max-width: 22.5rem;
  width: 100%;
  margin-inline-start: 2.5rem;
}
@media screen and (max-width: 767px) {
  .interview__section-image {
    margin-inline-start: 0;
    margin-top: 1.5rem;
    max-width: 100%;
  }
}

.interview__section-image-item {
  width: 100%;
  border-radius: 0.625rem;
  -o-object-fit: cover;
     object-fit: cover;
}

.interview__schedule-list {
  margin-top: 1.5rem;
  border-top: 0.0625rem solid #D2E8F7;
}

.interview__schedule-item {
  display: flex;
  align-items: center;
  padding-block: 0.75rem;
  border-bottom: 0.0625rem solid #D2E8F7;
}

.interview__schedule-time {
  min-width: 5.625rem;
  font-size: 1.25rem;
  font-weight: 700;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .interview__schedule-time {
    font-size: 1rem;
  }
}

.interview__schedule-label {
  margin-inline-start: 1.5rem;
  font-size: 1.125rem;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .interview__schedule-label {
    margin-inline-start: 1rem;
    font-size: 0.875rem;
  }
}

.interview__career-list {
  margin-top: 1.5rem;
  padding-inline-start: 1.25rem;
  border-left: 0.0625rem solid #ddd;
}

.interview__career-item + .interview__career-item {
  margin-top: 1.25rem;
}

.interview__career-period {
  font-size: 1.125rem;
  font-weight: 700;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .interview__career-period {
    font-size: 0.875rem;
  }
}

.interview__career-description {
  margin-top: 0.5rem;
  font-size: 1.125rem;
  line-height: 1.6;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .interview__career-description {
    font-size: 0.875rem;
  }
}

.interview02--layout {
  margin-top: 5rem;
  overflow-x: clip;
}
@media screen and (max-width: 767px) {
  .interview02--layout {
    margin-top: 1.875rem;
  }
}

.interview02__title-wrap .title01_main {
  color: #3987FD;
}

.interview02__nav-wrap {
  justify-content: flex-end;
  align-items: center;
  display: flex;
  gap: 1.5rem;
  margin-left: auto;
  padding-right: 0rem;
}
@media screen and (max-width: 767px) {
  .interview02__nav-wrap {
    gap: 1.25rem;
    margin-top: 2.75rem;
  }
}

.interview02__nav {
  position: static;
  top: 0;
  right: 4.0625rem;
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  background-color: transparent;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.interview02__nav::before {
  position: absolute;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  /* ← ここはSVGサイズに合わせる */
  height: 20px;
  transform: translate(-50%, -50%);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.interview02__nav--prev {
  background-image: url("../images/common/interview02-iconL.svg");
  background-size: 2.5rem 2.5rem;
}

.interview02__nav--next {
  background-image: url("../images/common/interview02-iconR.svg");
  background-size: 2.5rem 2.5rem;
}

.interview02__list {
  overflow: hidden;
  margin-top: 2.5rem;
  /* 左端はインナー幅に揃え、右端は画面いっぱいにはみ出す */
  width: calc(50vw + 50%);
  margin-inline-start: 0;
  margin-inline-end: 0;
  max-width: 1280px;
}
@media screen and (max-width: 767px) {
  .interview02__list {
    margin-top: 1.5rem;
    width: 100%;
  }
}

.interview02__card {
  display: block;
  height: 100%;
  text-decoration: none;
  background-color: #fff;
  border-radius: 0.75rem;
  transition: background-color 0.5s ease;
  position: relative;
  z-index: 1;
}
.interview02__card::before {
  content: "";
  position: absolute;
  top: -0.625rem;
  left: -0.625rem;
  right: -0.625rem;
  bottom: -0.625rem;
  border-radius: 0.75rem;
  background-color: #E7F2FF;
  z-index: -1;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.interview02__card:hover::before {
  opacity: 1;
}
.interview02__card:hover .interview02__img {
  transform: scale(1.1);
}

.interview02__image {
  border-radius: 0.75rem;
  width: 100%;
  aspect-ratio: 320/406;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .interview02__image {
    aspect-ratio: 167/212;
  }
}

.interview02__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.interview02__body {
  padding: 1.5rem 1.25rem;
}
@media screen and (max-width: 767px) {
  .interview02__body {
    padding: 1rem;
  }
}

.interview02__card-title {
  font-size: 1.25rem;
  line-height: 1.5;
  font-weight: 500;
  color: #1A61AE;
  padding-bottom: 1.375rem;
  border-bottom: 0.1125rem dotted #1A61AE;
}
@media screen and (max-width: 767px) {
  .interview02__card-title {
    font-size: 1rem;
    line-height: 1.6875;
    padding-bottom: 1rem;
  }
}

.interview02__name {
  margin-top: 1.25rem;
  font-size: 1.25rem;
  font-weight: 600;
  color: #000;
}
@media screen and (max-width: 767px) {
  .interview02__name {
    font-size: 1rem;
    line-height: 1.5;
    margin-top: 0.75rem;
  }
}

.interview02__position {
  margin-top: 0.9375rem;
  font-size: 0.8125rem;
  line-height: 1.5384615385;
  color: #000;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .interview02__position {
    font-size: 0.875rem;
    line-height: 1.5;
    margin-top: 0.5rem;
  }
}

.interview02__btn-wrap {
  margin-top: 5.375rem;
  text-align: right;
  margin-bottom: 6.25rem;
}
@media screen and (max-width: 767px) {
  .interview02__btn-wrap {
    margin-top: 3.90625rem;
    text-align: none;
  }
}

.lower-fv {
  position: relative;
}
.lower-fv::before {
  content: "";
  position: absolute;
  width: 92.375rem;
  height: 65.625rem;
  background: url(../images/common/fv-bg02.png) no-repeat center center/contain;
  z-index: -1;
  top: -31.75rem;
  left: 65%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .lower-fv::before {
    background-image: url(../images/common/fv-sp-bg02.png);
    width: 35.75rem;
    height: 58.625rem;
    top: -15.4375rem;
    left: 58%;
    transform: translateX(-50%);
  }
}

.lower-fv--layout {
  margin-top: 6.75rem;
}
@media screen and (max-width: 767px) {
  .lower-fv--layout {
    margin-top: 2.25rem;
    margin-bottom: 5.9375rem;
  }
}

.lower-fv__content {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .lower-fv__content {
    flex-direction: column;
  }
}

.lower-fv__title {
  max-width: 36.875rem;
  width: 100%;
  margin-top: 11.565rem;
}
@media screen and (max-width: 767px) {
  .lower-fv__title {
    max-width: 100%;
    margin-top: 6.6875rem;
  }
}

@media screen and (max-width: 767px) {
  .lower-fv__title--about {
    margin-top: 9.375rem;
  }
}

@media screen and (max-width: 767px) {
  .lower-fv__img {
    margin-top: 2.125rem;
    width: 100%;
    display: flex;
    justify-content: center;
  }
}

@media screen and (max-width: 767px) {
  .lower-fv__img--about {
    margin-top: 2.25rem;
  }
}

.lower-fv__img img {
  max-width: 38.25rem;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 0 9.1px rgba(93, 93, 93, 0.4));
}
@media screen and (max-width: 767px) {
  .lower-fv__img img {
    width: clamp(21.875rem, 70vw, 32.5rem);
    max-width: none;
    height: auto;
  }
}

.memberCard-List {
  max-width: 1980px;
  width: 100%;
}

.memberCard-List .swiper-slide {
  width: 20rem;
}

.memberCard {
  position: relative;
  display: block;
  background-color: #fff;
  border-radius: 0.625rem;
  box-shadow: 0.125rem 0.125rem 0.25rem 0 rgb(191, 215, 255);
  overflow: hidden;
  transition: 0.5s ease;
  cursor: pointer;
  padding: 2.8125rem 2.1875rem;
}

.memberCard__name {
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.3;
  color: #3984FD;
  margin-top: 0rem;
  text-align: center;
  transition: color 0.5s ease;
}

.memberCard__imageWrap {
  max-width: 15.625rem;
  width: 100%;
  overflow: hidden;
  border-radius: 50%;
  box-shadow: 0.125rem 0.125rem 0.25rem 0 rgba(236, 243, 255, 0.25);
  margin-top: 2.1875rem;
  margin-inline: auto;
}

.memberCard__imageWrap img {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  height: auto;
  width: 100%;
  transition: 0.5s ease;
}

@media (any-hover: hover) {
  .memberCard:hover {
    background-color: #3984FD;
  }
  .memberCard:hover .memberCard__name {
    color: #fff;
  }
  .memberCard:hover .memberCard__imageWrap img {
    transform: scale(1.1);
  }
}
.number {
  background-color: #E6F0FF;
  position: relative;
  margin-top: 6.75rem;
}
@media screen and (max-width: 767px) {
  .number {
    margin-top: 3.125rem;
  }
}
.number::before {
  content: "";
  position: absolute;
  width: 90.875rem;
  height: 62.1875rem;
  background: url(../images/common/number-bubble.png) no-repeat center center/contain;
  z-index: 0;
  left: 50%;
  transform: translateX(-50%);
  top: -0.4375rem;
}
@media screen and (max-width: 767px) {
  .number::before {
    display: none;
  }
}

.number--layout {
  padding-top: 2.3125rem;
  padding-bottom: 5.75rem;
}
@media screen and (max-width: 767px) {
  .number--layout {
    padding-block: 2.5rem;
  }
}

.number__items {
  margin-top: 3.5rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(23.125rem, 1fr));
  -moz-column-gap: 2.75rem;
       column-gap: 2.75rem;
  row-gap: 2rem;
}
@media screen and (max-width: 767px) {
  .number__items {
    grid-template-columns: repeat(1, 1fr);
    row-gap: 2rem;
    margin-top: 2.5rem;
  }
}

.number__item {
  position: relative;
  aspect-ratio: 370/340;
  width: 100%;
  height: auto;
  padding: 1.5rem;
  background: #fff;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  box-shadow: 0 0 20px 0 rgba(60, 86, 52, 0.1);
}
@media screen and (max-width: 767px) {
  .number__item {
    aspect-ratio: 350/230;
    padding: 1.1875rem 1.0625rem;
  }
}

.number__item01 {
  background-image: url("../images/common/number-item01.png");
}

.number__item02 {
  background-image: url("../images/common/number-item02.png");
}

.number__item03 {
  background-image: url("../images/common/number-item03.png");
}

.number__item04 {
  background-image: url("../images/common/number-item04.png");
}

.number__item05 {
  background-image: url("../images/common/number-item05.png");
}

.number__item06 {
  background-image: url("../images/common/number-item06.png");
}

.item__title {
  color: #1246C3;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
}
.item__title::before {
  content: "";
  width: 15px;
  height: 15px;
  aspect-ratio: 1/1;
  background: url("../images/common/title_01.svg") no-repeat center center/contain;
  border-radius: 50%;
}

.item__data {
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  top: 57%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .item__data {
    top: 50%;
  }
}

.item__data-large {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 8rem;
  line-height: 1.2578125;
  letter-spacing: -0.02em;
  font-weight: 700;
  color: #1A61AE;
  -webkit-text-stroke-width: 10px;
  -webkit-text-stroke-color: #fff;
  paint-order: stroke;
  width: 100%;
  display: block;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .item__data-large {
    font-size: 4.5rem;
    line-height: 1.2638888889;
  }
}

.item__data-large03 {
  font-size: 7.1875rem;
  line-height: 1.2695652174;
}
@media screen and (max-width: 767px) {
  .item__data-large03 {
    font-size: 4.5rem;
    line-height: 1.2638888889;
  }
}

.item__data-small {
  position: absolute;
  content: "";
  bottom: -0.625rem;
  right: -2.9375rem;
  font-size: 2.25rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #444;
}
@media screen and (max-width: 767px) {
  .item__data-small {
    bottom: 0rem;
    right: -2.8125rem;
    font-size: 1.5rem;
    line-height: 1.5;
  }
}

.item__data-small03 {
  position: absolute;
  content: "";
  bottom: -1.5625rem;
  right: -1.5625rem;
}
@media screen and (max-width: 767px) {
  .item__data-small03 {
    bottom: 0.3125rem;
    right: -2.5rem;
  }
}

.item__data-small02 {
  position: absolute;
  content: "";
  bottom: -0.8125rem;
  right: -2.5rem;
  font-size: 1.25rem;
}
@media screen and (max-width: 767px) {
  .item__data-small02 {
    bottom: -0.3125rem;
    right: -4.6875rem;
  }
}

.item__data-small01 {
  position: absolute;
  content: "";
  bottom: -1.25rem;
  right: -0.1875rem;
}
@media screen and (max-width: 767px) {
  .item__data-small01 {
    bottom: -0.375rem;
    right: -2.1875rem;
  }
}

.item__data-small04 {
  position: absolute;
  content: "";
  bottom: -1.25rem;
  right: -3.25rem;
}

.p-404 {
  position: relative;
  overflow: hidden;
  padding-top: 12.5rem;
  padding-bottom: 18.75rem;
}
.p-404::before {
  content: "";
  position: absolute;
  top: -20.75rem;
  left: 64%;
  transform: translateX(-50%);
  width: 112.4375rem;
  height: 74.8125rem;
  background: url(../images/common/404-bg.png) no-repeat center center/cover;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-404::before {
    width: 36.5rem;
    height: 43.375rem;
    background: url(../images/common/404-sp-bg.png) no-repeat center center/contain;
    top: -9.6875rem;
    left: 56%;
    transform: translateX(-50%);
  }
}

.p-404__inner {
  max-width: 37.5rem;
  width: 100%;
  margin-inline: auto;
  text-align: center;
}

.p-404__content {
  align-items: center;
  justify-content: center;
}

.p-404__title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 9.375rem;
  line-height: 1.5;
  font-weight: 800;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .p-404__title {
    font-size: 5rem;
    line-height: 1.2625;
  }
}

.p-404__text {
  margin-top: 2.8125rem;
  font-size: 1.375rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 400;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .p-404__text {
    margin-top: 1.75rem;
    font-size: 0.9375rem;
    line-height: 1.8;
  }
}

.recruit {
  background-color: #1A61AE;
  position: relative;
  z-index: 0;
}
.recruit::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 13rem;
  background: url(../images/common/bg-daen.png) no-repeat center center/100% 100%;
  left: 0;
  top: -13rem;
}
@media screen and (max-width: 767px) {
  .recruit::before {
    top: -3.21875rem;
    height: 3.21875rem;
    background-image: url(../images/common/bg-sp-daen.png);
  }
}
.recruit::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 13rem;
  background: url(../images/common/bg-daen-down.png) no-repeat center center/100% 100%;
  left: 0;
  bottom: -13rem;
  z-index: -2;
}
@media screen and (max-width: 767px) {
  .recruit::after {
    bottom: -3.125rem;
    height: 3.21875rem;
    background-image: url(../images/common/bg-daen-down-sp.png);
  }
}

.recruit--layout {
  margin-top: 18.25rem;
}
@media screen and (max-width: 767px) {
  .recruit--layout {
    padding-block: 5rem;
    margin-top: 6.5rem;
  }
}

.recruit__inner {
  max-width: 84.375rem;
  padding-inline: 1.5625rem;
  position: relative;
}
.recruit__inner::before {
  content: "";
  position: absolute;
  max-width: 87.5rem;
  width: 96.875rem;
  height: 131.9375rem;
  background: url(../images/common/recruit-bg.png) no-repeat center center/contain;
  left: 49%;
  transform: translateX(-50%);
  top: -15.25rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .recruit__inner {
    max-width: 37.5rem;
    padding-inline: 1.25rem;
    position: relative;
  }
  .recruit__inner::before {
    content: "";
    position: absolute;
    left: auto;
    right: 0;
    top: 19.0625rem;
    width: 3.03125rem;
    height: 3.46875rem;
    transform: none;
    background: url(../images/common/mvv-bg-sp.png) no-repeat center center/100% auto;
    z-index: -1;
  }
}

.recruit__item-wrap {
  margin-inline: auto;
  width: 100%;
  max-width: 74.5625rem;
  padding-inline: 1.5625rem;
  display: flex;
  align-items: center;
  gap: 9.375rem;
}
@media screen and (max-width: 767px) {
  .recruit__item-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-inline: 0;
  }
}

.recruit__item {
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  .recruit__item {
    margin-top: 3.3125rem;
  }
}

.recruit__item:nth-of-type(even) {
  background-color: #105096;
  border-radius: 3.75rem;
  padding-block: 3.1875rem;
}
@media screen and (max-width: 767px) {
  .recruit__item:nth-of-type(even) {
    margin-top: 2.1875rem;
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    padding-inline: 1.25rem;
  }
}

.recruit__item--reverse .recruit__item-wrap {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .recruit__item--reverse .recruit__item-wrap {
    flex-direction: column;
    margin-inline: -1.25rem;
    padding-inline: 1.25rem;
    width: calc(100% + 2.5rem);
  }
}

.recruit__img {
  width: 100%;
  max-width: 25rem;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .recruit__img {
    margin-top: 1.5rem;
    max-width: 18.75rem;
    order: 2;
  }
}

.recruit__img img {
  box-shadow: 0 0 3.125rem 0 rgba(21, 70, 104, 0.18);
}

@media screen and (max-width: 767px) {
  .recruit__text-wrap {
    display: contents;
  }
}

@media screen and (max-width: 767px) {
  .recruit__skills-wrap {
    order: 3;
  }
}

.recruit__title-wrap {
  width: 100%;
  max-width: 37.0625rem;
}
@media screen and (max-width: 767px) {
  .recruit__title-wrap {
    display: flex;
    flex-direction: column;
  }
}

.recruit__title {
  display: flex;
  gap: 0.3125rem;
  font-size: 2.5rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .recruit__title {
    font-size: 1.875rem;
    flex-direction: column;
    align-items: center;
    text-align: center;
    order: 1;
  }
}

.recruit__text {
  margin-top: 1.875rem;
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .recruit__text {
    line-height: 1.7;
    margin-top: 2rem;
  }
}

.recruit__skills-title {
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 0;
  font-weight: 700;
  color: #fff;
  margin-top: 1.875rem;
}
@media screen and (max-width: 767px) {
  .recruit__skills-title {
    margin-top: 1.5rem;
    line-height: 1.7;
  }
}

.recruit__skills-list {
  margin-top: 0.625rem;
}

.recruit__skills-item {
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 0;
  font-weight: 500;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .recruit__skills-item {
    line-height: 1.7;
  }
}

.recruit__btn {
  margin-top: 3.125rem;
}
@media screen and (max-width: 767px) {
  .recruit__btn {
    margin-top: 2rem;
    order: 4;
  }
}

.recruitment {
  position: relative;
}
.recruitment::before {
  content: "";
  position: absolute;
  width: 4.96875rem;
  height: 6.4375rem;
  background: url(../images/common/recruitment-bg.png) no-repeat center center/contain;
  left: 90%;
  top: 2.875rem;
}
@media screen and (max-width: 767px) {
  .recruitment::before {
    background: url(../images/common/recruitment-bg-sp.png) no-repeat center center/contain;
    width: 2.75rem;
    height: 4.6875rem;
    top: 6.625rem;
    left: 96%;
    transform: translateX(-50%);
  }
}
.recruitment::after {
  content: "";
  position: absolute;
  width: 6.625rem;
  height: 8.5625rem;
  background: url(../images/common/recruitment-bg02.png) no-repeat center center/contain;
  left: 1%;
  top: 20.625rem;
}
@media screen and (max-width: 767px) {
  .recruitment::after {
    background: url(../images/common/recruitment-bg-sp02.png) no-repeat center center/contain;
    width: 2.75rem;
    height: 4.6875rem;
    top: 36.25rem;
    left: 1%;
    transform: translateX(-50%);
  }
}

.recruitment--layout {
  margin-block: 14.5rem;
}
@media screen and (max-width: 767px) {
  .recruitment--layout {
    margin-block: 3rem;
  }
}

.recruitment__title {
  padding-top: 1.5rem;
}
@media screen and (max-width: 767px) {
  .recruitment__title {
    padding-top: 2.8125rem;
  }
}

.recruitment__list {
  margin-top: 3.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .recruitment__list {
    margin-top: 2.6875rem;
    flex-direction: column;
    justify-content: center;
    gap: 1.5rem;
  }
}

.recruitment__item {
  max-width: 23.75rem;
}
@media screen and (max-width: 767px) {
  .recruitment__item {
    max-width: 100%;
  }
}

.recruitment__btn {
  display: inline-flex;
  gap: 0.3125rem;
  width: 100%;
  height: 100%;
  background-color: #3987FD;
  border-radius: 0.9375rem;
  padding: 2.9375rem 1.125rem;
  transition: 0.5s;
  box-shadow: 0px 4px 4px 0 rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 767px) {
  .recruitment__btn {
    gap: 0.125rem;
  }
}
.recruitment__btn::after {
  content: "";
  display: block;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: url(../images/common/recruit-btn-icon.png) no-repeat center/contain;
}
@media screen and (max-width: 767px) {
  .recruitment__btn::after {
    width: 1.84375rem;
    height: 1.84375rem;
    opacity: 1;
  }
}

.recruitment__btn-text {
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .recruitment__btn-text {
    font-size: 1.375rem;
    line-height: 1.5;
    letter-spacing: -0.06em;
  }
}

.sidebar-career {
  width: 100%;
  max-width: 100%;
}
.sidebar-career .sidebar-career__inner {
  width: 100%;
  max-width: 100%;
  padding-left: 1.875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-career__inner {
    padding-left: 0;
  }
}
.sidebar-career .sidebar-career__headline {
  padding-top: 2.1875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-career__headline {
    padding-top: 3.6875rem;
  }
}
.sidebar-career .sidebar-career__body {
  list-style: none;
  padding-left: 0;
}
.sidebar-career .sidebar-career__item {
  position: relative;
  padding-left: 2.1875rem;
}
.sidebar-career .sidebar-career__item::after {
  content: "";
  position: absolute;
  top: 0.8125rem;
  left: 2.8125rem;
  width: 0.0625rem;
  height: calc(100% - 3.125rem);
  background-color: #D2D2D2;
  height: 135%;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-career__item::after {
    left: 2.125rem;
    top: 0.9375rem;
    height: 124%;
  }
}
.sidebar-career .sidebar-career__item:last-child::after {
  display: none;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-career__item {
    padding-left: 1.6875rem;
  }
}
.sidebar-career .sidebar-career__image {
  margin-top: 4.6875rem;
  margin-left: auto;
  margin-right: auto;
  max-width: 33.75rem;
  aspect-ratio: 540/360;
  position: relative;
  isolation: isolate;
}
.sidebar-career .sidebar-career__image::before {
  content: "";
  position: absolute;
  bottom: -7rem;
  width: 17.375rem;
  height: 17.4375rem;
  background: url(../images/common/carrierpass-bubble.png) no-repeat center center/cover;
  left: calc(50% + 5.625rem);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-career__image::before {
    width: 7.6875rem;
    height: 7.75rem;
    bottom: -1.8125rem;
    left: calc(50% + 4.0625rem);
  }
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-career__image {
    margin-top: 3.125rem;
    max-width: 25rem;
    aspect-ratio: 305/205;
  }
}
.sidebar-career .sidebar-career__image img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  border-radius: 0.8125rem;
}
.sidebar-career .sidebar-work__headline {
  margin-top: 4.6875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-work__headline {
    margin-top: 2.8125rem;
  }
}
.sidebar-career .sidebar-work__image {
  margin-top: 1.5rem;
  max-width: 33.75rem;
  aspect-ratio: 540/360;
  overflow: hidden;
  border-radius: 0.625rem;
}
@media screen and (max-width: 767px) {
  .sidebar-career .sidebar-work__image {
    max-width: 25rem;
    aspect-ratio: 305/205;
  }
}
.sidebar-career .sidebar-work__image img,
.sidebar-career .sidebar-work__image .sidebar-work__image-item {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.sidebar-job-reward {
  position: relative;
}

.sidebar-job-reward--layout {
  margin-top: 4.6875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-job-reward--layout {
    margin-top: 3.125rem;
  }
}

.sidebar-job-reward__inner {
  max-width: 48.25rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1.5625rem;
  padding-left: 1.5625rem;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .sidebar-job-reward__inner {
    max-width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
}

.sidebar-job-reward__body {
  padding-left: 1.875rem;
  position: relative;
  isolation: isolate;
}
@media screen and (max-width: 767px) {
  .sidebar-job-reward__body {
    padding-left: 0;
  }
}

.sidebar-job-reward__image {
  margin-top: 4.6875rem;
  width: 100%;
  max-width: 33.75rem;
  aspect-ratio: 540/360;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  isolation: isolate;
}
.sidebar-job-reward__image::before {
  content: "";
  position: absolute;
  width: 16.75rem;
  height: 17.5625rem;
  background: url(../images/common/sidebar-work-bubble.png) no-repeat center center/contain;
  left: calc(50% - 23.375rem);
  z-index: -1;
  bottom: -5.5rem;
}
@media screen and (max-width: 767px) {
  .sidebar-job-reward__image::before {
    bottom: -2rem;
    left: calc(50% - 12.375rem);
    width: 7.8125rem;
    height: 7.8125rem;
  }
}
@media screen and (max-width: 767px) {
  .sidebar-job-reward__image {
    margin-top: 3.625rem;
    width: 100%;
    max-width: 22.8125rem;
    aspect-ratio: 281/187;
  }
}

.sidebar-job-reward__image img,
.sidebar-job-reward__image .sidebar-job-reward__image-item {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  border-radius: 0.625rem;
}

.sidebar-message--layout {
  margin-top: 4.6875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-message--layout {
    margin-top: 3.125rem;
  }
}

.sidebar-message__inner {
  padding-left: 1.875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-message__inner {
    padding-left: 0;
  }
}

.sidebar-message__body {
  padding-left: 2.5rem;
}
@media screen and (max-width: 767px) {
  .sidebar-message__body {
    padding-left: 0;
  }
}

.sidebar-schedule__inner {
  padding-left: 1.875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-schedule__inner {
    padding-left: 0;
  }
}

.sidebar-schedule__headline {
  margin-top: 4.6875rem;
}

@media screen and (max-width: 767px) {
  .sidebar-schedule__items {
    max-width: 100%;
    width: 100%;
  }
}

.sidebar-schedule__list {
  position: relative;
  max-width: 42.1875rem;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 4.0625rem;
  position: relative;
  padding: 3.5rem 3.9375rem 3.5rem 6rem;
  margin-bottom: 40px;
  border-radius: 50px;
  border: 1px solid #E2F3F9;
  background: #fff;
  box-shadow: 0 4px 30px 0 rgba(57, 141, 249, 0.15);
}
@media screen and (max-width: 767px) {
  .sidebar-schedule__list {
    margin-top: 3rem;
    padding-inline: 2.25rem;
    padding-block: 1.875rem;
    max-width: 100%;
    width: 100%;
  }
}

.schedule__item {
  position: relative;
  display: flex;
  padding-bottom: 1.5rem;
  padding-top: 1.5rem;
  border-bottom: 1px solid #D2E8F7;
  width: 100%;
  font-size: 1.5rem;
  font-weight: 500;
  color: #000;
}
.schedule__item:last-child {
  margin-bottom: 0;
}
.schedule__item::before {
  content: "";
  position: absolute;
  top: 2rem;
  left: -2.1875rem;
  width: 1.25rem;
  height: 1.25rem;
  aspect-ratio: 1/1;
  background: url(../images/common/bubble-01.png) no-repeat center center/contain;
  z-index: 1;
  transform: translateY(28%);
}
@media screen and (max-width: 767px) {
  .schedule__item::before {
    left: -1.25rem;
  }
}
.schedule__item::after {
  content: "";
  position: absolute;
  top: 2.625rem;
  left: -1.5625rem;
  width: 0.0625rem;
  height: 100%;
  background-color: #D2D2D2;
}
@media screen and (max-width: 767px) {
  .schedule__item::after {
    left: -0.625rem;
  }
}
.schedule__item:last-child::after {
  display: none;
}
@media screen and (max-width: 767px) {
  .schedule__item {
    font-size: 1.25rem;
    padding-left: 1.875rem;
  }
}

.schedule__content {
  flex: 1;
  margin-left: 1.5rem;
  font-size: 1.5rem;
  font-weight: 500;
  color: #000;
}
@media screen and (max-width: 767px) {
  .schedule__content {
    font-size: 1.25rem;
    margin-left: 2.5rem;
  }
}

.sidebar-schedule__image {
  width: 100%;
  max-width: 33.75rem;
  aspect-ratio: 540/360;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  isolation: isolate;
}
.sidebar-schedule__image::before {
  content: "";
  position: absolute;
  bottom: 5rem;
  width: 16.75rem;
  height: 17.5625rem;
  background: url(../images/common/sidebar-schedule-bubble.png) no-repeat center center/contain;
  left: calc(50% + 6.625rem);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .sidebar-schedule__image::before {
    left: calc(50% + 4.9375rem);
    top: 0.8125rem;
    width: 7.875rem;
    height: 7.875rem;
  }
}
@media screen and (max-width: 767px) {
  .sidebar-schedule__image {
    max-width: 22.8125rem;
    width: 100%;
    aspect-ratio: 278/187;
  }
}

.sidebar-schedule__image img,
.sidebar-schedule__image .sidebar-schedule__image-item {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  border-radius: 0.8125rem;
}

.sidebar-work {
  width: 100%;
  max-width: 100%;
  position: relative;
  isolation: isolate;
}

.sidebar-work__inner {
  padding-left: 1.875rem;
}
@media screen and (max-width: 767px) {
  .sidebar-work__inner {
    padding-left: 0;
  }
}

.section-sidebar-work__item {
  padding-inline: 2.5rem;
}
@media screen and (max-width: 767px) {
  .section-sidebar-work__item {
    padding-inline: initial;
  }
}

.sidebar-work__image {
  margin-top: 4.6875rem;
  max-width: 33.75rem;
  aspect-ratio: 540/360;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  isolation: isolate;
}
.sidebar-work__image::before {
  content: "";
  position: absolute;
  bottom: 12rem;
  width: 17.375rem;
  height: 17.4375rem;
  background: url(../images/common/sidebar-work-bubble.png) no-repeat center center/contain;
  left: calc(50% - 23.625rem);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .sidebar-work__image::before {
    width: 6.5rem;
    height: 6.5625rem;
    bottom: 8rem;
    left: calc(50% - 11.375rem);
  }
}
@media screen and (max-width: 767px) {
  .sidebar-work__image {
    max-width: 25rem;
    aspect-ratio: 305/205;
  }
}

.sidebar-work__image img,
.sidebar-work__image .sidebar-work__image-item {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  border-radius: 0.8125rem;
}

.single-interview__container {
  display: flex;
  gap: 1.875rem;
  min-width: 0;
  background-color: #F1FAFF;
  padding-top: 4.6875rem;
  padding-bottom: 4.6875rem;
  max-width: 77.4375rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .single-interview__container {
    flex-direction: column;
    padding-top: 3.125rem;
    padding-bottom: 3.125rem;
  }
}

.single-interview__inner {
  width: 100%;
  max-width: 80.5625rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1.5625rem;
  padding-left: 1.5625rem;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .single-interview__inner {
    padding-right: 0.625rem;
    padding-left: 0.625rem;
    max-width: 37.5rem;
  }
}

.single-interview-wrap {
  background-color: #F1FAFF;
}

.single-interview-wrap__sidebar {
  max-width: 24.5rem;
  width: 100%;
  box-sizing: border-box;
  transition: none;
  position: sticky;
  top: 5.3125rem;
  left: 0;
}
@media screen and (max-width: 767px) {
  .single-interview-wrap__sidebar {
    padding-inline: 0;
    max-width: 100%;
    position: static;
  }
}

/* JS で .is-sticky 付与時に position: fixed で追従 */
.single-interview-wrap__sidebar.is-sticky {
  position: fixed;
  top: 4.6875rem;
}

.single-interview-wrap__sidebar.is-sticky-bottom {
  position: absolute;
  top: auto;
  bottom: 4.6875rem;
}

.sidebar__name {
  margin-top: 3.75rem;
  font-size: 1.25rem;
  line-height: 1.5;
  font-weight: 700;
  color: #000;
}
@media screen and (max-width: 767px) {
  .sidebar__name {
    font-size: 1.0625rem;
    line-height: 1.4705882353;
    text-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  }
}

.sidebar__image {
  max-width: 24.5rem;
  border-radius: 0.625rem;
  aspect-ratio: 392/497;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .sidebar__image {
    aspect-ratio: 330/415;
    max-width: 100%;
  }
}
.sidebar__image .sidebar__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.sidebar__content {
  min-width: 0;
  max-width: 48.875rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1.5625rem;
  padding-left: 1.5625rem;
  background-color: #fff;
  border-radius: 0.8125rem;
  box-sizing: border-box;
  padding-bottom: 6.5625rem;
  overflow-x: clip;
}
@media screen and (max-width: 767px) {
  .sidebar__content {
    padding-bottom: 4.125rem;
    max-width: none;
    padding-inline: 1.25rem;
    max-width: none;
  }
}

.sidebar__position {
  margin-top: 1.3125rem;
}

.single-work--layout {
  padding-top: 18.75rem;
  position: relative;
  overflow: visible;
}
.single-work--layout::before {
  content: "";
  position: absolute;
  width: 46.875rem;
  height: 46.875rem;
  background: url(../images/common/single-work-bubble01.png) no-repeat center center/contain;
  z-index: 0;
  right: 2.8125rem;
  top: -30.625rem;
  transform: translateX(50%);
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .single-work--layout::before {
    width: 17.625rem;
    height: 17.625rem;
    right: 0.5625rem;
    top: -10.625rem;
  }
}
.single-work--layout::after {
  content: "";
  position: absolute;
  width: 32.5rem;
  height: 32.5rem;
  background: url(../images/common/single-work-bubble02.png) no-repeat center center/contain;
  z-index: -1;
  left: -8.875rem;
  top: 18.75rem;
  transform: translate(-50%, 0);
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .single-work--layout::after {
    width: 8.75rem;
    height: 8.75rem;
    background: url(../images/common/single-work-bubble02-sp.png) no-repeat center center/contain;
    left: 0;
    top: 38.25rem;
  }
}
@media screen and (max-width: 767px) {
  .single-work--layout {
    padding-top: 7.375rem;
  }
}

.single-work__title {
  font-size: 2.25rem;
  line-height: 1.3055555556;
  font-weight: 700;
  color: #1A61AE;
  padding-bottom: 2.125rem;
  border-bottom: 2px solid #A8BACE;
}
@media screen and (max-width: 767px) {
  .single-work__title {
    font-size: 1rem;
    line-height: 1.5;
    align-self: stretch;
    padding-bottom: 0.625rem;
    border-bottom: 1px solid #A8BACE;
  }
}

.single-work__inner {
  position: relative;
}

.single-work__content {
  margin-top: 3.75rem;
  margin-left: auto;
  margin-right: auto;
  max-width: 70.5rem;
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 1.875rem;
}
@media screen and (max-width: 767px) {
  .single-work__content {
    margin-top: 2.5rem;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }
}

.single-work__scroll-down {
  position: absolute;
  left: -0.625rem;
  bottom: 0;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .single-work__scroll-down {
    left: 0.8125rem;
    bottom: -5rem;
  }
}

.single-work__image {
  max-width: 32.5rem;
  width: 100%;
  overflow: hidden;
  border-radius: 0.625rem;
}
.single-work__image img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 520/350;
}
@media screen and (max-width: 767px) {
  .single-work__image {
    width: 100%;
    max-width: 20.625rem;
    aspect-ratio: 520/350;
  }
}

.thanks {
  padding-block: 12.5rem;
  position: relative;
  overflow: hidden;
}
.thanks::before {
  content: "";
  position: absolute;
  width: 111.0625rem;
  height: 74.779375rem;
  background: url(../images/common/thanks-bg.png) no-repeat center center/contain;
  margin-right: calc(50% - 50vw);
  left: 2cap;
  top: -20.75rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .thanks::before {
    width: 31.25rem;
    height: 43.505625rem;
    left: calc(50% - 11.625rem);
    background: url(../images/common/thanks-bg-sp.png) no-repeat center center/contain;
    top: -10rem;
  }
}

.thanks__text {
  margin-top: 12.5rem;
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .thanks__text {
    margin-top: 0;
    font-size: 2rem;
    line-height: 1.3125;
  }
}

.thanks__text-sub {
  margin-top: 1.9375rem;
  text-align: center;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.01125em;
  background: linear-gradient(177deg, #1A386B 13.69%, #1A386B 65.17%, #346DD1 96.87%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 767px) {
  .thanks__text-sub {
    text-align: center;
    margin-top: 2rem;
    font-size: 0.9375rem;
    line-height: 1.7333333333;
    letter-spacing: 0.009375em;
  }
}

.top-about {
  position: relative;
}

.top-about--layout {
  margin-top: 0.125rem;
}
@media screen and (max-width: 767px) {
  .top-about--layout {
    margin-top: 2.25rem;
  }
}

.top-about__content {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .top-about__content {
    flex-direction: column;
  }
}

.top-about__wrap {
  margin-top: 1.3125rem;
  max-width: 27.3125rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top-about__wrap {
    display: contents;
    max-width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .top-about__title {
    order: 1;
  }
}

.top-about__text {
  margin-top: 1.875rem;
  font-size: 1.125rem;
  line-height: 160%;
  letter-spacing: 0;
  font-weight: 500;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .top-about__text {
    order: 3;
    margin-top: 2rem;
    font-size: 1rem;
  }
}

.top-about__img {
  max-width: 38.25rem;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .top-about__img {
    max-width: 100%;
    margin-top: 2.125rem;
    order: 2;
  }
}

.top-about__btn {
  margin-top: 3.75rem;
}
@media screen and (max-width: 767px) {
  .top-about__btn {
    order: 4;
    margin-top: 1.25rem;
  }
}

.top-business {
  position: relative;
}

.top-business--layout {
  margin-top: 6.5rem;
}
@media screen and (max-width: 767px) {
  .top-business--layout {
    margin-top: 4.82375rem;
  }
}

.top-business__content {
  max-width: 70.5rem;
  width: 100%;
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.125rem;
}
@media screen and (max-width: 767px) {
  .top-business__content {
    display: flex;
    flex-direction: column;
  }
}

@media screen and (max-width: 767px) {
  .top-business__title {
    margin-inline: unset;
    width: 100%;
    order: 1;
  }
}

.top-business__img {
  max-width: 34.25rem;
  width: 100%;
  aspect-ratio: 548/570;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767px) {
  .top-business__img {
    margin-top: 2rem;
    max-width: 21.875rem;
    aspect-ratio: 350/278;
    width: 100%;
    order: 2;
  }
}

.top-business__wrap {
  margin-top: 7.75rem;
  margin-left: 7.4375rem;
  max-width: 26.625rem;
  width: 100%;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .top-business__wrap {
    display: contents;
  }
}

.top-business__text {
  margin-top: 1.875rem;
  font-size: 1rem;
  line-height: 160%;
  letter-spacing: 0;
  font-weight: 500;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .top-business__text {
    margin-top: 2rem;
    order: 3;
  }
}

.top-business__btn {
  margin-top: 3.75rem;
}
@media screen and (max-width: 767px) {
  .top-business__btn {
    width: 100%;
    margin-top: 0.9375rem;
    order: 4;
  }
}

.top-culture {
  position: relative;
  background-color: #1A61AE;
  overflow: hidden;
}
.top-culture::before {
  content: "";
  position: absolute;
  width: 93.316875rem;
  height: 41.5675rem;
  background: url(../images/common/top-culture_bg.png) no-repeat center center/contain;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .top-culture::before {
    background: url(../images/common/top-culture-sp_bg.png) no-repeat center center/contain;
    width: 26.4375rem;
    height: 16.875rem;
    top: 15.6875rem;
    left: 46%;
    transform: translateX(-50%);
    z-index: 1;
  }
}

.top-culture--layout {
  padding-top: 5rem;
  padding-bottom: 9.25rem;
}
@media screen and (max-width: 767px) {
  .top-culture--layout {
    padding-top: 0;
    padding-bottom: 1.875rem;
  }
}

.top-culture__content {
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
}
@media screen and (max-width: 767px) {
  .top-culture__content {
    flex-direction: column;
  }
}

.top-culture__wrap {
  max-width: 31.0625rem;
  width: 100%;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .top-culture__wrap {
    display: contents;
  }
}

.top-culture__title {
  margin-top: 78px;
}
@media screen and (max-width: 767px) {
  .top-culture__title {
    order: 1;
  }
}

.top-culture__text {
  margin-top: 1.875rem;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.6;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .top-culture__text {
    margin-top: 2rem;
    font-size: 1rem;
    order: 3;
  }
}

.top-culture__btn {
  margin-top: 4.75rem;
}
@media screen and (max-width: 767px) {
  .top-culture__btn {
    order: 4;
    margin-top: 0.9375rem;
    margin-inline: auto;
  }
}

.top-culture__img {
  max-width: 42.9375rem;
  width: 100%;
  aspect-ratio: 687/563;
  overflow: hidden;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .top-culture__img {
    margin-top: 2.4375rem;
    max-width: 21.875rem;
    aspect-ratio: 350/289;
    order: 2;
  }
}

.top-team {
  position: relative;
  overflow: hidden;
  background-color: #1A61AE;
}

.top-team--layout {
  padding-top: 6.5rem;
  padding-bottom: 1.875rem;
}
@media screen and (max-width: 767px) {
  .top-team--layout {
    padding-top: 2.8125rem;
  }
}

.top-team__inner {
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .top-team__contentWrap {
    display: flex;
    flex-direction: column;
  }
}

.top-team__content {
  margin-top: 4.375rem;
  display: flex;
  max-width: 72.3125rem;
  width: 100%;
  z-index: 3;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .top-team__content {
    margin-top: 2.8125rem;
    flex-direction: column;
    display: contents;
  }
}

.top-team__title {
  flex: 1;
}
@media screen and (max-width: 767px) {
  .top-team__title {
    order: 1;
  }
}

.top-team__text {
  margin-top: 1.875rem;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.6;
  color: #fff;
  max-width: 35rem;
}
@media screen and (max-width: 767px) {
  .top-team__text {
    order: 2;
    margin-top: 2.3125rem;
    font-size: 1rem;
  }
}

.top-team__btn {
  margin-top: 7.3125rem;
  flex-shrink: 0;
  max-width: 26.78125rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top-team__btn {
    margin-top: 2rem;
    max-width: 19.375rem;
    order: 3;
    margin-inline: auto;
  }
}

.top-team__cta {
  display: inline-flex;
  align-items: center;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: #D2E8F7;
  text-decoration: none;
}

.top-team__img {
  margin-top: 4.375rem;
  margin-inline: calc(50% - 50vw);
}
@media screen and (max-width: 767px) {
  .top-team__img {
    margin-left: 0;
    margin-top: 2.5rem;
    order: 2;
  }
}

.top-work {
  margin-top: 6.5rem;
  padding-bottom: 3.1875rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .top-work {
    margin-top: 2.8375rem;
    padding-bottom: 1.75rem;
  }
}

.top-work__content {
  max-width: 70.5rem;
  width: 100%;
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.25rem;
}
@media screen and (max-width: 767px) {
  .top-work__content {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }
}

.top-work__wrap {
  margin-top: 8.0625rem;
  max-width: 26.625rem;
  width: 100%;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .top-work__wrap {
    display: contents;
    margin-top: 0;
    margin-right: 0;
    max-width: none;
    width: auto;
  }
}

@media screen and (max-width: 767px) {
  .top-work__title {
    order: 1;
  }
}

.top-work__text {
  margin-top: 1.875rem;
  font-size: 1rem;
  line-height: 160%;
  letter-spacing: 0;
  font-weight: 500;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .top-work__text {
    margin-top: 2rem;
    order: 3;
  }
}

.top-work__btn {
  margin-top: 3.75rem;
}
@media screen and (max-width: 767px) {
  .top-work__btn {
    margin-top: 0.9375rem;
    order: 4;
  }
}

.top-work__img {
  max-width: 34.25rem;
  width: 100%;
  aspect-ratio: 547/572;
  overflow: hidden;
}
.top-work__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
@media screen and (max-width: 767px) {
  .top-work__img {
    margin-top: 2rem;
    max-width: 21.875rem;
    aspect-ratio: 350/289;
    order: 2;
  }
}

.work-company {
  max-width: 75rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .work-company {
    padding-top: 0;
    width: 100%;
  }
}

.work-company--layout {
  margin-top: 4.6875rem;
}
@media screen and (max-width: 767px) {
  .work-company--layout {
    padding-top: 2.4375rem;
    padding-bottom: 6.375rem;
  }
}

.work-company__title {
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .work-company__title {
    font-size: 1.5rem;
  }
}

.work-company__line {
  height: 2px;
  background-color: #A8BACE;
  border: none;
}
.work-company__line--top {
  margin-top: 0;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-company__line--top {
    margin-bottom: 2rem;
  }
}
.work-company__line:not(.work-company__line--top):not(.work-company__line--bottom) {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-company__line:not(.work-company__line--top):not(.work-company__line--bottom) {
    margin-top: 2rem;
  }
}
.work-company__line--bottom {
  margin-top: 4.375rem;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .work-company__line--bottom {
    margin-top: 3.75rem;
  }
}

.work-company__body {
  margin-top: 2.5rem;
  padding-left: 2.375rem;
}
@media screen and (max-width: 767px) {
  .work-company__body {
    padding-left: 0;
    margin-top: 2rem;
  }
}

.work-company__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0rem 2.5rem;
  margin: 0;
  align-items: flex-start;
  margin-top: 1.75rem;
  padding-top: 1.75rem;
  border-bottom: 2px solid #EBECEC;
  padding-bottom: 1.75rem;
}
@media screen and (max-width: 767px) {
  .work-company__row {
    flex-direction: column;
    gap: 0.5rem;
    max-width: 20.4375rem;
    width: 100%;
  }
}

.work-company__label {
  flex: 0 0 20.3125rem;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .work-company__label {
    flex: none;
    font-size: 1.125rem;
  }
}

.work-company__value {
  flex: 1;
  min-width: 0;
  margin: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.5;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .work-company__value {
    font-size: 1rem;
  }
}
.work-company__value p {
  margin: 0;
}
.work-company__value p + p {
  margin-top: 0.125em;
}

.work-conditions {
  max-width: 75rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-top: 2.5rem;
  padding-bottom: 0;
  padding-bottom: 2.125rem;
  border-bottom: 2px solid #A8BACE;
}
@media screen and (max-width: 767px) {
  .work-conditions {
    padding-top: 2rem;
    width: 100%;
    padding-bottom: 2.125rem;
    border-bottom: 1px solid #A8BACE;
  }
}

.work-conditions__title {
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .work-conditions__title {
    font-size: 1.5rem;
  }
}

.work-conditions__line {
  height: 2px;
  background-color: #A8BACE;
  border: none;
}
.work-conditions__line--top {
  margin-top: 0;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-conditions__line--top {
    margin-bottom: 2rem;
  }
}
.work-conditions__line:not(.work-conditions__line--top):not(.work-conditions__line--bottom) {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-conditions__line:not(.work-conditions__line--top):not(.work-conditions__line--bottom) {
    margin-top: 2rem;
  }
}
.work-conditions__line--bottom {
  margin-top: 4.375rem;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .work-conditions__line--bottom {
    margin-top: 3.75rem;
  }
}

.work-conditions__body {
  margin-top: 2.5rem;
  padding-left: 2.375rem;
}
@media screen and (max-width: 767px) {
  .work-conditions__body {
    padding-left: 0;
    margin-top: 2rem;
  }
}

.work-conditions__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0rem 2.5rem;
  margin: 0;
}
.work-conditions__row:not(:first-child) {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-conditions__row:not(:first-child) {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .work-conditions__row {
    flex-direction: column;
    gap: 0.5rem;
  }
}

.work-conditions__label {
  flex: 0 0 20.3125rem;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .work-conditions__label {
    flex: none;
    font-size: 1.125rem;
  }
}

.work-conditions__value {
  flex: 1;
  min-width: 0;
  margin: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.5;
  color: #333333;
}
.work-conditions__value p + p {
  margin-top: 0.125em;
}

.work-content {
  max-width: 75rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-top: 2.5rem;
  padding-bottom: 4.6875rem;
  border-bottom: 2px solid #A8BACE;
}
@media screen and (max-width: 767px) {
  .work-content {
    padding-top: 2rem;
    border-bottom: 1px solid #A8BACE;
    padding-bottom: 2.125rem;
    width: 100%;
  }
}

.single-work__inner {
  max-width: 80rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1.25rem;
  padding-left: 1.25rem;
}
@media screen and (max-width: 767px) {
  .single-work__inner {
    padding-right: 1.25rem;
  }
}

.work-content .work-content__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .work-content .work-content__title {
    font-size: 1.5rem;
  }
}

.work-content__body {
  margin-top: 2.5rem;
  padding-left: 2.375rem;
}
@media screen and (max-width: 767px) {
  .work-content__body {
    padding-left: 0;
    margin-top: 2rem;
  }
}

.work-content__block:not(:first-child) {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-content__block:not(:first-child) {
    margin-top: 2rem;
  }
}

.work-content__subtitle {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  color: #2C5DB3;
  padding-left: 1.5625rem;
}
.work-content__subtitle::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  width: 15px;
  height: 15px;
  aspect-ratio: 1/1;
  background: url("../images/common/title_01.svg") no-repeat center center/contain;
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  .work-content__subtitle {
    font-size: 1.25rem;
    padding-left: 1.375rem;
    gap: 8px;
  }
  .work-content__subtitle::before {
    width: 12px;
    height: 12px;
  }
}

.work-content__text {
  margin-top: 0.9375rem;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.6;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .work-content__text {
    margin-top: 0.75rem;
    font-size: 1rem;
  }
}

.work-content__text ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.work-content__text li {
  position: relative;
  padding-left: 0.8125rem;
}

.bullet {
  position: relative;
  padding-left: 1.25rem;
}
.bullet::before {
  content: "";
  position: absolute;
  left: 0.3125rem;
  top: 0.75rem;
  width: 0.25rem;
  height: 0.25rem;
  background-color: #3987FD;
  border-radius: 50%;
}

.work-requirements {
  max-width: 75rem;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  margin-top: 4.6875rem;
  padding-bottom: 4.6875rem;
  border-bottom: 2px solid #A8BACE;
  position: relative;
  overflow: visible;
}
.work-requirements::before {
  content: "";
  position: absolute;
  width: 17.90625rem;
  height: 17.90625rem;
  background: url(../images/common/single-work-bubble03.png) no-repeat center center/100% 100%;
  z-index: 0;
  right: -20.4375rem;
  top: -11.1875rem;
  transform: translateX(-50%);
  z-index: -1;
  margin-right: calc(50% - 50vw);
}
@media screen and (max-width: 767px) {
  .work-requirements::before {
    display: none;
  }
}
.work-requirements:after {
  position: absolute;
  content: "";
  width: 20.78125rem;
  height: 20.78125rem;
  background: url(../images/common/single-work-bubble04.png) no-repeat center center/100% 100%;
  z-index: -1;
  left: -4.5rem;
  bottom: -10rem;
  transform: translateX(-50%);
  margin-left: calc(50% - 50vw);
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .work-requirements:after {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .work-requirements {
    padding-top: 0;
    border-bottom: 1px solid #A8BACE;
    padding-bottom: 2.125rem;
    width: 100%;
  }
}

.work-requirements__title {
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  color: #1A61AE;
}
@media screen and (max-width: 767px) {
  .work-requirements__title {
    font-size: 1.5rem;
  }
}

.work-requirements__line {
  height: 2px;
  background-color: #A8BACE;
  border: none;
}
.work-requirements__line--top {
  margin-top: 0;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-requirements__line--top {
    margin-bottom: 2rem;
  }
}
.work-requirements__line:not(.work-requirements__line--top):not(.work-requirements__line--bottom) {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-requirements__line:not(.work-requirements__line--top):not(.work-requirements__line--bottom) {
    margin-top: 2rem;
  }
}
.work-requirements__line--bottom {
  margin-top: 4.375rem;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .work-requirements__line--bottom {
    margin-top: 3.75rem;
  }
}

.work-requirements__body {
  margin-top: 2.5rem;
  padding-left: 2.375rem;
}
@media screen and (max-width: 767px) {
  .work-requirements__body {
    padding-left: 0;
    margin-top: 2rem;
  }
}

.work-requirements__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0rem 2.5rem;
  margin: 0;
}
.work-requirements__row:not(:first-child) {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767px) {
  .work-requirements__row:not(:first-child) {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .work-requirements__row {
    flex-direction: column;
    gap: 0.5rem;
  }
}

.work-requirements__label {
  flex: 0 0 20.3125rem;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .work-requirements__label {
    flex: none;
    font-size: 1.125rem;
  }
}

.work-requirements__value {
  flex: 1;
  min-width: 0;
  margin: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.5;
  color: #333333;
}

.working {
  position: relative;
}
.working::before {
  content: "";
  position: absolute;
  width: 100.5rem;
  height: 44.375rem;
  background: url(../images/common/way-of-working-bubble.png) no-repeat center center/contain;
  z-index: -1;
  left: 50%;
  transform: translateX(-54%);
  top: -3.75rem;
}
@media screen and (max-width: 767px) {
  .working::before {
    width: 3.8125rem;
    height: 4.875rem;
    top: 6.75rem;
    background: url(../images/common/way-of-working-bubble-sp.png) no-repeat center center/contain;
    transform: translateX(-50%);
    left: 94%;
  }
}

.working--layout {
  margin-top: 2.5625rem;
  overflow-x: clip;
}
@media screen and (max-width: 767px) {
  .working--layout {
    margin-top: 2.5rem;
  }
}

.working__content {
  max-width: 74.8125rem;
  width: 100%;
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
}
@media screen and (max-width: 767px) {
  .working__content {
    flex-direction: column;
    align-items: stretch;
    gap: 2rem;
  }
}

.working__wrap {
  max-width: 31.5rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .working__wrap {
    display: contents;
  }
}

.working__title {
  max-width: 31.5rem;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .working__title {
    max-width: 100%;
    order: 1;
  }
}

@media screen and (max-width: 767px) {
  .working__text-wrap {
    order: 3;
  }
}

.working__headline {
  margin-top: 1.875rem;
  font-size: 1.875rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 700;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .working__headline {
    margin-top: 2rem;
    font-size: 1.25rem;
  }
}

.working__text {
  margin-top: 1.5rem;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0;
  font-weight: 400;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .working__text {
    margin-top: 1.25rem;
    font-size: 1rem;
    line-height: 1.7;
  }
}

.working__img {
  max-width: 35.5rem;
  width: 100%;
  aspect-ratio: 568/432;
  overflow: hidden;
  border-radius: 0.625rem;
}
.working__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
@media screen and (max-width: 767px) {
  .working__img {
    margin-top: 32px;
    max-width: 100%;
    aspect-ratio: 350/222;
    order: 2;
  }
}

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

.md-show {
  display: none;
}
@media screen and (max-width: 767px) {
  .md-show {
    display: block;
  }
}
/*# sourceMappingURL=style.css.map */
