@charset "UTF-8";
/*!
page > common > common
------------------------------
*/
:where(body) {
  --content-max-width: 965px;
  --content-width--pc: min(calc(100% - 8%), 965px);
  --content-width--sp: min(calc(100% - 8%), calc(100% - 3rem));
  --transition-fast: 0.2s;
  /* color */
  --color-red1: #FA000F;
  --color-red1-20: #FFCBCE;
  --color-red1-40: #7D0008;
  --color-red2: #CC0000;
  --color-gray1: #F4F4F4;
  --color-gray2: #D9D9D9;
  --color-gray5: #4D4D4D;
  --color-gray6: #222222;
  --color-white: #fff;
  --color-black: #0C0C0C;
  --border-radius-base: 8px;
  --font-jp: "Noto Sans JP", sans-serif;
  --fz-h3: calc(22 / 16 * 1rem);
  --fz-h5: calc(17 / 16 * 1rem);
  --fz-h6: calc(16 / 16 * 1rem);
  --fz-p: calc(15 / 16 * 1rem);
  --fz-pc_h1: calc(44 / 16 * 1rem);
  --fz-sp_h1: calc(30 / 16 * 1rem);
  --fz-pcsp_sub: calc(14 / 16 * 1rem);
}
@media screen and (min-width: 768px) {
  :where(body) {
    --fz-h3: calc(26 / 16 * 1rem);
    --fz-h5: calc(18 / 16 * 1rem);
    --fz-p: 1rem;
    --border-radius-base: 16px;
  }
}

/*!
global > mixin
------------------------------
*/
/*!
foundation > base
------------------------------
*/
html.lenis,
html.lenis body {
  height: auto;
}

html,
body {
  -ms-scroll-chaining: none;
      overscroll-behavior: none;
}

.lenis:not(.lenis-autoToggle).lenis-stopped {
  overflow: clip;
}

.lenis [data-lenis-prevent],
.lenis [data-lenis-prevent-wheel],
.lenis [data-lenis-prevent-touch] {
  -ms-scroll-chaining: none;
      overscroll-behavior: contain;
}

.lenis.lenis-smooth iframe {
  pointer-events: none;
}

.lenis.lenis-autoToggle {
  -webkit-transition-property: overflow;
  transition-property: overflow;
  -webkit-transition-duration: 1ms;
          transition-duration: 1ms;
  transition-behavior: allow-discrete;
}

#SiteID span {
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  #SiteID span {
    font-size: 0.875rem;
  }
}
#SiteID a + a {
  margin-left: 24px;
}
@media screen and (max-width: 767px) {
  #SiteID a + a {
    margin-left: 24px;
  }
}
#SiteID a + a::before {
  left: -12px;
}

@media screen and (max-width: 767px) {
  #HeaderArea2 > .Container #SiteID {
    padding-block: 15px;
  }
}
#HeaderArea2 > .Container #SiteID span {
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  #HeaderArea2 > .Container #SiteID span {
    font-size: 0.875rem;
  }
}
#HeaderArea2 > .Container #SiteID a + a {
  margin-left: 24px;
}
#HeaderArea2 > .Container #SiteID a + a::before {
  left: -12px;
}

#GlobalNaviMenu > li > a {
  padding: 0 16px;
}

header {
  z-index: 71;
  min-height: initial !important;
}

footer {
  position: relative;
  z-index: 5;
}
footer #FooterPageTop {
  border: none;
  outline: none;
}

body {
  opacity: 0;
}
body.loaded {
  opacity: 1;
  -webkit-transition: opacity 0.1s;
  transition: opacity 0.1s;
}

:where(main) *,
:where(main) *::before,
:where(main) *::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

:where(main) {
  letter-spacing: 0.04em;
  color: var(--color-black);
  font-family: var(--font-jp);
  background-color: var(--color-white);
}
:where(main) h1,
:where(main) h2,
:where(main) h3,
:where(main) h4,
:where(main) h5,
:where(main) h6,
:where(main) figure {
  margin: 0;
}
:where(main) h2 {
  background: transparent;
}
@-webkit-keyframes transformRightLeft {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@keyframes transformRightLeft {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@-webkit-keyframes transformLeftRight {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes transformLeftRight {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes transformDown1 {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
}
@keyframes transformDown1 {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
}
@-webkit-keyframes transformDown2 {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes transformDown2 {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes transformAngel1 {
  0% {
    -webkit-transform: translate(0);
            transform: translate(0);
  }
  100% {
    -webkit-transform: translate(100%, -100%);
            transform: translate(100%, -100%);
  }
}
@keyframes transformAngel1 {
  0% {
    -webkit-transform: translate(0);
            transform: translate(0);
  }
  100% {
    -webkit-transform: translate(100%, -100%);
            transform: translate(100%, -100%);
  }
}
@-webkit-keyframes transformAngel2 {
  0% {
    -webkit-transform: translate(-100%, 100%);
            transform: translate(-100%, 100%);
  }
  100% {
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}
@keyframes transformAngel2 {
  0% {
    -webkit-transform: translate(-100%, 100%);
            transform: translate(-100%, 100%);
  }
  100% {
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}

@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

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

/** -- ▷ header -- */
/*!
component > gnavi
------------------------------
*/
@media screen and (max-width: 767px) {
  #TopicPath ul li {
    font-size: 0.6875rem;
  }
}

.c_mv02 {
  overflow: hidden;
  width: 100%;
  background: url("/recruit/images/img_texture.png"), radial-gradient(50% 229.59% at 50% 50%, #f4f4f4 0%, #f4f4f4 100%);
  padding-bottom: 94px;
  position: relative;
  z-index: 0;
}
.c_mv02::after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 64px;
  left: 0px;
  bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0)), to(#FFFFFF));
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
}
.c_mv02 #TopicPath {
  background: transparent;
}
.c_mv02 #TopicPath ul {
  padding: 19px 21px 22px;
}
@media screen and (min-width: 995px) {
  .c_mv02 #TopicPath ul {
    padding: 19px 0 21px;
  }
}
@media screen and (max-width: 994px) and (min-width: 768px) {
  .c_mv02 #TopicPath ul {
    padding-inline: 21px;
  }
}
@media screen and (min-width: 768px) {
  .c_mv02 #TopicPath ul li:not(.FirstItem) {
    padding: 0 0 0 23px;
    background: url("/image/jp/r1/icon/icon_topic_path_transition_hd.gif") no-repeat 9px center;
    background-size: 6px 6px;
  }
}
.c_mv02 .c_mv02__inner {
  width: calc(100% - 20px);
  margin-left: auto;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .c_mv02 .c_mv02__inner {
    max-width: calc(50% + 640px);
  }
}
.c_mv02 .c_mv02__imgarea {
  margin: 0;
  width: 100%;
  margin-left: auto;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .c_mv02 .c_mv02__imgarea {
    width: 77.5%;
    height: 520px;
    min-width: 717px;
  }
}
.c_mv02 .c_mv02__imgarea img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 16px 0 0 16px;
}
@media screen and (min-width: 768px) {
  .c_mv02 .c_mv02__imgarea img {
    min-width: 1294px;
  }
}
.c_mv02 .c_mv02__contentarea {
  position: absolute;
  bottom: -54px;
  width: 235px;
  left: -20px;
  aspect-ratio: 235/154;
  border-radius: 0 16px 16px 0;
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(20px);
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .c_mv02 .c_mv02__contentarea {
    bottom: -20px;
    width: 388px;
    aspect-ratio: 388/310;
    border-radius: 16px;
    left: unset;
    right: calc(71.3% + clamp(-10.8125rem, 25.782414307vw + -23.2041728763rem, 0rem));
  }
}
.c_mv02 .c_mv02__heading {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
}
.c_mv02 .c_mv02__ttl {
  color: var(--color-black);
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .c_mv02 .c_mv02__ttl {
    font-size: 2.75rem;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.04em;
  }
}
.c_mv02 .c_mv02__sub {
  color: var(--color-red2);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
  padding: 0;
  background: unset;
  margin: 8px 0 0 0;
}
@media screen and (min-width: 768px) {
  .c_mv02 .c_mv02__sub {
    margin: 24px 0 0 0;
  }
}

.c_mv03 {
  overflow: hidden;
  width: 100%;
  background: url("/recruit/images/img_texture.png"), radial-gradient(50% 229.59% at 50% 50%, #f4f4f4 0%, #f4f4f4 100%);
  padding-bottom: 94px;
  position: relative;
  z-index: 0;
}
.c_mv03::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 64px;
  left: 0px;
  bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(244, 244, 244, 0)), to(#F4F4F4));
  background: linear-gradient(180deg, rgba(244, 244, 244, 0) 0%, #F4F4F4 100%);
}
.c_mv03 #TopicPath {
  background: transparent;
}
.c_mv03 #TopicPath ul {
  padding: 19px 21px 22px;
}
@media screen and (min-width: 768px) {
  .c_mv03 #TopicPath ul {
    padding: 19px 0 23px;
  }
}
@media screen and (max-width: 994px) and (min-width: 768px) {
  .c_mv03 #TopicPath ul {
    padding-inline: 21px;
  }
}
@media screen and (min-width: 768px) {
  .c_mv03 #TopicPath ul li:not(.FirstItem) {
    padding: 0 0 0 23px;
    background: url(/image/jp/r1/icon/icon_topic_path_transition_hd.gif) no-repeat 9px center;
    background-size: 6px 6px;
  }
}
.c_mv03 .c_mv03__inner {
  margin-left: auto;
  position: relative;
  z-index: 1;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .c_mv03 .c_mv03__inner {
    width: calc(100% - 20px);
    max-width: calc(50% + 640px);
  }
}
.c_mv03 .c_mv03__imgarea {
  margin: 0;
  width: 100%;
  overflow: hidden;
  padding-left: 20px;
}
@media screen and (min-width: 768px) {
  .c_mv03 .c_mv03__imgarea {
    padding-left: clamp(1.9375rem, 40.625vw + -17.5625rem, 19rem);
    height: 520px;
    min-width: 717px;
  }
}
.c_mv03 .c_mv03__imgarea img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 16px 0 0 16px;
  -o-object-position: top center;
     object-position: top center;
}
.c_mv03 .c_mv03__contentarea {
  position: absolute;
  bottom: -54px;
  width: 235px;
  aspect-ratio: 235/154;
  border-radius: 0 16px 16px 0;
  background-color: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(40px);
  z-index: 2;
  left: 0;
}
@media screen and (min-width: 768px) {
  .c_mv03 .c_mv03__contentarea {
    bottom: -20px;
    width: 388px;
    aspect-ratio: 388/310;
    border-radius: 16px;
  }
}
.c_mv03 .c_mv03__heading {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
}
.c_mv03 .c_mv03__ttl {
  color: var(--color-black);
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .c_mv03 .c_mv03__ttl {
    font-size: 2.75rem;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.04em;
  }
}
.c_mv03 .c_mv03__sub {
  color: var(--color-red2);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
  padding: 0;
  background: unset;
  margin: 8px 0 0 0;
}
@media screen and (min-width: 768px) {
  .c_mv03 .c_mv03__sub {
    margin: 24px 0 0 0;
  }
}

.c_mv04 {
  overflow: hidden;
  width: 100%;
  z-index: 0;
}
.c_mv04 #TopicPath {
  background: transparent;
}
.c_mv04 #TopicPath ul {
  padding: 19px 21px 22px;
}
@media screen and (min-width: 768px) {
  .c_mv04 #TopicPath ul {
    padding: 19px 0 23px;
  }
}
@media screen and (max-width: 994px) and (min-width: 768px) {
  .c_mv04 #TopicPath ul {
    padding-inline: 21px;
  }
}
@media screen and (min-width: 768px) {
  .c_mv04 #TopicPath ul li:not(.FirstItem) {
    padding: 0 0 0 23px;
    background: url(/image/jp/r1/icon/icon_topic_path_transition_hd.gif) no-repeat 9px center;
    background-size: 6px 6px;
  }
}
.c_mv04 .c_mv04__inner {
  margin-left: auto;
  position: relative;
  z-index: 1;
  width: 100%;
}
.c_mv04 .c_mv04__imgarea {
  width: 100%;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .c_mv04 .c_mv04__imgarea {
    height: 640px;
  }
}
.c_mv04 .c_mv04__imgarea img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
}
.c_mv04 .c_mv04__absolutebox {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 22px;
}
@media screen and (min-width: 768px) {
  .c_mv04 .c_mv04__absolutebox {
    bottom: 40px;
  }
}
.c_mv04 .c_mv04__absolutebox .container {
  max-width: 1275px;
  margin-left: 0;
  width: calc(100% - 20px);
}
@media screen and (min-width: 768px) {
  .c_mv04 .c_mv04__absolutebox .container {
    width: calc(100% - 40px);
    margin-left: auto;
    margin-right: auto;
  }
}
.c_mv04 .c_mv04__contentarea {
  border-radius: 0 16px 16px 0;
  z-index: 2;
  left: 0;
  max-width: 620px;
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(10px);
}
@media screen and (min-width: 768px) {
  .c_mv04 .c_mv04__contentarea {
    max-width: -webkit-fit-content;
    max-width: -moz-fit-content;
    max-width: fit-content;
    border-radius: 16px;
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(20px);
  }
}
.c_mv04 .infor {
  padding: 25px 24px 23px 24px;
}
@media screen and (min-width: 768px) {
  .c_mv04 .infor {
    padding: 42px 60px 38px 64px;
  }
}
.c_mv04 .infor_tag {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.04em;
  color: var(--color-red2);
}
.c_mv04 .infor_tag::before {
  height: 26px;
  top: 2px;
}
.c_mv04 .infor_ttl {
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.04em;
  color: var(--color-black);
  margin-top: 7px;
}
@media screen and (min-width: 768px) {
  .c_mv04 .infor_ttl {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.04em;
    margin-top: 16px;
  }
}
.c_mv04 .infor_position {
  font-size: 1.1875rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.04em;
  margin-top: 9px;
}
@media screen and (min-width: 768px) {
  .c_mv04 .infor_position {
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.04em;
    margin-top: 16px;
  }
}
.c_mv04 .infor_other {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: var(--color-black);
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .c_mv04 .infor_other {
    margin-top: 18px;
  }
}
.c_mv04 .infor_other span + span {
  margin-left: 12px;
  position: relative;
}
.c_mv04 .infor_other span + span::before {
  content: "";
  position: absolute;
  top: 4px;
  left: -8px;
  bottom: 0;
  width: 1px;
  background-color: #000;
}

.c_mtitle__en {
  padding: 0;
  background: none;
}
@media screen and (max-width: 767px) {
  .c_mtitle__en {
    margin: 0 0 5px !important;
  }
}
.c_mtitle__jp {
  display: block;
  margin-top: -6px;
}
@media screen and (min-width: 768px) {
  .c_mtitle__jp {
    margin-top: 0;
  }
}

.ttl_line {
  position: relative;
  padding-left: 20px;
}
.ttl_line::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 25px;
  background-color: var(--color-red2);
  left: 0;
  top: 4px;
}
@media screen and (min-width: 768px) {
  .ttl_line::before {
    height: 35px;
  }
}

.h3 {
  font-size: var(--fz-h3);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.5;
  color: var(--color-black);
}

.h5 {
  font-size: var(--fz-h5);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.7;
  color: var(--color-black);
}

.h6 {
  font-size: var(--fz-h6);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.75;
  color: var(--color-gray5);
}

/*!
component > btn
------------------------------
*/
.c_btn {
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
}
.c_btn.c_btn_primary {
  font-size: 1.125rem;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 335px;
  width: 100%;
  background-color: var(--color-gray6);
  border-radius: 9999px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-inline: 50px;
  padding-block: 19px;
  position: relative;
  letter-spacing: 0.04em;
  color: var(--color-white);
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_primary {
    max-width: 320px;
    font-size: 1.375rem;
    padding-block: 25px;
  }
}
.c_btn.c_btn_primary i {
  position: absolute;
  width: 24px;
  aspect-ratio: 1;
  right: 17px;
  translate: 0 -50%;
  top: 50%;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_primary i {
    right: 25px;
  }
}
.c_btn.c_btn_primary i::after {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  background-color: var(--color-white);
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.c_btn.c_btn_primary i::before {
  content: "";
  position: absolute;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  inset: 0;
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  background-color: var(--color-white);
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_primary:hover {
    color: var(--color-white);
    background-color: var(--color-red2);
  }
  .c_btn.c_btn_primary:hover i::after {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .c_btn.c_btn_primary:hover i::before {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    -webkit-animation-delay: var(--transition-fast);
            animation-delay: var(--transition-fast);
  }
}
.c_btn.c_btn_sub {
  font-size: var(--fz-h6);
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 280px;
  width: 100%;
  background-color: var(--color-white);
  border-radius: 9999px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-inline: 50px;
  padding-block: 10px;
  position: relative;
  letter-spacing: 0.04em;
  color: var(--color-red2);
  border: 2px solid var(--color-red2);
  -webkit-transition: background-color 0.4s, color 0.4s;
  transition: background-color 0.4s, color 0.4s;
  line-height: 1.75;
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_sub {
    padding-block: 14px;
    font-size: var(--fz-h5);
    line-height: 1.7;
  }
}
.c_btn.c_btn_sub::after {
  content: "";
  position: absolute;
  width: 24px;
  aspect-ratio: 1;
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  top: 50%;
  right: 15px;
  translate: 0 -50%;
  background-color: var(--color-red2);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_sub::after {
    right: 22px;
  }
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_sub:hover {
    text-decoration: none;
    color: var(--color-white);
    background-color: var(--color-red2);
  }
  .c_btn.c_btn_sub:hover::after {
    background-color: #fff;
  }
}
.c_btn.c_btn_second {
  font-size: var(--fz-h5);
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 320px;
  width: 100%;
  border-radius: 9999px;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: relative;
  letter-spacing: 0.04em;
  color: var(--color-red2);
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  text-decoration: none;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .c_btn.c_btn_second {
    -webkit-column-gap: 12px;
       -moz-column-gap: 12px;
            column-gap: 12px;
  }
}

.c_btn_second__scaled {
  position: relative;
  width: 40px;
  aspect-ratio: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .c_btn_second__scaled {
    width: 48px;
  }
}
.c_btn_second__scaled::before {
  content: "";
  position: absolute;
  border-radius: 50%;
  inset: 0;
  -webkit-transition: background-color 0.4s, scale 0.4s;
  transition: background-color 0.4s, scale 0.4s;
  border: 1px solid var(--color-red2);
}
.c_btn_second__icon {
  overflow: hidden;
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.c_btn_second__icon::before {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 20px 20px;
          mask-size: 20px 20px;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  background-color: var(--color-white);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media screen and (min-width: 768px) {
  .c_btn_second__icon::before {
    -webkit-mask-size: 24px 24px;
            mask-size: 24px 24px;
  }
}
.c_btn_second__icon::after {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 20px 20px;
          mask-size: 20px 20px;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  background-color: var(--color-red2);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media screen and (min-width: 768px) {
  .c_btn_second__icon::after {
    -webkit-mask-size: 24px 24px;
            mask-size: 24px 24px;
  }
}
@media screen and (min-width: 768px) {
  .c_btn_second:hover .c_btn_second__scaled::before {
    background-color: var(--color-red2);
    scale: 1.2;
  }
  .c_btn_second:hover .c_btn_second__icon::after {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .c_btn_second:hover .c_btn_second__icon::before {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    -webkit-animation-delay: var(--transition-fast);
            animation-delay: var(--transition-fast);
  }
}

/*!
component > Other
------------------------------

- loadpage
------------------------------
*/
[data-delay="0.1s"] {
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}

[data-delay="0.2s"] {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

[data-delay="0.3s"] {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}

[data-delay="0.4s"] {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}

[data-delay="0.5s"] {
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

[data-delay="0.6s"] {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}

[data-delay="0.7s"] {
  -webkit-transition-delay: 0.7s;
          transition-delay: 0.7s;
}

[data-delay="0.8s"] {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}

[data-delay="0.9s"] {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}

[data-delay="1s"] {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
}

[data-delay="1.5s"] {
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

.js_inview[data-duration="1s"] {
  -webkit-transition-duration: 1s;
          transition-duration: 1s;
}

.js_inview[data-duration="1.5s"] {
  -webkit-transition-duration: 1.5s;
          transition-duration: 1.5s;
}

.js_inview[data-duration="2s"] {
  -webkit-transition-duration: 2s;
          transition-duration: 2s;
}

.js_inview {
  opacity: 0;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transition-duration: 1s;
          transition-duration: 1s;
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}

.fade {
  opacity: 0;
}

.fadeup {
  -webkit-transform: translate3d(0, 100px, 0);
          transform: translate3d(0, 100px, 0);
}
.fadeup.is_show {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

.fadedown {
  -webkit-transform: translate3d(0, -100px, 0);
          transform: translate3d(0, -100px, 0);
}

.faderight {
  -webkit-transform: translate3d(30px, 0, 0);
          transform: translate3d(30px, 0, 0);
}

.fadeleft {
  -webkit-transform: translate3d(-30px, 0, 0);
          transform: translate3d(-30px, 0, 0);
}

.bounce_in {
  opacity: 0;
  -webkit-animation-duration: 700ms;
          animation-duration: 700ms;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
}
.bounce_in.is_show {
  -webkit-animation-name: bounce_in;
          animation-name: bounce_in;
}
@-webkit-keyframes bounce_in {
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  20% {
    -webkit-transform: scale3d(1.2, 1.2, 1.2);
    transform: scale3d(1.2, 1.2, 1.2);
  }
  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9);
  }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03);
  }
  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97);
  }
  100% {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}
@keyframes bounce_in {
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  20% {
    -webkit-transform: scale3d(1.2, 1.2, 1.2);
    transform: scale3d(1.2, 1.2, 1.2);
  }
  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9);
  }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03);
  }
  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97);
  }
  100% {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

/*!
component > Texts
------------------------------
*/
.cmn_txt {
  font-size: var(--fz-p);
  line-height: 1.8;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--color-black);
}

.txt_sub {
  font-size: 0.875rem;
  line-height: 1.7;
  letter-spacing: 0.04em;
  font-weight: 700;
  color: inherit;
}

.text_center {
  text-align: center;
}

/*!
component > Anchor
------------------------------
*/
.anchor {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  border-radius: 999px;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
@media screen and (min-width: 768px) {
  .anchor {
    background-color: var(--color-white);
    gap: 0;
    width: initial;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    border: 2px solid var(--color-red1-20);
    padding: 20px clamp(1.25rem, 9.1603053435vw + -3.1526717557rem, 2rem);
  }
}
.anchor__child {
  width: 100%;
  max-width: 328px;
  border: 2px solid var(--color-red1-20);
  border-radius: 999px;
}
@media screen and (min-width: 768px) {
  .anchor__child {
    width: auto;
    border: 0;
    padding-left: 13px;
    border-radius: 0;
  }
}
@media screen and (min-width: 768px) {
  .anchor__child:not(:last-child) {
    padding-right: 16px;
    border-right: 1px solid var(--color-gray2);
  }
}
@media screen and (min-width: 768px) {
  .anchor__child:first-child {
    padding-left: 0;
  }
}
.anchor__target.h5 {
  font-size: 1rem;
  color: var(--color-red2);
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2px;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
  position: relative;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-block: 11px;
  padding-inline: 10px;
  padding-top: 9px;
  padding-bottom: 10px;
}
@media screen and (min-width: 768px) {
  .anchor__target.h5 {
    padding: 0;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding-left: 13px;
    font-size: var(--fz-h5);
  }
  .anchor__target.h5:hover::before {
    opacity: 1;
  }
  .anchor__target.h5:hover .txt {
    opacity: 0.8;
  }
  .anchor__target.h5:hover i::before {
    -webkit-animation-name: transformDown2;
            animation-name: transformDown2;
    -webkit-animation-delay: var(--transition-fast);
            animation-delay: var(--transition-fast);
  }
  .anchor__target.h5:hover i::after {
    -webkit-animation-name: transformDown1;
            animation-name: transformDown1;
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
}
.anchor__target.h5::before {
  content: "";
  width: 8px;
  height: 8px;
  background-color: var(--color-red2);
  opacity: 1;
  border-radius: 50%;
  left: 0;
  top: 50%;
  translate: 0 -50%;
  position: absolute;
  opacity: 0;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.anchor__target.h5 .txt {
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.anchor__target.h5 i {
  position: absolute;
  width: 16px;
  aspect-ratio: 1;
  overflow: hidden;
  top: 50%;
  translate: 0 -50%;
  right: 16px;
}
@media screen and (min-width: 768px) {
  .anchor__target.h5 i {
    width: 20px;
    position: relative;
    top: 0;
    right: 0;
    translate: 0;
  }
}
.anchor__target.h5 i::before {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-image: url("../images/common/icon_arrow_bottom.svg");
          mask-image: url("../images/common/icon_arrow_bottom.svg");
  background-color: var(--color-red2);
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.anchor__target.h5 i::after {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-image: url("../images/common/icon_arrow_bottom.svg");
          mask-image: url("../images/common/icon_arrow_bottom.svg");
  background-color: var(--color-red2);
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.table_row2__row:not(:first-child) {
  margin-top: 32px;
}
@media screen and (min-width: 768px) {
  .table_row2__row:not(:first-child) {
    margin-top: 24px;
  }
}
.table_row2__row:not(:last-child) {
  border-bottom: 1px solid var(--color-gray2);
  padding-bottom: 32px;
}
.table_row2__ttl {
  margin-bottom: 17px;
}

.c_box {
  padding: 24px;
  background-color: var(--color-white);
  border-radius: 18px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .c_box {
    padding: 24px 24px 25px;
  }
}
.c_box__ttl {
  position: relative;
  margin-bottom: 8px;
  padding-left: 12px;
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .c_box__ttl {
    font-size: 1.125rem;
    font-weight: 700;
    line-height: 1.7;
    letter-spacing: 0.04em;
  }
}
.c_box__ttl::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 8px;
  height: 8px;
  background-color: var(--color-red1);
  border-radius: 100%;
}
.c_box__txt {
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .c_box__txt {
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.04em;
  }
}
.c_box__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 11px;
}
@media screen and (min-width: 768px) {
  .c_box__flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 20px;
  }
}
.c_box__img {
  width: 134px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.c_box__img img {
  width: 100%;
}
.c_box__content {
  width: 100%;
}
.c_box__bottom {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--color-gray2);
}
@media screen and (min-width: 768px) {
  .c_box__bottom {
    margin-top: 16px;
    padding-top: 19px;
  }
}
.c_box__sub {
  margin-bottom: 5px;
  color: var(--color-gray5);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .c_box__sub {
    margin-bottom: 5px;
    font-weight: 700;
  }
}
.c_box__note {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
}

.accordion {
  border-bottom: 1px solid var(--color-gray2);
  padding-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .accordion {
    padding-bottom: 32px;
  }
}
.accordion.opened .accordion__toggle_icon::before {
  -webkit-transform: translate(-50%, -50%) rotate(180deg);
          transform: translate(-50%, -50%) rotate(180deg);
}
.accordion.opened .accordion__toggle_icon::after {
  -webkit-transform: translate(-50%, -50%) rotate(180deg);
          transform: translate(-50%, -50%) rotate(180deg);
}
.accordion__head {
  padding: 20px 0 8px;
}
@media screen and (min-width: 768px) {
  .accordion__head {
    padding: 32px 24px 8px;
  }
  .accordion__head:hover {
    cursor: pointer;
  }
  .accordion__head:hover .accordion__ttl {
    color: var(--color-red2);
  }
}
.accordion__ttl {
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
.accordion__head_in {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 10px;
  padding-left: 42px;
}
@media screen and (min-width: 768px) {
  .accordion__head_in {
    padding-left: 42px;
  }
}
.accordion__head_in::before {
  content: "";
  position: absolute;
  width: 30px;
  height: 28px;
  top: 0;
  left: 0;
  background-image: url("../images/text_Q.svg");
}
.accordion__toggle_icon {
  position: relative;
  width: 24px;
  height: 24px;
  margin-top: 4px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.accordion__toggle_icon::after, .accordion__toggle_icon::before {
  content: "";
  position: absolute;
  width: 16px;
  height: 2px;
  background-color: var(--color-red1);
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
}
.accordion__toggle_icon::after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
.accordion__body {
  display: none;
}
@media screen and (min-width: 768px) {
  .accordion__body {
    padding-inline: 24px;
  }
}
.accordion__body > * {
  position: relative;
  padding-left: 42px;
  cursor: text;
}
.accordion__body > *::before {
  content: "";
  position: absolute;
  width: 30px;
  height: 28px;
  top: 0;
  left: 0;
  background-image: url("../images/text_A.svg");
}

.interview__bg {
  background-color: var(--color-gray1);
}
.interview__inner {
  max-width: 1275px;
  width: calc(100% - 40px);
  margin-left: auto;
  margin-right: auto;
  display: -ms-grid;
  display: grid;
  gap: 32px;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  padding-block: 48px;
}
@media screen and (min-width: 768px) {
  .interview__inner {
    padding-block: 100px;
  }
}
@media screen and (min-width: 1440px) {
  .interview__inner {
    -ms-grid-columns: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.interview a.interview__card {
  text-decoration: none;
}
.interview__card {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  aspect-ratio: 335/200;
  padding: 20px;
  border-radius: 16px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .interview__card {
    aspect-ratio: initial;
    height: 300px;
    padding: 40px;
  }
}
.interview__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.64);
  backdrop-filter: blur(8px);
  z-index: 1;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
@media screen and (min-width: 768px) {
  .interview__card:hover::before {
    opacity: 1;
  }
  .interview__card:hover .interview__thumb img {
    scale: 1.1;
  }
  .interview__card:hover .interview__card_body {
    color: var(--color-black);
  }
  .interview__card:hover .interview__card_content .h3 {
    color: var(--color-black);
  }
  .interview__card:hover .interview__card_icon::before {
    background-color: var(--color-red2);
    scale: 1.1;
  }
  .interview__card:hover .interview__card_icon i::after {
    -webkit-animation-name: transformRightLeft;
            animation-name: transformRightLeft;
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .interview__card:hover .interview__card_icon i::before {
    -webkit-animation-name: transformLeftRight;
            animation-name: transformLeftRight;
    -webkit-animation-delay: var(--transition-fast);
            animation-delay: var(--transition-fast);
  }
}
.interview__card_body {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  color: var(--color-white);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 2;
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
}
.interview__card_body.has_sub_txt {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.interview__card_body.has_sub_txt .h3 {
  margin-bottom: 5px;
}
.interview__card_content {
  max-width: 214px;
}
@media screen and (min-width: 768px) {
  .interview__card_content {
    max-width: 234px;
  }
}
.interview__card_content .h3 {
  -webkit-transition: color 0.4s;
  transition: color 0.4s;
  color: var(--color-white);
}
.interview__card_icon {
  width: 48px;
  aspect-ratio: 1;
  border-radius: 50%;
  position: relative;
  z-index: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.interview__card_icon::before {
  content: "";
  border-radius: 50%;
  position: absolute;
  inset: 0;
  background-color: var(--color-white);
  -webkit-transition: background-color 0.4s, scale 0.4s;
  transition: background-color 0.4s, scale 0.4s;
  z-index: -1;
}
.interview__card_icon i {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.interview__card_icon i::before {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 20px 20px;
          mask-size: 20px 20px;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  background-color: var(--color-white);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media screen and (min-width: 768px) {
  .interview__card_icon i::before {
    -webkit-mask-size: 24px 24px;
            mask-size: 24px 24px;
  }
}
.interview__card_icon i::after {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-image: url("../images/common/icon_arrow_right.svg");
          mask-image: url("../images/common/icon_arrow_right.svg");
  -webkit-mask-size: 20px 20px;
          mask-size: 20px 20px;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  background-color: var(--color-red2);
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media screen and (min-width: 768px) {
  .interview__card_icon i::after {
    -webkit-mask-size: 24px 24px;
            mask-size: 24px 24px;
  }
}
@media screen and (min-width: 1315px) {
  .interview__card.wide {
    -ms-grid-column-span: 3;
    grid-column: span 3;
  }
}
.interview__thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.interview__thumb img {
  border-radius: 16px;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: scale 0.4s;
  transition: scale 0.4s;
}

.timeline__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 16px;
}
.timeline__item:not(:last-child) {
  padding-bottom: 15px;
  border-bottom: 1px solid var(--color-gray2);
}
@media screen and (min-width: 768px) {
  .timeline__item:not(:last-child) {
    padding-bottom: 21px;
  }
}
.timeline__item:not(:first-child) {
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .timeline__item:not(:first-child) {
    margin-top: 18px;
  }
}
.timeline__date {
  color: var(--color-red2);
  width: 52px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.timeline__content {
  color: var(--color-black);
}

.footer_cta {
  background-color: var(--color-gray1);
  padding-bottom: 65px;
  position: relative;
  z-index: 5;
}
.footer_cta__head {
  height: 320px;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .footer_cta__head {
    height: 480px;
  }
}
.footer_cta__parallax {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footer_cta__parallax {
    display: block;
  }
}
.footer_cta__parallax img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
}
.footer_cta__body {
  margin-left: auto;
  margin-right: auto;
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(10px);
  border-radius: 16px;
  padding-block: 64px;
  margin-top: -101px;
}
@media screen and (min-width: 768px) {
  .footer_cta__body {
    max-width: 1275px;
    width: calc(100% - 40px);
    margin-top: -102px;
    padding-inline: 32px;
  }
}
@media screen and (min-width: 768px) {
  .footer_cta__body.body_margin02 {
    margin-top: -197px;
  }
}
.footer_cta__title {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  text-align: center;
  margin-inline: 0 !important;
}
@media screen and (min-width: 768px) {
  .footer_cta__title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.04em;
  }
}
.footer_cta__title span {
  font-size: inherit;
  display: inline-block;
  background: transparent;
  padding: 0;
}
.footer_cta__catch {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.04em;
  text-align: center;
  padding-inline: 20px;
  margin-top: 13px;
}
@media screen and (min-width: 768px) {
  .footer_cta__catch {
    font-size: 1.125rem;
    font-weight: 700;
    line-height: 1.7;
    letter-spacing: 0.04em;
    padding-inline: 0;
    margin-top: 13px;
  }
}
.footer_cta__btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 24px;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-inline: 20px;
  margin-top: 41px;
}
@media screen and (min-width: 768px) {
  .footer_cta__btns {
    padding-inline: 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-top: 40px;
    gap: 32px;
  }
}
.footer_cta__btn {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: var(--color-red2);
  height: 88px;
  font-weight: 700;
  padding-left: clamp(1.125rem, 1.25vw + 0rem, 1.5rem);
  padding-right: clamp(1rem, 1.1104166667vw + 0.000625rem, 1.333125rem);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 6px;
  border-radius: 999px;
  -webkit-transition: background-color 0.4s;
  transition: background-color 0.4s;
  outline: none;
  border: none;
  cursor: pointer;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footer_cta__btn {
    font-size: 1.625rem;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.04em;
    width: 464px;
    height: clamp(5rem, 5.9523809524vw + 2.1428571429rem, 7.5rem);
  }
  .footer_cta__btn:hover {
    background-color: var(--color-red1-40);
  }
  .footer_cta__btn:hover i::before {
    scale: 1.2;
  }
}
.footer_cta__btn i {
  position: absolute;
  width: 24px;
  aspect-ratio: 1;
  top: 50%;
  translate: 0 -50%;
  right: 28px;
}
@media screen and (min-width: 768px) {
  .footer_cta__btn i {
    width: 32px;
    right: clamp(1.5rem, 3.5714285714vw + -0.2142857143rem, 3rem);
  }
}
.footer_cta__btn i::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--color-white);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-transition: scale 0.4s;
  transition: scale 0.4s;
}
.footer_cta__btn.entry {
  color: var(--color-white);
  text-decoration: none;
}
.footer_cta__btn.entry i {
  overflow: hidden;
}
.footer_cta__btn.entry i::before {
  -webkit-mask-image: url("../images/common/icon_arrow_angle.svg");
          mask-image: url("../images/common/icon_arrow_angle.svg");
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.footer_cta__btn.entry i::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--color-white);
  -webkit-transform: translate(-100%, 100%);
          transform: translate(-100%, 100%);
  -webkit-transition: scale 0.4s;
  transition: scale 0.4s;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-animation-duration: 0.4s;
          animation-duration: 0.4s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-mask-image: url("../images/common/icon_arrow_angle.svg");
          mask-image: url("../images/common/icon_arrow_angle.svg");
}
@media screen and (min-width: 768px) {
  .footer_cta__btn.entry:hover i::before {
    scale: 1.2;
    -webkit-animation-name: transformAngel1;
            animation-name: transformAngel1;
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .footer_cta__btn.entry:hover i::after {
    scale: 1.2;
    -webkit-animation-name: transformAngel2;
            animation-name: transformAngel2;
    -webkit-animation-delay: 0.4s;
            animation-delay: 0.4s;
  }
}
.footer_cta__btn.career {
  color: var(--color-white);
}
.footer_cta__btn.career i::before {
  -webkit-mask-image: url("../images/common/icon_mail.svg");
          mask-image: url("../images/common/icon_mail.svg");
}

.dialog {
  position: fixed;
  z-index: 90;
  inset: 0;
  background: rgba(217, 217, 217, 0.7);
  backdrop-filter: blur(20px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 17px 20px 20px;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.15s linear, visibility 0.15s linear;
  transition: opacity 0.15s linear, visibility 0.15s linear;
}
@media screen and (min-width: 768px) {
  .dialog {
    padding: 20px;
  }
}
.dialog.opened {
  opacity: 1;
  visibility: visible;
}
.dialog__main {
  background-color: var(--color-white);
  border-radius: 16px;
}
.dialog__content {
  position: relative;
  padding-inline: 32px;
  padding-top: 40px;
  padding-bottom: 32px;
}
@media screen and (min-width: 768px) {
  .dialog__content {
    padding-top: 48px;
    padding-inline: 47px;
    padding-bottom: 40px;
  }
}
.dialog__close {
  position: absolute;
  width: 32px;
  aspect-ratio: 1;
  -webkit-mask-image: url("../images/common/icon_close.svg");
          mask-image: url("../images/common/icon_close.svg");
  -webkit-mask-size: 100%;
          mask-size: 100%;
  background-color: var(--color-red2);
  top: 16px;
  right: 16px;
  cursor: pointer;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
@media screen and (min-width: 768px) {
  .dialog__close:hover {
    opacity: 0.8;
  }
}
.dialog__ttl {
  font-size: 1.1875rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.04em;
  padding: 0;
  background: none;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .dialog__ttl {
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.04em;
  }
}
.dialog__txt {
  text-align: center;
  font-size: 0.9375rem;
  line-height: 1.8;
  font-weight: 400;
  letter-spacing: 0.04em;
  margin-top: 25px;
}
@media screen and (min-width: 768px) {
  .dialog__txt {
    margin-top: 31px;
    font-size: var(--fz-p);
  }
}
.dialog__txt .mail {
  color: var(--color-red2);
}
.dialog .close-btn {
  width: 124px;
  height: 38px;
  background-color: transparent;
  border: 2px solid var(--color-red2);
  border-radius: 999px;
  margin-left: auto;
  margin-right: auto;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-red2);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  cursor: pointer;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
  margin-top: 26px;
  padding-left: 18px;
}
@media screen and (min-width: 768px) {
  .dialog .close-btn {
    width: 130px;
    height: 42px;
    margin-top: 40px;
    padding-left: 20px;
    font-size: 1rem;
  }
  .dialog .close-btn:hover {
    opacity: 0.8;
  }
}
.dialog .close-btn i {
  display: block;
  width: 20px;
  aspect-ratio: 1;
  -webkit-mask-image: url("../images/common/icon_close.svg");
          mask-image: url("../images/common/icon_close.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  background-color: var(--color-red2);
}

.marquee {
  overflow: hidden;
  width: 100%;
}
.marquee__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.marquee__content img {
  width: 1242px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-right: 30px;
}
@media screen and (min-width: 768px) {
  .marquee__content img {
    width: max(clamp(1182.34px, 153.7496274218vw + 0.0053651267px, 2214px), 153.75vw + 0px);
  }
}
.marquee__content.is-set img {
  -webkit-animation: loop-horizontal var(--animation-duration-horizontal) linear infinite;
          animation: loop-horizontal var(--animation-duration-horizontal) linear infinite;
}
@-webkit-keyframes loop-horizontal {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(-100%, 0, 0);
            transform: translate3d(-100%, 0, 0);
  }
}
@keyframes loop-horizontal {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(-100%, 0, 0);
            transform: translate3d(-100%, 0, 0);
  }
}

/*!
layout > container
------------------------------
*/
.container {
  max-width: var(--content-max-width);
  width: calc(100% - 40px);
  margin-left: auto;
  margin-right: auto;
}