@charset "UTF-8";
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #000;
  background: #fff;
  line-height: 1.8;
  overflow-x: hidden;
}

a {
  text-decoration: none;
  color: inherit;
}

ul {
  list-style: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

[data-aos=fade] {
  opacity: 0;
}

:root {
  --gradient: linear-gradient(to right, #5a5a9f, #c54f8f);
  --purple: #5a5a9f;
  --pink: #c54f8f;
  --dark: #3c3c50;
  --font-en: Lexend, sans-serif;
  --font-jp: Zen Kaku Gothic New, sans-serif;
  --max-width: 1206px;
  --section-width: 1432px;
}

br.only-sp {
  display: none;
}
@media (max-width: 768px) {
  br.only-sp {
    display: inline;
  }
}

br.only-pc {
  display: inline;
}
@media (max-width: 768px) {
  br.only-pc {
    display: none;
  }
}

.ly_content-wrapper {
  position: relative;
  z-index: 1;
}

.ly_bg-white {
  background-color: #fff;
}

.ly_bg-gradient {
  background: linear-gradient(to bottom, rgba(90, 90, 159, 0) 0%, rgba(90, 90, 159, 0.14) var(--middle-position, 40%), rgba(90, 90, 159, 0) 100%);
}

main {
  position: relative;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: #fff;
  border-bottom: min(0.1322751323vw, 2px) solid rgba(90, 90, 159, 0.15);
  height: min(6.6137566138vw, 100px);
  display: flex;
  align-items: center;
}
.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1512px;
  margin: 0 auto;
  padding: 0 min(2.6455026455vw, 40px);
}
.header__logo img {
  width: min(10.119047619vw, 153px);
  height: min(3.0423280423vw, 46px);
  object-fit: contain;
}
.header__nav {
  display: flex;
  align-items: center;
  gap: min(2.6455026455vw, 40px);
}
.header__nav-list {
  display: flex;
  gap: min(2.6455026455vw, 40px);
  align-items: center;
}
.header__nav-list > li {
  position: relative;
}
.header__nav-list a {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  text-transform: uppercase;
  transition: opacity 0.3s;
}
.header__nav-list a:hover {
  opacity: 0.7;
}
.header__dropdown-trigger > span {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  text-transform: uppercase;
  cursor: default;
  transition: opacity 0.3s;
}
.header__dropdown-trigger:hover > span {
  opacity: 0.7;
}
.header__dropdown-trigger:hover .header__dropdown {
  opacity: 1;
  visibility: visible;
  left: 50%;
  transform: translateX(-50%) translateY(0);
}
.header__dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(min(0.5291005291vw, 8px));
  min-width: min(14.5502645503vw, 220px);
  background: #fff;
  border-radius: min(0.7936507937vw, 12px);
  box-shadow: 0 min(0.5291005291vw, 8px) min(2.1164021164vw, 32px) rgba(0, 0, 0, 0.12);
  padding: min(0.7936507937vw, 12px) 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s, transform 0.25s;
  z-index: 10;
}
.header__dropdown::before {
  content: "";
  position: absolute;
  top: min(-1.0582010582vw, -16px);
  left: 0;
  right: 0;
  height: min(1.0582010582vw, 16px);
}
.header__dropdown li a {
  display: block;
  padding: min(0.6613756614vw, 10px) min(1.3227513228vw, 20px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-size: min(0.9259259259vw, 14px);
  color: #3c3c50;
  white-space: nowrap;
  transition: background 0.2s;
}
.header__dropdown li a:hover {
  background: rgba(90, 90, 159, 0.06);
  opacity: 1;
}
.header__entry-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: min(11.9047619048vw, 180px);
  height: min(3.3068783069vw, 50px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  border-radius: min(6.6137566138vw, 100px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: min(0.1058201058vw, 1.6px);
  transition: all 0.35s ease-in-out;
  z-index: 0;
}
.header__entry-btn > span {
  position: relative;
  z-index: 1;
}
.header__entry-btn > span::after {
  content: "ENTRY";
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
.header__entry-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: min(6.6137566138vw, 100px);
  background: #fff;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
  z-index: 0;
  pointer-events: none;
}
.header__entry-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: min(6.6137566138vw, 100px);
  padding: min(0.1322751323vw, 2px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
  z-index: 0;
  pointer-events: none;
}
@media (hover: hover) {
  .header__entry-btn:hover::before {
    opacity: 1;
  }
  .header__entry-btn:hover::after {
    opacity: 1;
  }
  .header__entry-btn:hover > span::after {
    opacity: 1;
  }
}
.header__hamburger {
  display: none;
  flex-direction: column;
  gap: min(0.3968253968vw, 6px);
  background: none;
  border: none;
  cursor: pointer;
  padding: min(0.6613756614vw, 10px);
}
.header__hamburger span {
  display: block;
  width: min(1.8518518519vw, 28px);
  height: min(0.1984126984vw, 3px);
  background: #3c3c50;
  border-radius: min(0.1322751323vw, 2px);
  transition: transform 0.3s, opacity 0.3s;
}
.header__hamburger.is-active span:nth-child(1) {
  transform: translateY(min(0.5952380952vw, 9px)) rotate(45deg);
}
.header__hamburger.is-active span:nth-child(2) {
  opacity: 0;
}
.header__hamburger.is-active span:nth-child(3) {
  transform: translateY(min(-0.5952380952vw, -9px)) rotate(-45deg);
}
.header--scrolled {
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.08);
}
@media (max-width: 768px) {
  .header {
    height: 16vw;
  }
  .header__inner {
    padding: 0 4.2666666667vw;
  }
  .header__logo img {
    width: 26.6666666667vw;
    height: 8vw;
  }
  .header__nav {
    display: none;
  }
  .header__hamburger {
    display: flex;
    gap: 1.3333333333vw;
    padding: 2.6666666667vw;
  }
  .header__hamburger span {
    width: 6.4vw;
    height: 0.5333333333vw;
    border-radius: 0.2666666667vw;
  }
  .header__hamburger.is-active span:nth-child(1) {
    transform: translateY(1.8666666667vw) rotate(45deg);
  }
  .header__hamburger.is-active span:nth-child(3) {
    transform: translateY(-1.8666666667vw) rotate(-45deg);
  }
}

.mobile-menu {
  display: none;
  position: fixed;
  top: 16vw;
  left: 0;
  right: 0;
  bottom: 0;
  background: #fff;
  z-index: 99;
  flex-direction: column;
  align-items: center;
  justify-content: start;
  gap: 40px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  overflow-y: auto;
  padding-block: 5.3333333333vw;
}
.mobile-menu.is-open {
  opacity: 1;
  pointer-events: auto;
}
.mobile-menu__list {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 32px;
}
.mobile-menu__list li {
  width: 100%;
}
.mobile-menu__list > li > a,
.mobile-menu__list > li > span {
  display: inline-block;
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: 24px;
  text-transform: uppercase;
  width: 100%;
}
.mobile-menu__list > li > span {
  cursor: default;
}
.mobile-menu__sublist {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 12px;
  margin-top: 12px;
}
.mobile-menu__sublist a {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #3c3c50;
  opacity: 0.75;
  transition: opacity 0.2s;
}
.mobile-menu__sublist a:hover {
  opacity: 1;
}
.mobile-menu__entry-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 240px;
  height: 56px;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  border-radius: 100px;
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 1.6px;
}
@media (max-width: 768px) {
  .mobile-menu {
    display: flex;
    top: 16vw;
    gap: 8.5333333333vw;
  }
  .mobile-menu__list {
    gap: 6.4vw;
  }
  .mobile-menu__list > li > a,
  .mobile-menu__list > li > span {
    font-size: 5.3333333333vw;
  }
  .mobile-menu__sublist {
    gap: 2.1333333333vw;
    margin-top: 2.1333333333vw;
  }
  .mobile-menu__sublist a {
    font-size: 3.7333333333vw;
  }
  .mobile-menu__entry-btn {
    width: 53.3333333333vw;
    height: 12.8vw;
    font-size: 4.2666666667vw;
  }
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: min(1.3227513228vw, 20px);
  width: fit-content;
  height: min(3.9682539683vw, 60px);
  padding: min(0.3968253968vw, 6px) min(0.6613756614vw, 10px) min(0.3968253968vw, 6px) min(1.9841269841vw, 30px);
  border-radius: 100px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  letter-spacing: min(0.1058201058vw, 1.6px);
  position: relative;
  transition: all 0.35s ease-in-out;
}
@media (max-width: 768px) {
  .btn {
    height: 12.8vw;
    padding: 1.3333333333vw 2.1333333333vw 1.3333333333vw 5.3333333333vw;
    font-size: 3.7333333333vw;
    gap: 3.2vw;
    letter-spacing: 0.2666666667vw;
  }
}
.btn > * {
  position: relative;
  z-index: 1;
}
.btn__en {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
}
.btn__arrow {
  width: min(2.6455026455vw, 40px);
  height: min(2.6455026455vw, 40px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  transition: all 0.35s ease-in-out;
}
@media (max-width: 768px) {
  .btn__arrow {
    width: 8.5333333333vw;
    height: 8.5333333333vw;
  }
}
.btn__arrow svg {
  position: relative;
  z-index: 1;
  transition: all 0.35s ease-in-out;
  width: min(1.1904761905vw, 18px);
  height: min(1.1904761905vw, 18px);
}

@media (max-width: 768px) {
  .btn__arrow svg {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
}
.btn__arrow--gradient {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  transition: all 0.35s ease-in-out;
}
.btn__arrow--gradient::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  transition: all 0.35s ease-in-out;
}
.btn__arrow--white {
  background: #fff;
  color: #5a5a9f;
  transition: all 0.35s ease-in-out;
}
.btn__arrow--white::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  opacity: 0;
  transition: all 0.35s ease-in-out;
}
.btn--outline {
  box-sizing: border-box;
  background: transparent;
  color: #000;
  transition: all 0.35s ease-in-out;
}
.btn--outline::after {
  transition: all 0.35s ease-in-out;
}
.btn--outline::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 100px;
  padding: min(0.1984126984vw, 3px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  box-sizing: border-box;
  -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  mask-composite: exclude;
  z-index: 0;
  pointer-events: none;
  transition: all 0.35s ease-in-out;
}
@media (max-width: 768px) {
  .btn--outline::after {
    padding: 0.8vw;
  }
}
.btn--outline::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 100px;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  opacity: 0;
  transition: all 0.35s ease-in-out;
  z-index: 0;
  pointer-events: none;
}
@media (hover: hover) {
  .btn--outline:hover {
    color: #fff;
  }
  .btn--outline:hover::before {
    opacity: 1;
  }
  .btn--outline:hover .btn__arrow--gradient {
    color: #5a5a9f;
  }
  .btn--outline:hover .btn__arrow--gradient::before {
    opacity: 1;
  }
}
.btn--white-outline {
  box-sizing: border-box;
  border: min(0.1984126984vw, 3px) solid #fff;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  transition: all 0.35s ease-in-out;
}
.btn--white-outline::before {
  transition: all 0.35s ease-in-out;
}
@media (max-width: 768px) {
  .btn--white-outline {
    border-width: 0.8vw;
  }
}
.btn--white-outline::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: min(6.6137566138vw, 100px);
  background: #fff;
  opacity: 0;
  transition: all 0.35s ease-in-out;
  z-index: 0;
  pointer-events: none;
}
@media (max-width: 768px) {
  .btn--white-outline::before {
    border-radius: 26.6666666667vw;
  }
}
@media (hover: hover) {
  .btn--white-outline:hover {
    color: #000;
  }
  .btn--white-outline:hover::before {
    opacity: 1;
  }
  .btn--white-outline:hover .btn__arrow--white {
    color: #fff;
  }
  .btn--white-outline:hover .btn__arrow--white::before {
    opacity: 1;
  }
}

.label {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: min(0.3968253968vw, 6px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .label {
    font-size: 4.8vw;
  }
}
.label {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
}
.label--on-gradient {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: min(0.3968253968vw, 6px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .label--on-gradient {
    font-size: 4.8vw;
  }
}
.label--on-gradient {
  background: #fff;
}
.label--on-gradient span {
  background-image: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
@media (max-width: 768px) {
  .label {
    padding: 1.0666666667vw;
    font-size: 3.7333333333vw;
  }
}

.section-heading {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
}
.section-heading__title {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
  font-size: min(5.5555555556vw, 84px);
  line-height: 1.16;
  letter-spacing: -0.04em;
  width: fit-content;
}
.section-heading__title-en {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
}
.section-heading--on-gradient .section-heading__title {
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  -webkit-text-fill-color: #fff;
  color: #fff;
  font-weight: 700;
  font-size: min(5.5555555556vw, 84px);
  line-height: 1.16;
  letter-spacing: -0.04em;
}
@media (max-width: 768px) {
  .section-heading {
    gap: 5.3333333333vw;
  }
  .section-heading__title {
    font-size: 9.6vw;
  }
  .section-heading--on-gradient .section-heading__title {
    font-size: 9.6vw;
  }
}

.footer-wrapper {
  padding-top: min(26.1243386243vw, 395px);
  position: relative;
  z-index: 1;
}

.footer {
  background: #3c3c50;
  border-radius: min(2.6455026455vw, 40px) min(2.6455026455vw, 40px) 0 0;
  padding-top: 0;
  position: relative;
  padding-inline: min(2.6455026455vw, 40px);
}
.footer__entry {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  max-width: 898px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  border-radius: min(0.7936507937vw, 12px);
  padding: min(2.6455026455vw, 40px) min(5.291005291vw, 80px) min(3.3068783069vw, 50px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(1.3227513228vw, 20px);
  overflow: hidden;
}
.footer__entry::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
  z-index: 0;
}
.footer__entry::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: min(0.1984126984vw, 3px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
  z-index: 1;
}
@media (hover: hover) {
  .footer__entry:hover::before {
    opacity: 1;
  }
  .footer__entry:hover::after {
    opacity: 1;
  }
  .footer__entry:hover .footer__entry-title {
    background: linear-gradient(to right, #5a5a9f, #c54f8f);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
}
.footer__entry-title {
  font-weight: 700;
  font-size: min(2.3148148148vw, 35px);
  color: #fff;
  position: relative;
  z-index: 1;
}
.footer__entry-mynavi {
  display: block;
  width: 100%;
  position: relative;
  z-index: 1;
}
.footer__entry-mynavi img {
  width: 100%;
  height: auto;
}
.footer__inner {
  max-width: 898px;
  margin: 0 auto;
  padding: 196px 0 min(1.3227513228vw, 20px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(5.291005291vw, 80px);
}
.footer__links {
  display: flex;
  gap: min(2.6455026455vw, 40px);
  width: 100%;
}
.footer__link-card {
  flex: 1;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  border: min(0.1322751323vw, 2px) solid #5a5a9f;
  border-radius: min(0.6613756614vw, 10px);
  padding: min(1.3227513228vw, 20px) min(1.9841269841vw, 30px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: min(10.119047619vw, 153px);
  position: relative;
  overflow: hidden;
  transition: border-color 0.35s ease-in-out;
}
.footer__link-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff;
  border-radius: inherit;
  opacity: 1;
  transition: opacity 0.35s ease-in-out;
  z-index: 0;
}
@media (hover: hover) {
  .footer__link-card:hover::before {
    opacity: 0;
  }
  .footer__link-card:hover {
    border-color: #fff;
  }
  .footer__link-card:hover .footer__link-card-title {
    background: none;
    -webkit-background-clip: unset;
    -webkit-text-fill-color: #fff;
    background-clip: unset;
  }
  .footer__link-card:hover .footer__link-card-label {
    background: #fff;
  }
  .footer__link-card:hover .footer__link-card-label span {
    background: linear-gradient(to right, #5a5a9f, #c54f8f);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
  .footer__link-card:hover .footer__link-card-arrow {
    color: #5a5a9f;
  }
  .footer__link-card:hover .footer__link-card-arrow::before {
    opacity: 1;
  }
}
.footer__link-card-text {
  display: flex;
  flex-direction: column;
  gap: min(0.2645502646vw, 4px);
  position: relative;
  z-index: 1;
}
.footer__link-card-label {
  display: inline-block;
  padding: 0 min(0.2645502646vw, 4px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(0.9259259259vw, 14px);
  text-transform: uppercase;
  align-self: flex-start;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  transition: background 0.35s ease-in-out;
}
.footer__link-card-label span {
  color: #fff;
  transition: all 0.35s ease-in-out;
}
.footer__link-card-title {
  font-weight: 700;
  font-size: min(2.7777777778vw, 42px);
  letter-spacing: -7%;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: all 0.35s ease-in-out;
}
.footer__link-card-arrow {
  width: min(3.3068783069vw, 50px);
  height: min(3.3068783069vw, 50px);
  border-radius: 50%;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  border: min(0.1322751323vw, 2px) solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
  position: relative;
  z-index: 1;
  transition: all 0.35s ease-in-out;
}
.footer__link-card-arrow::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
.footer__link-card-arrow::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  padding: min(0.1322751323vw, 2px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
.footer__link-card-arrow svg {
  width: min(1.1904761905vw, 18px);
  height: min(1.1904761905vw, 18px);
  position: relative;
  z-index: 1;
  transition: color 0.35s ease-in-out;
}
.footer__copyright {
  font-family: "Lexend", sans-serif;
  font-weight: 400;
  font-size: min(1.0582010582vw, 16px);
  color: #fff;
}

@media (max-width: 768px) {
  .footer-wrapper {
    padding-top: 53.3333333333vw;
  }
  .footer {
    border-radius: 5.3333333333vw 5.3333333333vw 0 0;
    padding-inline: 4.2666666667vw;
  }
  .footer__entry {
    width: calc(100% - 8.5333333333vw);
    padding: 6.4vw 5.3333333333vw 8vw;
    border-radius: 2.6666666667vw;
    gap: 3.2vw;
  }
  .footer__entry-title {
    font-size: 5.3333333333vw;
  }
  .footer__inner {
    padding: 34.6666666667vw 0 4.2666666667vw;
    gap: 10.6666666667vw;
  }
  .footer__links {
    flex-direction: column;
    gap: 4.2666666667vw;
  }
  .footer__link-card {
    border-radius: 2.1333333333vw;
    padding: 4.2666666667vw 5.3333333333vw;
    min-height: 21.3333333333vw;
  }
  .footer__link-card-label {
    font-size: 2.9333333333vw;
    padding: 0 0.8vw;
  }
  .footer__link-card-title {
    font-size: 7.4666666667vw;
  }
  .footer__link-card-arrow {
    width: 9.6vw;
    height: 9.6vw;
  }
  .footer__link-card-arrow img,
  .footer__link-card-arrow svg {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
  .footer__copyright {
    font-size: 2.9333333333vw;
  }
}
.fixed-works-link {
  position: fixed;
  bottom: min(3.6375661376vw, 55px);
  right: min(2.6455026455vw, 40px);
  z-index: 4;
  width: min(9.9206349206vw, 150px);
  height: min(9.9206349206vw, 150px);
  border-radius: 50%;
  border: min(0.2645502646vw, 4px) solid transparent;
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(to right, #5a5a9f, #c54f8f) border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: min(0.2645502646vw, 4px);
  padding-top: min(0.7936507937vw, 12px);
  transition: all 0.35s ease-in-out;
  overflow: hidden;
}
.fixed-works-link::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
  z-index: 0;
  pointer-events: none;
}
.fixed-works-link > * {
  position: relative;
  z-index: 1;
}
@media (hover: hover) {
  .fixed-works-link:hover {
    border-color: #fff;
    color: #fff;
  }
  .fixed-works-link:hover::before {
    opacity: 1;
  }
  .fixed-works-link:hover .fixed-works-link__text::after {
    opacity: 1;
  }
  .fixed-works-link:hover .fixed-works-link__arrow::after {
    opacity: 1;
  }
}
.fixed-works-link__text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.1904761905vw, 18px);
  line-height: 1.33;
  text-align: center;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}
.fixed-works-link__text::after {
  content: "TOWの仕事を\aもっと見る";
  white-space: pre-line;
  position: absolute;
  inset: 0;
  color: #fff;
  -webkit-text-fill-color: #fff;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
.fixed-works-link__arrow {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-mask-image: url("../../../images/src/2027_renewal/arrow-right-gradient.svg");
  mask-image: url("../../../images/src/2027_renewal/arrow-right-gradient.svg");
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-size: contain;
  mask-repeat: no-repeat;
  width: min(1.1904761905vw, 18px);
  height: min(1.1904761905vw, 18px);
  position: relative;
}
.fixed-works-link__arrow::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
@media (max-width: 768px) {
  .fixed-works-link {
    width: 26.6666666667vw;
    height: 26.6666666667vw;
    bottom: 4.2666666667vw;
    right: 4.2666666667vw;
    gap: 0.5333333333vw;
    padding-top: 2.1333333333vw;
    border-width: 0.8vw;
  }
  .fixed-works-link__text {
    font-size: 3.2vw;
  }
  .fixed-works-link__arrow {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
}

.page-fv {
  width: 100%;
  padding-top: min(14.5502645503vw, 220px);
  padding-bottom: min(11.9047619048vw, 180px);
  display: flex;
  align-items: start;
  justify-content: center;
}
.page-fv__inner {
  width: calc(100% - min(5.291005291vw, 80px));
  max-width: 1206px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
}
.page-fv__title-group {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding-bottom: min(1.3227513228vw, 20px);
}
.page-fv__label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 min(0.5952380952vw, 9px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  margin-bottom: min(1.3227513228vw, 20px);
  position: relative;
  z-index: 1;
}
.page-fv__label span {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
  line-height: normal;
  color: #fff;
  text-transform: uppercase;
}
.page-fv__title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(7.9365079365vw, 120px);
  line-height: 1.08;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.05em;
}
.page-fv__title-en {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  letter-spacing: 0em;
}
.page-fv__lead {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: min(2.6455026455vw, 40px);
  letter-spacing: min(0.1058201058vw, 1.6px);
  color: #000;
}
@media (max-width: 768px) {
  .page-fv {
    min-height: auto;
    padding-top: 26.6666666667vw;
    padding-bottom: 21.3333333333vw;
    padding-inline: 5.3333333333vw;
    display: block;
  }
  .page-fv__inner {
    max-width: 100%;
    padding: 0;
    gap: 5.3333333333vw;
    margin-inline: 0;
  }
  .page-fv__title-group {
    gap: 4vw;
    padding-bottom: 2.6666666667vw;
  }
  .page-fv__label {
    padding: 0 1.3333333333vw;
    margin-bottom: 0;
  }
  .page-fv__label span {
    font-size: 3.7333333333vw;
  }
  .page-fv__title {
    font-size: 10.6666666667vw;
  }
  .page-fv__lead {
    font-size: 3.7333333333vw;
    line-height: 7.4666666667vw;
    letter-spacing: 0.2666666667vw;
  }
}

.page-bg-gradient {
  position: absolute;
  left: 0;
  width: 100%;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(to bottom, transparent 0%, rgba(90, 90, 159, 0.24) 29.6%, rgba(90, 90, 159, 0) 100%);
  opacity: 0.2;
}

.page-body {
  position: relative;
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
}
.page-body__lead {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  letter-spacing: min(0.1058201058vw, 1.6px);
  color: #3c3c50;
}
@media (max-width: 768px) {
  .page-body {
    width: calc(100% - 10.6666666667vw);
  }
  .page-body__lead {
    font-size: 3.7333333333vw;
    line-height: 1.85;
    letter-spacing: 0.1493333333vw;
  }
  .page-body__lead br {
    display: none;
  }
}

.hero {
  position: fixed;
  width: 100%;
  height: calc(100svh - min(6.6137566138vw, 100px));
  overflow: hidden;
  margin-top: min(6.6137566138vw, 100px);
  padding-bottom: min(3.6375661376vw, 55px);
  background-color: linear-gradient(to right, #5a5a9f, #c54f8f);
}
.hero__slider {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.hero__slide-inner {
  position: relative;
  width: 100%;
  height: 100%;
}
.hero__slide-inner::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.8) 100%);
  z-index: 2;
  pointer-events: none;
}
.hero__slide {
  position: absolute;
  inset: 0;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.2s cubic-bezier(0.65, 0, 0.35, 1);
}
.hero__slide.is-active {
  clip-path: inset(0 0 0 0);
}
.hero__slide.is-prev {
  clip-path: inset(0 0 0 0);
  transition: none;
}
.hero__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}
.hero__content {
  position: relative;
  width: 100%;
  height: 100svh;
  padding-top: min(6.6137566138vw, 100px);
  mix-blend-mode: difference;
  /* z-index を付けない: スタッキングコンテキストを作らず、タイトルを背景と同一レイヤーでブレンドする */
}
.hero__title {
  position: absolute;
  bottom: 0;
  left: 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(8.5978835979vw, 130px);
  line-height: 1.05;
  color: #fff;
  display: flex;
  flex-direction: column;
}
.hero__bottom-glow {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: min(3.9682539683vw, 60px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  opacity: 0.3;
  filter: blur(min(3.3068783069vw, 50px));
  z-index: 2;
  pointer-events: none;
}

.intro {
  position: relative;
  padding: min(10.582010582vw, 160px) min(2.6455026455vw, 40px);
  text-align: center;
  height: 100vh;
}
.intro__text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  font-weight: 700;
  font-size: 20px;
  line-height: 2.4;
}
.intro__text p {
  margin-bottom: min(1.5873015873vw, 24px);
}
.intro__text p:last-child {
  margin-bottom: 0;
}

.about {
  position: relative;
  overflow: hidden;
  padding: min(4.1666666667vw, 63px) min(2.6455026455vw, 40px) min(10.582010582vw, 160px);
}
.about__bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, rgba(90, 90, 159, 0) 0%, rgba(90, 90, 159, 0.13) 50%, rgba(90, 90, 159, 0) 100%);
  pointer-events: none;
  z-index: 0;
}
.about__inner {
  position: relative;
  z-index: 1;
  max-width: 1206px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: min(19.8412698413vw, 300px) 1fr;
  grid-template-rows: auto 1fr;
  justify-content: center;
  align-items: flex-start;
  gap: min(1.3227513228vw, 20px) min(5.291005291vw, 80px);
}
.about__message-body {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
  padding-top: min(3.9682539683vw, 60px);
}
.about__photo-area {
  grid-column: 1;
  grid-row: 1/-1;
  display: flex;
  flex-direction: column;
  gap: min(1.7195767196vw, 26px);
  width: 85%;
}
.about__photo-wrapper {
  min-width: 0;
  aspect-ratio: 425/571;
  overflow: hidden;
  border-radius: min(0.6613756614vw, 10px);
}
.about__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.5) translate3d(-5%, 8%, 0);
}
.about__photo-info {
  width: max-content;
}
.about__photo-title {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.6;
}
.about__photo-name {
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
  margin-top: min(0.7936507937vw, 12px);
}
.about__message-action {
  grid-column: 2;
  grid-row: 2;
  padding-top: min(2.6455026455vw, 40px);
}

.works__inner {
  max-width: 1432px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin-inline: auto;
  border-radius: min(1.3227513228vw, 20px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  position: relative;
  overflow: clip;
  padding: min(9.9206349206vw, 150px) 0 min(9.9206349206vw, 150px) min(7.4735449735vw, 113px);
  display: flex;
  align-items: flex-start;
  gap: min(3.9682539683vw, 60px);
  position: relative;
}
.works__images {
  position: absolute;
  right: calc(min(0.6613756614vw, 10px) * -1);
  top: calc(min(19.8412698413vw, 300px) * -1);
  display: flex;
  gap: min(0.8597883598vw, 13px);
}
.works__images-col {
  display: flex;
  flex-direction: column;
  gap: min(0.8597883598vw, 13px);
  width: min(13.7566137566vw, 208px);
  will-change: transform;
}
.works__image {
  width: 100%;
  height: min(18.5185185185vw, 280px);
  border-radius: min(0.5291005291vw, 8px);
  overflow: hidden;
}
.works__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.works__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
  max-width: min(45.5687830688vw, 689px);
}
.works__content-info {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
}
.works__desc {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  color: #fff;
}

.people {
  padding: min(15.873015873vw, 240px) min(2.6455026455vw, 40px) 0;
}
.people__inner {
  max-width: min(79.3650793651vw, 1200px);
  margin: 0 auto;
}
.people__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: min(7.9365079365vw, 120px);
}
.people__desc {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
}
.people__profiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(5.291005291vw, 80px);
}
.people__profile {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: min(2.6455026455vw, 40px);
}
.people__profile > * {
  transition: all 0.35s ease-in-out;
}
@media (hover: hover) {
  .people__profile:hover > * {
    opacity: 0.6;
  }
  .people__profile:hover .people__profile-img img {
    transform: scale(1.05);
  }
}
.people__profile--offset {
  margin-top: min(5.291005291vw, 80px);
}
.people__profile-img {
  aspect-ratio: 1;
  background: #d9d9d9;
  border-radius: min(0.5291005291vw, 8px);
  overflow: hidden;
}
.people__profile-img img {
  transition: all 0.35s ease-in-out;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 10%;
}
.people__profile-voice {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  text-transform: uppercase;
  line-height: 1.5;
}
.people__profile-quote {
  font-weight: 700;
  font-size: min(1.6534391534vw, 25px);
  line-height: 1.6;
  margin-top: min(1.0582010582vw, 16px);
}
.people__profile-divider {
  width: 100%;
  height: 1px;
  background: #000;
  margin: min(1.3227513228vw, 20px) 0;
}
.people__profile-info {
  display: grid;
  grid-template-columns: max-content max-content;
  align-items: center;
  gap: min(1.0582010582vw, 16px);
  width: 100%;
}
.people__profile-role {
  font-weight: 700;
  font-size: min(1.0582010582vw, 16px);
  line-height: 1.875;
  letter-spacing: 0;
}
.people__profile-name {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.5;
}

.career {
  padding-top: min(15.873015873vw, 240px);
  position: relative;
  overflow: hidden;
}
.career a > * {
  transition: all 0.35s ease-in-out;
}
.career__inner {
  max-width: 1432px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin-inline: auto;
  border-radius: min(1.3227513228vw, 20px);
  padding: min(9.9206349206vw, 150px) 0;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  display: flex;
  align-items: flex-start;
}
.career__content {
  padding-left: min(7.4735449735vw, 113px);
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
  flex-shrink: 0;
  width: 50%;
}
.career__content-info {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
}
.career__desc {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  color: #fff;
  margin-bottom: min(2.6455026455vw, 40px);
}
.career__list {
  background: #fff;
  border-radius: min(0.7936507937vw, 12px) 0 0 min(0.7936507937vw, 12px);
  padding: min(3.9682539683vw, 60px);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
}
.career__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (hover: hover) {
  .career__item:hover .career__item-arrow {
    color: #5a5a9f;
  }
  .career__item:hover .career__item-arrow::before {
    opacity: 1;
  }
  .career__item:hover .career__item-arrow::after {
    opacity: 1;
  }
}
.career__item-text {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
  max-width: min(32.9365079365vw, 498px);
}
.career__item-title {
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
}
.career__item-desc {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.6;
}
.career__item-arrow {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.career__item-arrow img {
  width: min(1.1904761905vw, 18px);
  height: min(1.1904761905vw, 18px);
}
@media (max-width: 768px) {
  .career__item-arrow {
    width: 9.6vw;
    height: 9.6vw;
  }
  .career__item-arrow img {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
}
.career__item-arrow {
  position: relative;
  color: #fff;
  transition: all 0.35s ease-in-out;
}
.career__item-arrow::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
.career__item-arrow::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  padding: min(0.1322751323vw, 2px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff, #fff) content-box, linear-gradient(#fff, #fff) padding-box;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
.career__item-arrow svg {
  position: relative;
  z-index: 1;
  transition: color 0.35s ease-in-out;
}
.career__item-divider {
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.15);
}

.fr_benefits {
  padding-top: min(15.873015873vw, 240px);
}
.fr_benefits__inner {
  max-width: 1432px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin-inline: auto;
  border-radius: min(1.3227513228vw, 20px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  padding: min(9.9206349206vw, 150px) min(7.4735449735vw, 113px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: min(3.9682539683vw, 60px);
}
.fr_benefits__content {
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
}
.fr_benefits__content-info {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
}
.fr_benefits__desc {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  color: #fff;
}
.fr_benefits__images {
  position: relative;
  flex-shrink: 0;
  width: min(34.5899470899vw, 523px);
  height: min(30.6216931217vw, 463px);
}
.fr_benefits__image-large {
  position: relative;
  width: fit-content;
  height: min(21.164021164vw, 320px);
  padding-left: min(6.6137566138vw, 100px);
}
.fr_benefits__image-large img {
  border-radius: min(0.7936507937vw, 12px);
  overflow: hidden;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.fr_benefits__image-large--portrait {
  display: flex;
  align-items: center;
  justify-content: center;
}
.fr_benefits__image-large--portrait img {
  width: auto;
  height: 100%;
  object-fit: contain;
  position: relative;
  z-index: 1;
}
.fr_benefits__image-small {
  position: absolute;
  right: 0;
  bottom: 0;
  width: min(15.1455026455vw, 229px);
  height: min(20.3703703704vw, 308px);
  border-radius: min(0.7936507937vw, 12px);
  border: min(0.5291005291vw, 8px) solid transparent;
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(to right, #5a5a9f, #c54f8f) border-box;
  overflow: hidden;
  z-index: 1;
}
.fr_benefits__image-small img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right;
}

.movie {
  padding: min(15.873015873vw, 240px) 0 0;
  overflow: hidden;
}
.movie__header {
  max-width: 1432px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin-inline: auto;
  padding-left: min(7.4735449735vw, 113px);
  margin-bottom: min(7.9365079365vw, 120px);
}
.movie__carousel {
  overflow: visible;
  height: min(41.8650793651vw, 633px);
}
.movie__carousel .swiper-wrapper {
  align-items: flex-start;
}
.movie__slide {
  width: min(22.8174603175vw, 345px) !important;
  aspect-ratio: 345/464;
  padding-top: min(3.5714285714vw, 54px);
  opacity: 0.5;
  transition: padding-top 1.2s cubic-bezier(0.4, 0, 0.2, 1), opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.movie__slide.swiper-slide-active {
  padding-top: 0;
  opacity: 1;
}
.movie__slide.swiper-slide-active .movie__slide-inner {
  width: 100% !important;
  aspect-ratio: 9/16;
  height: min(37.7645502646vw, 571px);
  border-radius: min(1.3227513228vw, 20px);
}
.movie__slide.swiper-slide-active .movie__slide-overlay {
  opacity: 0;
}
.movie__slide.swiper-slide-active .movie__slide-title {
  opacity: 1;
}
.movie__slide-inner {
  position: relative;
  width: 100%;
  height: min(30.6878306878vw, 464px);
  border-radius: min(1.0582010582vw, 16px);
  overflow: hidden;
  transition: height 1.2s cubic-bezier(0.4, 0, 0.2, 1), border-radius 1.2s cubic-bezier(0.4, 0, 0.2, 1), opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.movie__slide-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.movie__slide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(92, 90, 159, 0.2), rgba(196, 80, 143, 0.2));
  opacity: 1;
  transition: opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}
.movie__slide-title {
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.6;
  text-align: right;
  margin-top: min(1.9841269841vw, 30px);
  opacity: 0;
  transition: opacity 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.movie__play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: max(48px, min(4.2328042328vw, 64px));
  height: max(48px, min(4.2328042328vw, 64px));
  border: none;
  background: none;
  padding: 0;
  cursor: pointer;
  z-index: 2;
  transition: transform 0.2s ease;
}
.movie__play-btn svg {
  width: 100%;
  height: 100%;
}
.movie__play-btn:hover {
  transform: translate(-50%, -50%) scale(1.1);
}

.movie-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  visibility: hidden;
  opacity: 0;
}
.movie-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
}
.movie-modal__content {
  position: relative;
  height: 85vh;
  aspect-ratio: 9/16;
  max-width: 90vw;
}
@media (max-width: 768px) {
  .movie-modal__content {
    height: 80dvh;
    max-width: 88vw;
  }
}
.movie-modal__player {
  width: 100%;
  height: 100%;
  border-radius: 12px;
  overflow: hidden;
}
.movie-modal__player iframe {
  width: 100%;
  height: 100%;
  border: none;
}
.movie-modal__close {
  position: absolute;
  top: -44px;
  right: 0;
  width: 36px;
  height: 36px;
  border: none;
  background: none;
  color: #fff;
  font-size: 28px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.2s ease;
}
@media (max-width: 768px) {
  .movie-modal__close {
    width: 44px;
    height: 44px;
    font-size: 32px;
    top: -52px;
  }
}
.movie-modal__close:hover {
  opacity: 0.7;
}

@media (max-width: 768px) {
  .hero {
    height: calc(100svh - 16vw);
    margin-top: 16vw;
    padding-bottom: 5.3333333333vw;
  }
  .hero__content {
    height: 100svh;
    padding-top: 16vw;
  }
  .hero__title {
    font-size: 12.8vw;
  }
  .hero__bottom-glow {
    height: 16vw;
    filter: blur(13.3333333333vw);
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.5), rgb(255, 255, 255), rgb(255, 255, 255));
  }
  .intro {
    padding: 21.3333333333vw 5.3333333333vw;
  }
  .intro__text {
    font-size: 3.7333333333vw;
    line-height: 2;
    width: 100%;
  }
  .intro__text p {
    margin-bottom: 6.4vw;
  }
  .about {
    padding: 10.6666666667vw 5.3333333333vw 33.3333333333vw;
  }
  .about__inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 8vw;
  }
  .about__message-body {
    order: 1;
    grid-column: auto;
    grid-row: auto;
    padding-top: 0;
    gap: 4vw;
  }
  .about__photo-area {
    order: 2;
    grid-column: auto;
    grid-row: auto;
    display: grid;
    grid-template-columns: 30% 1fr;
    align-items: end;
    width: 100%;
    gap: 4.2666666667vw;
  }
  .about__photo {
    transform: scale(1.5) translate3d(-5%, 8%, 0);
  }
  .about__photo-wrapper {
    border-radius: 1.6vw;
    width: 100%;
    height: 100%;
    aspect-ratio: 425/551;
  }
  .about__photo-title {
    font-size: 3.7333333333vw;
  }
  .about__photo-name {
    font-size: 4.8vw;
    margin-top: 2.1333333333vw;
  }
  .about__message-action {
    order: 3;
    grid-column: auto;
    grid-row: auto;
    padding-top: 0;
  }
  .works__inner {
    position: relative;
    width: calc(100% - 8vw);
    border-radius: 3.7333333333vw;
    padding: 0 5.3333333333vw 16vw;
    flex-direction: column;
    gap: 8vw;
  }
  .works__images {
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
    overflow: hidden;
    height: 100%;
    opacity: 0.5;
  }
  .works__images-col {
    width: 50%;
    flex-shrink: 0;
    gap: 2.1333333333vw;
  }
  .works__image {
    height: auto;
    aspect-ratio: 5/7;
    border-radius: 1.6vw;
    flex-shrink: 0;
  }
  .works__content {
    max-width: 100%;
    gap: 8vw;
    padding-top: 10.6666666667vw;
  }
  .works__content-info {
    gap: 5.3333333333vw;
  }
  .works__desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
  }
  .works__desc br {
    display: none;
  }
  .people {
    padding: 33.3333333333vw 5.3333333333vw 0;
  }
  .people__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 5.3333333333vw;
    margin-bottom: 18.6666666667vw;
  }
  .people__desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
  }
  .people__profiles {
    grid-template-columns: 1fr;
    gap: 10.6666666667vw;
  }
  .people__profile {
    gap: 5.3333333333vw;
  }
  .people__profile--offset {
    margin-top: 0;
  }
  .people__profile-voice {
    font-size: 3.7333333333vw;
  }
  .people__profile-quote {
    font-size: 4.8vw;
    margin-top: 2.1333333333vw;
  }
  .people__profile-divider {
    margin: 3.2vw 0;
  }
  .people__profile-info {
    gap: 3.2vw;
  }
  .people__profile-role {
    font-size: 3.2vw;
  }
  .people__profile-name {
    font-size: 3.7333333333vw;
  }
  .career {
    padding-top: 33.3333333333vw;
  }
  .career__inner {
    width: calc(100% - 8vw);
    border-radius: 3.7333333333vw;
    padding: 10.6666666667vw 0;
    flex-direction: column;
  }
  .career__content {
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
    width: 100%;
    gap: 8vw;
  }
  .career__content-info {
    gap: 5.3333333333vw;
  }
  .career__desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
    margin-bottom: 0;
  }
  .career__desc br {
    display: none;
  }
  .career__list {
    border-radius: 2.6666666667vw;
    padding: 6.4vw;
    gap: 6.4vw;
    margin-top: 10.6666666667vw;
    margin-inline: 5.3333333333vw;
  }
  .career__item {
    flex-direction: column;
    align-items: flex-start;
    gap: 3.2vw;
  }
  .career__item-text {
    max-width: 100%;
    gap: 2.6666666667vw;
  }
  .career__item-title {
    font-size: 4.8vw;
  }
  .career__item-desc {
    font-size: 3.4666666667vw;
  }
  .career__item-arrow {
    align-self: flex-end;
  }
  .fr_benefits {
    padding-top: 33.3333333333vw;
  }
  .fr_benefits__inner {
    width: calc(100% - 8vw);
    border-radius: 3.7333333333vw;
    padding: 10.6666666667vw 5.3333333333vw;
    flex-direction: column;
    gap: 8vw;
  }
  .fr_benefits__content {
    gap: 8vw;
  }
  .fr_benefits__content-info {
    gap: 4vw;
  }
  .fr_benefits__desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
  }
  .fr_benefits__desc br {
    display: none;
  }
  .fr_benefits__images {
    width: 100%;
    height: auto;
    position: relative;
  }
  .fr_benefits__image-large {
    width: fit-content;
    height: 48vw;
    padding-left: 0;
  }
  .fr_benefits__image-large img {
    border-radius: 2.1333333333vw;
  }
  .fr_benefits__image-small {
    width: 50.6666666667vw;
    height: 32vw;
    border-radius: 2.1333333333vw;
    border-width: 1.0666666667vw;
    right: 0;
    bottom: -8vw;
  }
  .fr_benefits__image-small img {
    object-position: right top;
  }
  .movie {
    padding: 33.3333333333vw 0 0;
  }
  .movie__header {
    width: calc(100% - 10.6666666667vw);
    padding-left: 5.3333333333vw;
    margin-bottom: 16vw;
  }
  .movie__carousel {
    height: 128vw;
  }
  .movie__slide {
    width: 64vw !important;
    padding-top: 8vw;
  }
  .movie__slide.swiper-slide-active .movie__slide-inner {
    height: 106.6666666667vw;
    border-radius: 3.7333333333vw;
  }
  .movie__slide-inner {
    height: 85.3333333333vw;
    border-radius: 2.6666666667vw;
  }
  .movie__slide-title {
    font-size: 3.7333333333vw;
    margin-top: 4.2666666667vw;
  }
}
.about-page .page-body {
  padding-top: min(4.2989417989vw, 65px);
  z-index: 1;
}

.about-sections {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(13.2275132275vw, 200px);
}

.about-message {
  display: grid;
  grid-template-columns: min(19.8412698413vw, 300px) 1fr;
  grid-template-rows: auto 1fr;
  align-items: flex-start;
  width: 100%;
  max-width: 1206px;
  gap: min(1.3227513228vw, 20px) min(8.9947089947vw, 136px);
}
.about-message__header {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
  padding-top: min(3.9682539683vw, 60px);
}
.about-message__profile {
  grid-column: 1;
  grid-row: 1/-1;
  display: flex;
  flex-direction: column;
  gap: min(1.5873015873vw, 24px);
  width: 85%;
}
.about-message__photo {
  min-width: 0;
  aspect-ratio: 340/457;
  border-radius: min(0.6613756614vw, 10px);
  overflow: hidden;
}
.about-message__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.5) translate3d(-5%, 8%, 0);
}
.about-message__info {
  display: flex;
  flex-direction: column;
  gap: min(0.7275132275vw, 11px);
  width: max-content;
}
.about-message__role {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.1904761905vw, 18px);
  line-height: normal;
  color: #3c3c50;
}
.about-message__name {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: normal;
  color: #3c3c50;
}
.about-message__body {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: min(2.6455026455vw, 40px);
}
.about-message__body p {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2.2;
  color: #3c3c50;
  margin-bottom: min(2.6455026455vw, 40px);
}
.about-message__body p:last-child {
  margin-bottom: 0;
}

.about-purpose {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(3.9682539683vw, 60px);
  width: 100%;
}
.about-purpose__heading {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  font-size: min(4.2328042328vw, 64px);
  line-height: 1;
}
.about-purpose__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(5.291005291vw, 80px);
  width: min(59.5238095238vw, 900px);
}
.about-purpose__image {
  width: 100%;
  height: min(33.4656084656vw, 506px);
  overflow: hidden;
}
.about-purpose__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-purpose__text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  color: #3c3c50;
  text-align: center;
}

.about-domain {
  width: 100%;
}
.about-domain__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.about-domain__info {
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
  width: min(38.2936507937vw, 579px);
}
.about-domain__heading {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(4.2328042328vw, 64px);
  line-height: 1;
  width: fit-content;
}
.about-domain__heading-en {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
}
.about-domain__desc {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  color: #3c3c50;
}
.about-domain__diagram {
  width: min(32.208994709vw, 487px);
  min-width: 487px;
  height: auto;
  flex-shrink: 0;
}
.about-domain__diagram img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.about-domain__sections {
  margin-top: min(6.6137566138vw, 100px);
  padding: 0 min(5.291005291vw, 80px);
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
}
.about-domain__section {
  display: flex;
  flex-direction: column;
  gap: min(2.6455026455vw, 40px);
}
.about-domain__section-header {
  display: flex;
  align-items: center;
  gap: min(1.9841269841vw, 30px);
}
.about-domain__section-header--right {
  justify-content: flex-end;
}
.about-domain__section-num {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.2;
  color: #3c3c50;
  text-transform: capitalize;
}
.about-domain__section-line {
  display: block;
  width: 0;
  height: min(2.380952381vw, 36px);
  border-left: 2px solid #3c3c50;
}
.about-domain__section-title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
  line-height: 1.2;
  color: #3c3c50;
}
.about-domain__section-body {
  display: flex;
  align-items: center;
  gap: min(2.6455026455vw, 40px);
}
.about-domain__section-body--reverse {
  justify-content: flex-end;
}
.about-domain__section-img {
  width: min(29.9603174603vw, 453px);
  height: min(18.6507936508vw, 282px);
  border-radius: min(0.3968253968vw, 6px);
  overflow: hidden;
  flex-shrink: 0;
}
.about-domain__section-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-domain__section-tags {
  display: flex;
  flex-wrap: wrap;
  gap: min(1.3227513228vw, 20px);
  align-items: flex-start;
}
.about-domain__section-tags.tags-01 {
  width: min(31.2169312169vw, 472px);
}
.about-domain__section-tags.tags-02 {
  width: min(19.6428571429vw, 297px);
}
.about-domain__section-tags.tags-03 {
  width: min(26.7857142857vw, 405px);
}
.about-domain__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: min(0.6613756614vw, 10px) min(1.0582010582vw, 16px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  border-radius: min(3.3068783069vw, 50px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.0582010582vw, 16px);
  line-height: 1;
  color: #fff;
  white-space: nowrap;
}
.about-domain__section-divider {
  width: 100%;
  height: 1px;
  background: rgba(60, 60, 80, 0.15);
  margin-top: min(2.6455026455vw, 40px);
}

.about-numbers {
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
  width: 100%;
}
.about-numbers__heading {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(4.2328042328vw, 64px);
  line-height: 1;
  width: fit-content;
}
.about-numbers__heading-en {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
}
.about-numbers__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(2.6455026455vw, 40px);
}
.about-numbers__card {
  position: relative;
  border-radius: min(0.9259259259vw, 14px);
  height: min(22.1560846561vw, 335px);
  overflow: hidden;
}
.about-numbers__card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 4px;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
}
.about-numbers__card {
  background: rgba(90, 90, 159, 0.08);
}
.about-numbers__card-label {
  position: absolute;
  top: min(1.3227513228vw, 20px);
  left: min(1.3227513228vw, 20px);
  background: #fff;
  border-radius: min(0.5291005291vw, 8px);
  padding: min(0.2645502646vw, 4px) min(0.9259259259vw, 14px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.1904761905vw, 18px);
  color: #5a5a9f;
  line-height: normal;
  z-index: 2;
}
.about-numbers__card-value {
  position: absolute;
  top: min(7.0767195767vw, 107px);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: baseline;
  color: #5a5a9f;
  z-index: 2;
}
.about-numbers__card-num {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(6.4153439153vw, 97px);
  line-height: 1.16;
}
.about-numbers__card-unit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(3.7037037037vw, 56px);
  letter-spacing: 0.1em;
  line-height: normal;
}
.about-numbers__card-icon {
  position: absolute;
  top: min(3.5052910053vw, 53px);
  left: min(3.5714285714vw, 54px);
  width: min(17.6587301587vw, 267px);
  height: min(17.6587301587vw, 267px);
  opacity: 0.1;
  z-index: 1;
}
.about-numbers__card-icon--users {
  top: min(5.2248677249vw, 79px);
  left: min(2.9100529101vw, 44px);
  width: min(18.9153439153vw, 286px);
  height: min(13.8888888889vw, 210px);
  opacity: 1;
}
.about-numbers__card-icon--woman {
  top: 50%;
  left: 50%;
  transform: translate(-53.5%, -50%);
  width: min(13.8888888889vw, 210px);
  height: min(13.8888888889vw, 210px);
  opacity: 1;
}
.about-numbers__card--wide {
  grid-column: span 2;
}
.about-numbers__card-dual {
  position: absolute;
  top: min(4.9603174603vw, 75px);
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: start;
  justify-content: center;
  gap: min(14.5502645503vw, 220px);
  z-index: 2;
}
.about-numbers__card-dual-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.about-numbers__card-dual-item .about-numbers__card-value {
  position: static;
  transform: none;
  left: auto;
}
.about-numbers__card-dual-label {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  font-size: min(1.3227513228vw, 20px);
  color: #5a5a9f;
  line-height: normal;
}
.about-numbers__card-dual-label-jp {
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.about-numbers__card--wide .about-numbers__card-icon--users {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(19.8412698413vw, 300px);
  height: auto;
  object-fit: contain;
  aspect-ratio: 285.032/209.336;
  opacity: 1;
  flex-shrink: 0;
}
.about-numbers__card-note {
  position: absolute;
  bottom: min(0.7936507937vw, 12px);
  right: min(1.3227513228vw, 20px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.1904761905vw, 18px);
  line-height: normal;
  color: #979797;
  text-align: right;
  z-index: 2;
}
.about-numbers__card-chart {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(15.873015873vw, 240px);
  height: min(15.873015873vw, 240px);
  object-fit: contain;
  z-index: 1;
}
.about-numbers__card-chart--job {
  top: 48.5%;
  width: min(16.5343915344vw, 250px);
  height: min(17.5734126984vw, 265.71px);
}
.about-numbers__card-chart--hire {
  top: 55.5%;
}

.about-sustaina {
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
  width: 100%;
}
.about-sustaina__heading {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(4.2328042328vw, 64px);
  line-height: normal;
  width: fit-content;
}
.about-sustaina__content {
  display: flex;
  align-items: center;
  gap: min(6.4153439153vw, 97px);
}
.about-sustaina__text {
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
}
.about-sustaina__desc {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  color: #3c3c50;
}
.about-sustaina__link {
  display: inline-flex;
  align-items: center;
  gap: min(1.3227513228vw, 20px);
  padding: min(0.3968253968vw, 6px) min(0.6613756614vw, 10px) min(0.3968253968vw, 6px) min(1.9841269841vw, 30px);
  border: 3px solid #5a5a9f;
  border-radius: min(6.6137566138vw, 100px);
  text-decoration: none;
  width: fit-content;
  height: min(3.9682539683vw, 60px);
  transition: opacity 0.3s;
}
.about-sustaina__link:hover {
  opacity: 0.7;
}
.about-sustaina__link-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: normal;
  color: #3c3c50;
  letter-spacing: 0.08em;
}
.about-sustaina__link-arrow {
  width: min(2.6455026455vw, 40px);
  height: min(2.6455026455vw, 40px);
  border-radius: 50%;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.about-sustaina__link-arrow img {
  width: min(1.1904761905vw, 18px);
  height: min(1.1904761905vw, 18px);
}
@media (max-width: 768px) {
  .about-sustaina__link-arrow {
    width: 9.6vw;
    height: 9.6vw;
  }
  .about-sustaina__link-arrow img {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
}
.about-sustaina__image {
  width: min(35.5158730159vw, 537px);
  flex-shrink: 0;
}
.about-sustaina__image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

@media (max-width: 768px) {
  .about-page .page-body {
    padding-top: 10.6666666667vw;
  }
  .about-sections {
    margin-top: 0;
    gap: 21.3333333333vw;
  }
  .about-message {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 8vw;
  }
  .about-message__header {
    order: 1;
    grid-column: 1;
    grid-row: auto;
    padding-top: 0;
    gap: 3.2vw;
  }
  .about-message__profile {
    order: 2;
    grid-column: 1;
    grid-row: auto;
    display: grid;
    grid-template-columns: 30% 1fr;
    align-items: end;
    width: 100%;
    gap: 5.3333333333vw;
  }
  .about-message__photo {
    width: 100%;
    height: auto;
    border-radius: 2.1333333333vw;
  }
  .about-message__role {
    font-size: 3.2vw;
  }
  .about-message__name {
    font-size: 4.8vw;
  }
  .about-message__body {
    order: 3;
    grid-column: 1;
    grid-row: auto;
    padding-top: 0;
  }
  .about-message__body p {
    font-size: 3.7333333333vw;
    line-height: 1.85;
    margin-bottom: 6.4vw;
  }
  .about-message__body p br {
    display: none;
  }
  .about-purpose {
    gap: 8vw;
  }
  .about-purpose__heading {
    font-size: 8.5333333333vw;
  }
  .about-purpose__inner {
    width: 100%;
    gap: 10.6666666667vw;
  }
  .about-purpose__image {
    height: auto;
    width: 100%;
  }
  .about-purpose__text {
    font-size: 3.7333333333vw;
    line-height: 1.85;
    text-align: left;
  }
  .about-purpose__text br {
    display: none;
  }
  .about-domain__top {
    flex-direction: column;
    gap: 8vw;
  }
  .about-domain__info {
    width: 100%;
    gap: 8vw;
  }
  .about-domain__heading {
    font-size: 8.5333333333vw;
  }
  .about-domain__desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
  }
  .about-domain__diagram {
    width: 100%;
    min-width: 0;
  }
  .about-domain__diagram img {
    width: 100%;
  }
  .about-domain__sections {
    margin-top: 10.6666666667vw;
    padding: 0;
    gap: 8vw;
  }
  .about-domain__section-header {
    gap: 4.2666666667vw;
  }
  .about-domain__section-header--right {
    justify-content: flex-start;
  }
  .about-domain__section-num {
    font-size: 4.2666666667vw;
  }
  .about-domain__section-line {
    height: 6.4vw;
  }
  .about-domain__section-title {
    font-size: 4.8vw;
  }
  .about-domain__section-body {
    flex-direction: column;
    gap: 5.3333333333vw;
  }
  .about-domain__section-body--reverse {
    flex-direction: column-reverse;
    justify-content: flex-start;
  }
  .about-domain__section-img {
    width: 100%;
    height: 48vw;
  }
  .about-domain__section-tags {
    width: 100%;
    gap: 2.6666666667vw;
  }
  .about-domain__section-tags.tags-01, .about-domain__section-tags.tags-02, .about-domain__section-tags.tags-03 {
    width: 100%;
  }
  .about-domain__tag {
    padding: 2.1333333333vw 3.2vw;
    font-size: 3.2vw;
    border-radius: 8vw;
  }
  .about-domain__section-divider {
    margin-top: 5.3333333333vw;
  }
  .about-numbers {
    gap: 10.6666666667vw;
  }
  .about-numbers__heading {
    font-size: 8.5333333333vw;
  }
  .about-numbers__grid {
    grid-template-columns: 1fr 1fr;
    gap: 4.2666666667vw;
  }
  .about-numbers__card {
    border-radius: 2.6666666667vw;
    height: 53.3333333333vw;
  }
  .about-numbers__card::before {
    padding: 3px;
  }
  .about-numbers__card-label {
    top: 3.2vw;
    left: 3.2vw;
    padding: 0.8vw 2.6666666667vw;
    font-size: 3.4666666667vw;
    border-radius: 1.6vw;
  }
  .about-numbers__card-value {
    top: 18.6666666667vw;
    left: 50%;
    transform: translateX(-50%);
  }
  .about-numbers__card-num {
    font-size: 12.8vw;
  }
  .about-numbers__card-unit {
    font-size: 7.4666666667vw;
  }
  .about-numbers__card-icon {
    top: 10.6666666667vw;
    left: 50%;
    transform: translateX(-50%);
    width: 34.6666666667vw;
    height: 34.6666666667vw;
  }
  .about-numbers__card-icon--users {
    top: 13.3333333333vw;
    width: 37.3333333333vw;
    height: 29.3333333333vw;
  }
  .about-numbers__card-icon--woman {
    top: 50%;
    transform: translate(-53.5%, -50%);
    width: 29.3333333333vw;
    height: 29.3333333333vw;
  }
  .about-numbers__card:has(.about-numbers__card-chart--hire) .about-numbers__card-label {
    font-size: 2.9333333333vw;
    letter-spacing: -0.05em;
  }
  .about-numbers__card--wide {
    grid-column: span 2;
    height: 53.3333333333vw;
    order: -1;
  }
  .about-numbers__card-dual {
    top: 16vw;
    gap: 10.6666666667vw;
    align-items: start;
  }
  .about-numbers__card-dual-item .about-numbers__card-value {
    position: static;
    transform: none;
    left: auto;
  }
  .about-numbers__card-dual-item .about-numbers__card-num {
    font-size: 13.8666666667vw;
  }
  .about-numbers__card-dual-item .about-numbers__card-unit {
    font-size: 5.8666666667vw;
  }
  .about-numbers__card-dual-label {
    font-size: 3.2vw;
  }
  .about-numbers__card--wide .about-numbers__card-icon--users {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 37.3333333333vw;
    height: auto;
  }
  .about-numbers__card-note {
    font-size: 2.6666666667vw;
    bottom: 1.6vw;
    right: 2.1333333333vw;
  }
  .about-numbers__card-chart {
    top: 55%;
    width: 34.6666666667vw;
    height: 34.6666666667vw;
  }
  .about-numbers__card-chart--job {
    top: 52%;
    width: 34.9333333333vw;
    height: auto;
  }
  .about-sustaina {
    gap: 8vw;
  }
  .about-sustaina__heading {
    font-size: 8.5333333333vw;
  }
  .about-sustaina__content {
    flex-direction: column;
    gap: 8vw;
  }
  .about-sustaina__desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
  }
  .about-sustaina__desc br {
    display: none;
  }
  .about-sustaina__link {
    height: 12.8vw;
    padding: 1.0666666667vw 2.1333333333vw 1.0666666667vw 5.3333333333vw;
    gap: 3.2vw;
  }
  .about-sustaina__link-text {
    font-size: 4.2666666667vw;
  }
  .about-sustaina__link-arrow {
    width: 9.6vw;
    height: 9.6vw;
  }
  .about-sustaina__image {
    width: 100%;
  }
  .about-sustaina__image img {
    width: 100%;
  }
}
.works-page .page-body {
  padding-top: min(4.0343915344vw, 61px);
  z-index: 1;
}

.works-projects {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(7.9365079365vw, 120px);
}
.works-projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(1.3227513228vw, 20px);
  width: 100%;
}
.works-projects__card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  aspect-ratio: 388.666/480;
  border-radius: min(0.6613756614vw, 10px);
  overflow: hidden;
  text-decoration: none;
  padding: min(1.5873015873vw, 24px);
}
@media (hover: hover) {
  .works-projects__card:hover .works-projects__card-img {
    transform: scale(1.05);
  }
}
.works-projects__card-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
}
.works-projects__card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(197, 79, 143, 0) 0%, rgba(90, 90, 159, 0.6) 100%);
}
.works-projects__card-info {
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: min(1.3227513228vw, 20px);
  width: 100%;
}
.works-projects__card-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: min(1.0582010582vw, 16px);
  color: #fff;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  text-transform: capitalize;
}
.works-projects__card-title {
  font-size: min(1.7195767196vw, 26px);
  line-height: 1.3076923077;
}
.works-projects__card-client {
  font-size: min(1.0582010582vw, 16px);
  line-height: 1.375;
}
.works-projects__card-arrow {
  width: min(2.6455026455vw, 40px);
  height: min(2.6455026455vw, 40px);
  border-radius: 50%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #5a5a9f;
}
.works-projects__card-arrow svg {
  width: min(1.1904761905vw, 18px);
  height: min(1.1904761905vw, 18px);
}
.works-projects__more {
  height: min(5.291005291vw, 80px);
  border-width: 3px;
  padding: min(0.3968253968vw, 6px) min(0.6613756614vw, 10px) min(0.3968253968vw, 6px) min(2.6455026455vw, 40px);
  transition: all 0.35s ease-in-out;
}
.works-projects__more > span:first-child {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}
.works-projects__more > span:first-child::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  color: #fff;
  -webkit-text-fill-color: #fff;
  opacity: 0;
  transition: opacity 0.35s ease-in-out;
}
@media (hover: hover) {
  .works-projects__more:hover > span:first-child::after {
    opacity: 1;
  }
}
.works-projects__more .btn__arrow {
  width: min(3.3068783069vw, 50px);
  height: min(3.3068783069vw, 50px);
}

.works-process {
  margin-top: min(13.2275132275vw, 200px);
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
}
.works-process__title {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(4.2328042328vw, 64px);
  line-height: 1;
}
.works-process__image {
  width: 100%;
}
.works-process__image img {
  width: 100%;
  height: auto;
}

@media (max-width: 768px) {
  .works-page .page-body {
    padding-top: 10.6666666667vw;
  }
  .works-projects {
    gap: 10.6666666667vw;
  }
  .works-projects__grid {
    grid-template-columns: 1fr;
    gap: 4.2666666667vw;
  }
  .works-projects__card {
    border-radius: 2.1333333333vw;
    padding: 4.2666666667vw;
  }
  .works-projects__card-info {
    gap: 3.2vw;
  }
  .works-projects__card-title {
    font-size: 4.8vw;
  }
  .works-projects__card-client {
    font-size: 3.2vw;
  }
  .works-projects__card-arrow {
    width: 9.6vw;
    height: 9.6vw;
  }
  .works-projects__card-arrow svg {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
  }
  .works-projects__more {
    height: 14.9333333333vw;
    padding: 1.3333333333vw 2.1333333333vw 1.3333333333vw 6.4vw;
  }
  .works-projects__more .btn__arrow {
    width: 9.6vw;
    height: 9.6vw;
  }
  .works-process {
    margin-top: 21.3333333333vw;
    gap: 10.6666666667vw;
  }
  .works-process__title {
    font-size: 7.4666666667vw;
  }
  .works-process__image {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .works-process__image img {
    min-width: 160vw;
    height: auto;
  }
}
.people-fv {
  position: relative;
  width: 100%;
  padding-top: min(6.6137566138vw, 100px);
  overflow: visible;
}
.people-fv__bg {
  position: absolute;
  top: min(6.6137566138vw, 100px);
  left: 0;
  width: 100%;
  height: min(62.3015873016vw, 942px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  opacity: 0.1;
}
.people-fv__inner {
  position: relative;
  width: min(59.4576719577vw, 899px);
  margin: 0 auto;
  padding-top: min(5.9523809524vw, 90px);
  margin-top: min(5.9523809524vw, 90px);
}
.people-fv__info {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
  width: min(42.9894179894vw, 650px);
}
.people-fv__voice {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1;
  text-transform: uppercase;
  color: #000;
}
.people-fv__title {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(3.3068783069vw, 50px);
  line-height: 1.3;
}
.people-fv__meta {
  display: flex;
  flex-direction: column;
  gap: min(0.7936507937vw, 12px);
}
.people-fv__dept {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #000;
}
.people-fv__name-row {
  display: flex;
  align-items: flex-end;
  gap: min(1.5873015873vw, 24px);
}
.people-fv__name {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
  color: #000;
}
.people-fv__year {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #000;
}
.people-fv__photo {
  position: absolute;
  right: 0;
  top: 0;
  width: min(22.619047619vw, 342px);
  height: min(30.4232804233vw, 460px);
  overflow: hidden;
  flex-shrink: 0;
  z-index: 0;
}
.people-fv__photo img {
  width: 100%;
  height: 100%;
  border-radius: min(0.6613756614vw, 10px);
  object-fit: cover;
}
.people-fv__profile {
  position: relative;
  width: min(59.4576719577vw, 899px);
  margin-left: auto;
  margin-right: auto;
  margin-top: min(6.8121693122vw, 103px);
  padding: min(2.6455026455vw, 40px);
  background: #fff;
  border-radius: min(0.6613756614vw, 10px);
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.people-fv__profile-label {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: min(0.3968253968vw, 6px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .people-fv__profile-label {
    font-size: 4.8vw;
  }
}
.people-fv__profile-label {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  font-size: min(1.5873015873vw, 24px);
}
.people-fv__profile-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.7;
  letter-spacing: min(0.1058201058vw, 1.6px);
  color: #000;
}

.people-section {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: min(13.2275132275vw, 200px);
}
.people-section--origin {
  width: 100%;
  margin-left: 0;
  padding-right: max(min(2.6455026455vw, 40px), 50% - 1206px / 2);
  gap: min(4.6296296296vw, 70px);
}
.people-section--origin .people-section__photo--left {
  flex: 1;
  min-width: 0;
}
.people-section--fulfillment {
  width: 100%;
  margin-right: 0;
  padding-left: max(min(2.6455026455vw, 40px), 50% - 1206px / 2);
  gap: min(4.6296296296vw, 70px);
}
.people-section--fulfillment .people-section__photo--right {
  flex: 1;
  min-width: 0;
}
.people-section--fulfillment .people-section__content {
  width: min(37.5661375661vw, 568px);
}
.people-section__photo {
  flex-shrink: 0;
}
.people-section__photo img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.people-section__photo--left img {
  border-radius: 0 min(0.6613756614vw, 10px) min(0.6613756614vw, 10px) 0;
}
.people-section__photo--right img {
  border-radius: min(0.6613756614vw, 10px) 0 0 min(0.6613756614vw, 10px);
}
.people-section__content {
  width: min(37.5661375661vw, 568px);
  display: flex;
  flex-direction: column;
  gap: min(4.6296296296vw, 70px);
}
.people-section__heading {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.people-section__subtitle {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.8518518519vw, 28px);
  line-height: 1;
  width: fit-content;
}
.people-section__title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(2.2486772487vw, 34px);
  line-height: 1.4;
  color: #000;
}
.people-section__body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.7;
  color: #000;
}
.people-section__body p + p {
  margin-top: 1em;
}
.people-section__highlight {
  background: linear-gradient(to bottom, rgba(154, 197, 242, 0) 68%, #9ac5f2 68%);
}

.people-wide {
  position: relative;
  width: 100%;
  padding: min(6.6137566138vw, 100px) 0;
  margin-top: min(13.2275132275vw, 200px);
  background: linear-gradient(to right, rgba(255, 255, 255, 0), rgba(197, 79, 143, 0.1));
}
.people-wide__inner {
  display: flex;
  align-items: flex-start;
  gap: min(4.6296296296vw, 70px);
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
}
.people-wide__left {
  width: min(37.5661375661vw, 568px);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.people-wide__subtitle {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.8518518519vw, 28px);
  line-height: 1;
  width: fit-content;
}
.people-wide__title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(2.2486772487vw, 34px);
  line-height: 1.4;
  color: #000;
}
.people-wide__right {
  flex: 1;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.7;
  color: #000;
}
.people-wide__right p + p {
  margin-top: 1em;
}
.people-wide__highlight {
  background: linear-gradient(to bottom, rgba(154, 197, 242, 0) 68%, #9ac5f2 68%);
}

.people-schedule {
  position: relative;
  width: 100%;
  margin-top: min(13.2275132275vw, 200px);
  overflow: hidden;
  border-radius: min(0.6613756614vw, 10px);
  max-width: min(95.8994708995vw, 1450px);
  margin-left: auto;
  margin-right: auto;
}
.people-schedule__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.people-schedule__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.people-schedule__overlay {
  position: absolute;
  inset: 0;
  background: rgba(36, 36, 77, 0.6);
}
.people-schedule__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(3.3068783069vw, 50px);
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  padding: min(6.6137566138vw, 100px) 0;
}
.people-schedule__heading {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.8518518519vw, 28px);
  color: #fff;
  text-align: center;
}
.people-schedule__columns {
  display: flex;
  gap: min(3.3068783069vw, 50px);
  width: 100%;
}
.people-schedule__col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: min(3.3068783069vw, 50px);
}
.people-schedule__item {
  display: flex;
  gap: min(1.3227513228vw, 20px);
  align-items: flex-start;
  position: relative;
}
.people-schedule__time {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(4.9603174603vw, 75px);
  flex-shrink: 0;
}
.people-schedule__time span:first-child {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #fff;
}
.people-schedule__dot {
  display: block;
  width: min(0.6613756614vw, 10px);
  height: min(0.6613756614vw, 10px);
  border-radius: 50%;
  background: #fff;
  flex-shrink: 0;
}
.people-schedule__dot::after {
  content: "";
  position: absolute;
  left: min(4.5304232804vw, 68.5px);
  top: min(0.9920634921vw, 15px);
  width: 0;
  border-left: min(0.1984126984vw, 3px) dashed rgba(255, 255, 255, 0.5);
  height: calc(100% + min(3.3068783069vw, 50px));
}
.people-schedule__item:last-child .people-schedule__dot::after {
  display: none;
}
.people-schedule__detail {
  display: flex;
  flex-direction: column;
  gap: min(1.5873015873vw, 24px);
}
.people-schedule__detail-title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.4;
  color: #fff;
}
.people-schedule__detail-desc {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.0582010582vw, 16px);
  color: #fff;
  line-height: 1.6;
}

.people-message {
  position: relative;
  z-index: 1;
  width: min(59.4576719577vw, 899px);
  margin: min(13.2275132275vw, 200px) auto 0;
  padding: min(3.9682539683vw, 60px);
  background: #fff;
  border-radius: min(0.6613756614vw, 10px);
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.people-message__label {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: min(0.3968253968vw, 6px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .people-message__label {
    font-size: 4.8vw;
  }
}
.people-message__label {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  font-size: min(1.5873015873vw, 24px);
  font-family: "Lexend", sans-serif, "Zen Kaku Gothic New", sans-serif;
}
.people-message__heading {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.9841269841vw, 30px);
  color: #000;
}
.people-message__body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.7;
  letter-spacing: min(0.1058201058vw, 1.6px);
  color: #000;
}
.people-message__body p + p {
  margin-top: 1em;
}
.people-message__highlight {
  background: linear-gradient(to bottom, rgba(154, 197, 242, 0) 68%, #9ac5f2 68%);
}

.people-list {
  position: relative;
  z-index: 1;
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: min(13.2275132275vw, 200px) auto 0;
}
.people-list__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: min(5.9523809524vw, 90px);
}
.people-list__header-left {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.people-list__label {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: min(0.3968253968vw, 6px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .people-list__label {
    font-size: 4.8vw;
  }
}
.people-list__label {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  font-size: min(1.5873015873vw, 24px);
}
.people-list__title {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-weight: 700;
  font-size: min(5.5555555556vw, 84px);
  line-height: 1;
  letter-spacing: -3.36px;
}
@media (max-width: 768px) {
  .people-list__title {
    font-size: 12.8vw;
  }
}
.people-list__header-right {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #000;
  line-height: 1.5;
}
.people-list__cards {
  display: flex;
  gap: min(2.6455026455vw, 40px);
  flex-wrap: wrap;
}

.people-card {
  display: flex;
  flex-direction: column;
  gap: min(2.6455026455vw, 40px);
  width: min(23.8095238095vw, 360px);
}
.people-card__photo {
  width: 100%;
  aspect-ratio: 1;
  background: #d9d9d9;
  border-radius: min(0.5291005291vw, 8px);
  overflow: hidden;
}
.people-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 10%;
}
.people-card__info {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.people-card__texts {
  display: flex;
  flex-direction: column;
  gap: min(1.0582010582vw, 16px);
}
.people-card__voice {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.5;
  text-transform: uppercase;
  color: #000;
}
.people-card__catch {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
  line-height: 1.4;
  color: #000;
}
.people-card__line {
  border: none;
  border-top: 1px solid #000;
  width: 100%;
  margin: 0;
}
.people-card__meta {
  display: flex;
  align-items: flex-end;
  gap: min(1.0582010582vw, 16px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  color: #000;
}
.people-card__role {
  font-size: min(1.0582010582vw, 16px);
  line-height: 1.5;
}
.people-card__name {
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.5;
}

@media (max-width: 768px) {
  .people-fv {
    padding-top: 16vw;
  }
  .people-fv__bg {
    top: 16vw;
    height: 133.3333333333vw;
  }
  .people-fv__inner {
    width: calc(100% - 10.6666666667vw);
    padding-top: 10.6666666667vw;
    margin-top: 10.6666666667vw;
  }
  .people-fv__info {
    width: 100%;
    gap: 6.4vw;
  }
  .people-fv__voice {
    font-size: 3.7333333333vw;
  }
  .people-fv__title {
    font-size: 7.4666666667vw;
  }
  .people-fv__dept {
    font-size: 3.7333333333vw;
  }
  .people-fv__meta {
    gap: 2.1333333333vw;
  }
  .people-fv__name {
    font-size: 4.8vw;
  }
  .people-fv__year {
    font-size: 3.7333333333vw;
  }
  .people-fv__photo {
    position: relative;
    width: 100%;
    height: 80vw;
    margin-top: 6.4vw;
  }
  .people-fv__photo img {
    border-radius: 2.1333333333vw;
    object-position: center 15%;
  }
  .people-fv__profile {
    width: calc(100% - 10.6666666667vw);
    margin-top: 10.6666666667vw;
    padding: 6.4vw;
    border-radius: 2.1333333333vw;
    gap: 3.2vw;
  }
  .people-fv__profile-label {
    font-size: 3.7333333333vw;
  }
  .people-fv__profile-text {
    font-size: 3.7333333333vw;
    line-height: 1.7;
    letter-spacing: 0.1493333333vw;
  }
  .people-section {
    flex-direction: column;
    margin-top: 21.3333333333vw;
    gap: 8vw;
  }
  .people-section--origin {
    padding-right: 0;
    padding: 0 5.3333333333vw;
  }
  .people-section--origin .people-section__photo--left {
    width: 100%;
    flex: none;
  }
  .people-section--fulfillment {
    padding-left: 0;
    padding: 0 5.3333333333vw;
  }
  .people-section--fulfillment .people-section__photo--right {
    width: 100%;
    flex: none;
    order: -1;
  }
  .people-section--fulfillment .people-section__content {
    width: 100%;
  }
  .people-section__photo img {
    border-radius: 2.1333333333vw !important;
  }
  .people-section__content {
    width: 100%;
    gap: 8vw;
  }
  .people-section__heading {
    gap: 3.2vw;
  }
  .people-section__subtitle {
    font-size: 4.8vw;
  }
  .people-section__title {
    font-size: 5.8666666667vw;
  }
  .people-section__body {
    font-size: 3.7333333333vw;
    line-height: 1.7;
  }
  .people-wide {
    margin-top: 21.3333333333vw;
    padding: 10.6666666667vw 0;
  }
  .people-wide__inner {
    flex-direction: column;
    gap: 8vw;
    width: calc(100% - 10.6666666667vw);
  }
  .people-wide__left {
    width: 100%;
    gap: 3.2vw;
  }
  .people-wide__subtitle {
    font-size: 4.8vw;
  }
  .people-wide__title {
    font-size: 5.8666666667vw;
  }
  .people-wide__right {
    font-size: 3.7333333333vw;
    line-height: 1.7;
  }
  .people-schedule {
    margin-top: 21.3333333333vw;
    border-radius: 2.1333333333vw;
    max-width: calc(100% - 10.6666666667vw);
  }
  .people-schedule__inner {
    width: calc(100% - 10.6666666667vw);
    padding: 10.6666666667vw 0;
    gap: 8vw;
  }
  .people-schedule__heading {
    font-size: 4.8vw;
  }
  .people-schedule__columns {
    flex-direction: column;
    gap: 8vw;
  }
  .people-schedule__col {
    gap: 6.4vw;
  }
  .people-schedule__time {
    width: 16vw;
  }
  .people-schedule__time span:first-child {
    font-size: 3.7333333333vw;
  }
  .people-schedule__dot {
    width: 2.1333333333vw;
    height: 2.1333333333vw;
  }
  .people-schedule__dot::after {
    left: 14.4vw;
    top: 3.2vw;
    border-left-width: 0.5333333333vw;
    height: calc(100% + 6.4vw);
  }
  .people-schedule__detail {
    gap: 3.2vw;
  }
  .people-schedule__detail-title {
    font-size: 3.7333333333vw;
  }
  .people-schedule__detail-desc {
    font-size: 3.2vw;
  }
  .people-message {
    width: calc(100% - 10.6666666667vw);
    margin-top: 21.3333333333vw;
    padding: 6.4vw;
    border-radius: 2.1333333333vw;
    gap: 3.2vw;
  }
  .people-message__label {
    font-size: 3.7333333333vw;
  }
  .people-message__heading {
    font-size: 5.3333333333vw;
  }
  .people-message__body {
    font-size: 3.7333333333vw;
    line-height: 1.7;
    letter-spacing: 0.1493333333vw;
  }
  .people-list {
    width: calc(100% - 10.6666666667vw);
    margin-top: 21.3333333333vw;
  }
  .people-list__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 4.2666666667vw;
    margin-bottom: 10.6666666667vw;
  }
  .people-list__title {
    font-size: 9.6vw;
  }
  .people-list__header-right {
    font-size: 3.7333333333vw;
  }
  .people-list__cards {
    flex-direction: column;
    gap: 10.6666666667vw;
  }
  .people-card {
    width: 100%;
    gap: 5.3333333333vw;
  }
  .people-card__photo {
    border-radius: 1.6vw;
  }
  .people-card__info {
    gap: 3.2vw;
  }
  .people-card__texts {
    gap: 2.6666666667vw;
  }
  .people-card__voice {
    font-size: 3.7333333333vw;
  }
  .people-card__catch {
    font-size: 4.8vw;
  }
  .people-card__meta {
    gap: 2.6666666667vw;
  }
  .people-card__role {
    font-size: 3.2vw;
  }
  .people-card__name {
    font-size: 3.7333333333vw;
  }
}
.career-diagram {
  padding: 0 0 min(5.291005291vw, 80px);
}
.career-diagram__inner {
  display: flex;
  justify-content: center;
}
.career-diagram__image {
  width: calc(100% - min(5.291005291vw, 80px));
  max-width: 1212px;
  height: auto;
  display: block;
}

.career-jobs {
  max-width: 1432px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: min(9.9206349206vw, 150px);
}

.career-job {
  border-radius: min(1.3227513228vw, 20px);
  padding: min(8.5978835979vw, 130px) min(5.9523809524vw, 90px);
}
.career-job--producer {
  background: linear-gradient(to right, #8787d7, #9ac5f2);
}
.career-job--planner {
  background: linear-gradient(to right, #8787d7, #8dd8cf);
}
.career-job--da {
  background: linear-gradient(to right, #8787d7, #fbaa9f);
}
.career-job__inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: min(3.9682539683vw, 60px);
}
.career-job__info {
  scroll-margin-top: min(20.7010582011vw, 313px);
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
  width: min(37.6984126984vw, 570px);
}
.career-job__header {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
}
.career-job__title {
  width: 100%;
  padding: 0 0 min(1.9841269841vw, 30px) 0;
  border-bottom: 1px solid #fff;
}
.career-job__title span {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(2.6455026455vw, 40px);
  line-height: 1.16;
  color: #fff;
}
.career-job__tags {
  display: flex;
  flex-wrap: wrap;
  gap: min(1.3227513228vw, 20px);
}
.career-job__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: min(0.6613756614vw, 10px) min(1.0582010582vw, 16px);
  background: #fff;
  border-radius: min(3.3068783069vw, 50px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.0582010582vw, 16px);
  color: #5a5a9f;
  line-height: normal;
}
.career-job__desc {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.8;
  color: #fff;
}
.career-job__desc p + p {
  margin-top: min(1.3227513228vw, 20px);
}
.career-job__growth {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
  flex: 1;
  min-width: 0;
}
.career-job__growth-title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.7195767196vw, 26px);
  color: #fff;
  line-height: normal;
}
.career-job__timeline {
  background: #fff;
  border-radius: min(0.9259259259vw, 14px);
  padding: min(3.9682539683vw, 60px);
  display: flex;
  flex-direction: column;
  gap: min(3.3068783069vw, 50px);
}
.career-job__timeline-item {
  display: flex;
  gap: min(2.6455026455vw, 40px);
  align-items: flex-start;
  position: relative;
}
.career-job__timeline-item:not(:last-child)::before {
  content: "";
  position: absolute;
  left: min(0.2645502646vw, 4px);
  top: min(0.9259259259vw, 14px);
  bottom: calc(min(-3.3068783069vw, -50px) - min(0.2645502646vw, 4px));
  width: min(0.1322751323vw, 2px);
  background: repeating-linear-gradient(to bottom, rgba(90, 90, 159, 0.16) 0, rgba(197, 79, 143, 0.16) min(0.5291005291vw, 8px), transparent min(0.5291005291vw, 8px), transparent min(1.0582010582vw, 16px));
}
.career-job__timeline-dot {
  width: min(0.6613756614vw, 10px);
  height: min(0.6613756614vw, 10px);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: min(0.5291005291vw, 8px);
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
}
.career-job__timeline-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
  min-width: 0;
}
.career-job__timeline-heading {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #5a5a9f;
  line-height: normal;
}
.career-job__timeline-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.0582010582vw, 16px);
  color: #000;
  line-height: normal;
}

.career-vision {
  position: relative;
  padding: min(13.2275132275vw, 200px) 0 0;
}
.career-vision::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(min(28.4391534392vw, 430px) * -1);
  height: calc(min(74.0079365079vw, 1119px) + min(15.873015873vw, 240px));
  background: linear-gradient(to top, rgba(90, 90, 159, 0.35), rgba(90, 90, 159, 0));
  pointer-events: none;
}
.career-vision__inner {
  position: relative;
  z-index: 1;
  max-width: 1432px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.career-vision__circle {
  width: min(29.7619047619vw, 450px);
  height: min(29.7619047619vw, 450px);
  border-radius: 50%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: min(1.9841269841vw, 30px);
  flex-shrink: 0;
}
.career-vision__circle-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.8;
  letter-spacing: 0.002em;
  color: #000;
  text-align: center;
}
.career-vision__connector {
  flex-shrink: 0;
  width: min(5.0925925926vw, 77px);
  margin-left: min(-1.3227513228vw, -20px);
  margin-right: min(1.9841269841vw, 30px);
}
.career-vision__connector img {
  width: 100%;
  height: auto;
  display: block;
}
.career-vision__paths {
  display: flex;
  flex-direction: column;
  gap: min(6.6137566138vw, 100px);
  min-width: 0;
}
.career-vision__path-en {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  font-size: min(5.9523809524vw, 90px);
  line-height: normal;
  color: rgba(90, 90, 159, 0.2);
  text-transform: capitalize;
}
.career-vision__path--alt .career-vision__path-en {
  color: #fff;
}
.career-vision__path-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(2.2486772487vw, 34px);
  line-height: 1.06;
  letter-spacing: min(0.1798941799vw, 2.72px);
  color: #000;
}

@media (max-width: 768px) {
  .career-page .page-fv .page-fv__label {
    margin-bottom: -2.1333333333vw;
  }
  .career-diagram {
    padding: 10.6666666667vw 0;
  }
  .career-diagram__image {
    width: calc(100% - 10.6666666667vw);
  }
  .career-jobs {
    width: calc(100% - 8vw);
    gap: 10.6666666667vw;
  }
  .career-job {
    border-radius: 3.7333333333vw;
    padding: 10.6666666667vw 5.3333333333vw;
  }
  .career-job__inner {
    flex-direction: column;
    gap: 10.6666666667vw;
  }
  .career-job__info {
    scroll-margin-top: 29.3333333333vw;
    width: 100%;
    gap: 8vw;
  }
  .career-job__header {
    gap: 4.2666666667vw;
  }
  .career-job__title {
    font-size: 5.8666666667vw;
  }
  .career-job__title span {
    font-size: 5.8666666667vw;
  }
  .career-job__title br {
    display: none;
  }
  .career-job__tags {
    gap: 2.1333333333vw;
  }
  .career-job__tag {
    padding: 1.6vw 3.2vw;
    font-size: 2.9333333333vw;
    border-radius: 8vw;
  }
  .career-job__desc {
    font-size: 3.4666666667vw;
    line-height: 1.75;
  }
  .career-job__desc p + p {
    margin-top: 3.7333333333vw;
  }
  .career-job__desc br {
    display: none;
  }
  .career-job__growth {
    gap: 4.2666666667vw;
  }
  .career-job__growth-title {
    font-size: 4.8vw;
  }
  .career-job__timeline {
    padding: 6.4vw;
    border-radius: 2.6666666667vw;
    gap: 7.4666666667vw;
  }
  .career-job__timeline-item {
    gap: 4.2666666667vw;
  }
  .career-job__timeline-item:not(:last-child)::before {
    left: 0.8vw;
    top: 3.2vw;
    bottom: -8.2666666667vw;
    width: 0.5333333333vw;
    background: repeating-linear-gradient(to bottom, rgba(90, 90, 159, 0.16) 0, rgba(197, 79, 143, 0.16) 2.1333333333vw, transparent 2.1333333333vw, transparent 4.2666666667vw);
  }
  .career-job__timeline-dot {
    width: 2.1333333333vw;
    height: 2.1333333333vw;
    margin-top: 1.3333333333vw;
  }
  .career-job__timeline-content {
    gap: 2.6666666667vw;
  }
  .career-job__timeline-heading {
    font-size: 3.7333333333vw;
  }
  .career-job__timeline-text {
    font-size: 3.2vw;
    line-height: 1.65;
  }
  .career-job__timeline-text br {
    display: none;
  }
  .career-vision {
    padding: 21.3333333333vw 0 0;
  }
  .career-vision::before {
    height: 320vw;
    bottom: -58.6666666667vw;
  }
  .career-vision__inner {
    flex-direction: column;
    gap: 10.6666666667vw;
    width: calc(100% - 10.6666666667vw);
  }
  .career-vision__circle {
    width: 74.6666666667vw;
    height: 74.6666666667vw;
    padding: 10.6666666667vw;
  }
  .career-vision__circle-text {
    font-size: 3.4666666667vw;
    letter-spacing: 0.1386666667vw;
  }
  .career-vision__connector {
    display: none;
  }
  .career-vision__paths {
    gap: 10.6666666667vw;
    align-items: center;
  }
  .career-vision__path-en {
    font-size: 10.6666666667vw;
  }
  .career-vision__path-text {
    width: 100%;
    font-size: 4.2666666667vw;
    text-align: right;
    line-height: 1.5;
  }
  .career-vision__path--alt {
    width: 100%;
  }
}
.benefits-page {
  background-color: rgba(90, 90, 159, 0.1);
}

.benefits {
  position: relative;
}
.benefits__inner-layout {
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(15.873015873vw, 240px);
}
.benefits__section {
  display: flex;
  flex-direction: column;
  gap: min(3.9682539683vw, 60px);
}
.benefits__section-header {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.benefits__section-heading {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(3.3068783069vw, 50px);
  line-height: normal;
  width: fit-content;
}
.benefits__section-desc {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: min(2.2486772487vw, 34px);
  color: #000;
}
.benefits__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: min(1.3227513228vw, 20px);
  align-items: stretch;
}
.benefits__item {
  background: #fff;
  border-radius: min(0.9259259259vw, 14px);
  padding: min(1.9841269841vw, 30px) 2em min(1.9841269841vw, 30px) min(1.9841269841vw, 30px);
}
.benefits__item--has-image {
  display: flex;
  flex-direction: column;
  padding: min(1.9841269841vw, 30px);
  gap: min(1.9841269841vw, 30px);
}
.benefits__item-image {
  position: relative;
  width: 100%;
  height: min(19.8412698413vw, 300px);
  border-radius: min(0.5291005291vw, 8px);
  background: #d9d9d9;
  overflow: hidden;
}
.benefits__item-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.benefits__item-image--portrait {
  display: flex;
  align-items: center;
  justify-content: center;
}
.benefits__item-image--portrait img {
  width: auto;
  height: 100%;
  object-fit: contain;
  position: relative;
  z-index: 1;
}
.benefits__item-image-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(8px);
  z-index: 0;
  transform: scale(1.2);
}
.benefits__item-body {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.benefits__item-title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.8518518519vw, 28px);
  line-height: normal;
  color: #5a5a9f;
}
.benefits__item-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.75;
  color: #000;
  word-break: balance;
}
.benefits__tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: min(0.6613756614vw, 10px);
  padding-right: min(1.9841269841vw, 30px);
}
.benefits__tag {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.0582010582vw, 16px);
  line-height: 1;
  padding: min(0.6613756614vw, 10px) min(1.3227513228vw, 20px);
  border-radius: min(6.6137566138vw, 100px);
}

@media (max-width: 768px) {
  .benefits__inner-layout {
    width: calc(100% - 10.6666666667vw);
    gap: 21.3333333333vw;
    padding-top: 8vw;
  }
  .benefits__section {
    gap: 8vw;
  }
  .benefits__section-header {
    gap: 3.2vw;
  }
  .benefits__section-heading {
    font-size: 7.4666666667vw;
  }
  .benefits__section-desc {
    font-size: 3.7333333333vw;
    line-height: 1.85;
  }
  .benefits__grid {
    grid-template-columns: 1fr;
    gap: 3.2vw;
  }
  .benefits__item {
    border-radius: 2.6666666667vw;
    padding: 6.4vw;
  }
  .benefits__item--has-image {
    gap: 5.3333333333vw;
  }
  .benefits__item-image {
    height: 48vw;
    border-radius: 1.6vw;
  }
  .benefits__item-body {
    gap: 3.2vw;
  }
  .benefits__item-title {
    font-size: 4.8vw;
  }
  .benefits__item-text {
    font-size: 3.4666666667vw;
    line-height: 1.75;
  }
  .benefits__tag-list {
    gap: 2.1333333333vw;
  }
  .benefits__tag {
    font-size: 3.2vw;
    padding: 2.1333333333vw 4.2666666667vw;
  }
}
.recruit-table__inner {
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(0.6613756614vw, 10px);
}
.recruit-table__row {
  display: flex;
  align-items: stretch;
  border-radius: min(0.9259259259vw, 14px);
  overflow: hidden;
}
.recruit-table__label {
  width: min(23.8095238095vw, 360px);
  flex-shrink: 0;
  background: rgba(90, 90, 159, 0.2);
  display: flex;
  align-items: center;
  padding: min(3.9682539683vw, 60px);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 2;
  letter-spacing: min(0.1058201058vw, 1.6px);
  color: #5a5a9f;
  border-radius: min(0.9259259259vw, 14px) 0 0 min(0.9259259259vw, 14px);
}
.recruit-table__value {
  flex: 1;
  background: #fff;
  padding: min(2.9761904762vw, 45px) min(1.9841269841vw, 30px) min(2.9761904762vw, 45px) min(2.9761904762vw, 45px);
  border-radius: 0 min(0.9259259259vw, 14px) min(0.9259259259vw, 14px) 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  line-height: 1.7;
  letter-spacing: min(0.1058201058vw, 1.6px);
  color: #000;
}
.recruit-table__value p + p {
  margin-top: min(1.3227513228vw, 20px);
}
.recruit-table__value strong {
  font-weight: 900;
  font-size: 1.15em;
  line-height: 1.7;
}
.recruit-table__value ul {
  list-style: disc;
  padding-left: min(1.9841269841vw, 30px);
}
.recruit-table__value li {
  line-height: 1.7;
}
.recruit-table__value li + li {
  margin-top: 0;
}

.recruit-flow {
  padding-top: min(13.2275132275vw, 200px);
}
.recruit-flow__inner {
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
}
.recruit-flow__heading {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}
.recruit-flow__heading-label {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: min(0.3968253968vw, 6px);
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .recruit-flow__heading-label {
    font-size: 4.8vw;
  }
}
.recruit-flow__heading-label {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  color: #fff;
  font-size: min(1.5873015873vw, 24px);
}
.recruit-flow__heading-title {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(4.2328042328vw, 64px);
  line-height: normal;
  width: fit-content;
}
.recruit-flow__steps {
  display: flex;
  flex-direction: column;
  gap: min(1.9841269841vw, 30px);
}
.recruit-flow__row {
  display: flex;
  align-items: center;
  gap: min(0.7275132275vw, 11px);
}
.recruit-flow__step {
  position: relative;
  width: min(17.9232804233vw, 271px);
  flex-shrink: 0;
}
.recruit-flow__step-badge {
  position: absolute;
  top: 0;
  left: min(0.6613756614vw, 10px);
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: min(0.3968253968vw, 6px) min(1.3227513228vw, 20px);
  border: 2px solid transparent;
  border-radius: min(0.3968253968vw, 6px);
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(to right, #5a5a9f, #c54f8f) border-box;
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  font-size: min(1.1904761905vw, 18px);
  color: #5a5a9f;
  text-transform: uppercase;
  line-height: normal;
}
.recruit-flow__step-box {
  margin-top: min(1.0582010582vw, 16px);
  width: 100%;
  height: min(13.8888888889vw, 210px);
  background: rgba(90, 90, 159, 0.08);
  border: 2px solid transparent;
  border-radius: min(0.6613756614vw, 10px);
  background: linear-gradient(#F2F2F7, #F2F2F7) padding-box, linear-gradient(to right, #5a5a9f, #c54f8f) border-box;
  display: flex;
  align-items: center;
  justify-content: center;
}
.recruit-flow__step-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.3227513228vw, 20px);
  color: #5a5a9f;
  text-align: center;
  line-height: normal;
}
.recruit-flow__arrow {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.recruit-flow__arrow img {
  width: min(0.462962963vw, 7px);
  height: min(0.7936507937vw, 12px);
}

@media (max-width: 768px) {
  .recruit-table {
    padding-top: 10.6666666667vw;
  }
  .recruit-table__inner {
    width: calc(100% - 10.6666666667vw);
    gap: 2.1333333333vw;
  }
  .recruit-table__row {
    flex-direction: column;
    border-radius: 2.6666666667vw;
  }
  .recruit-table__label {
    width: 100%;
    padding: 4.2666666667vw 5.3333333333vw;
    font-size: 3.7333333333vw;
    line-height: 1.6;
    border-radius: 2.6666666667vw 2.6666666667vw 0 0;
  }
  .recruit-table__value {
    border-radius: 0 0 2.6666666667vw 2.6666666667vw;
    padding: 4.2666666667vw 5.3333333333vw;
    font-size: 3.7333333333vw;
    line-height: 1.6;
    letter-spacing: 0.1493333333vw;
  }
  .recruit-table__value p + p {
    margin-top: 5.3333333333vw;
  }
  .recruit-table__value ul {
    padding-left: 5.3333333333vw;
  }
  .recruit-flow {
    padding-top: 21.3333333333vw;
  }
  .recruit-flow__inner {
    width: calc(100% - 10.6666666667vw);
    gap: 10.6666666667vw;
  }
  .recruit-flow__heading {
    gap: 3.2vw;
  }
  .recruit-flow__heading-label {
    font-size: 3.7333333333vw;
  }
  .recruit-flow__heading-title {
    font-size: 7.4666666667vw;
  }
  .recruit-flow__steps {
    gap: 4.2666666667vw;
  }
  .recruit-flow__row {
    flex-direction: column;
    gap: 2.1333333333vw;
  }
  .recruit-flow__step {
    width: 100%;
  }
  .recruit-flow__step-badge {
    left: 2.1333333333vw;
    padding: 1.0666666667vw 3.7333333333vw;
    font-size: 3.4666666667vw;
    border-radius: 1.0666666667vw;
  }
  .recruit-flow__step-box {
    margin-top: 3.2vw;
    height: 26.6666666667vw;
    border-radius: 2.1333333333vw;
  }
  .recruit-flow__step-text {
    font-size: 3.7333333333vw;
  }
  .recruit-flow__arrow {
    transform: rotate(90deg);
  }
  .recruit-flow__arrow img {
    width: 1.8666666667vw;
    height: 3.2vw;
  }
}
body.faq-page {
  background: linear-gradient(to bottom, #fff 0%, rgba(90, 90, 159, 0.12) 30%, rgba(90, 90, 159, 0.18) 100%);
}

.faq-content {
  position: relative;
  z-index: 1;
  max-width: 1206px;
  width: calc(100% - min(5.291005291vw, 80px));
  margin: 0 auto;
  padding-bottom: 0;
  display: flex;
  flex-direction: column;
  gap: min(10.582010582vw, 160px);
}

.faq-section {
  display: flex;
  flex-direction: column;
  gap: min(5.291005291vw, 80px);
}
.faq-section__title {
  background: linear-gradient(to right, #5a5a9f, #c54f8f);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(3.3068783069vw, 50px);
  line-height: normal;
  width: fit-content;
}
.faq-section__list {
  display: flex;
  flex-direction: column;
  gap: min(1.3227513228vw, 20px);
}

.faq-item {
  border-radius: min(0.9259259259vw, 14px);
  overflow: hidden;
}
.faq-item__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: min(1.9841269841vw, 30px);
  background: #fff;
  border: none;
  border-radius: min(0.9259259259vw, 14px);
  cursor: pointer;
  text-align: left;
  transition: border-radius 0.3s;
}
.faq-item__question-inner {
  display: flex;
  align-items: center;
  gap: min(1.3227513228vw, 20px);
}
.faq-item__q {
  font-family: "Lexend", sans-serif;
  font-weight: 600;
  font-size: min(2.380952381vw, 36px);
  line-height: min(2.2486772487vw, 34px);
  letter-spacing: min(0.1904761905vw, 2.88px);
  color: #5a5a9f;
  flex-shrink: 0;
}
.faq-item__question-text {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.5873015873vw, 24px);
  line-height: min(2.2486772487vw, 34px);
  color: #5a5a9f;
}
.faq-item__toggle {
  flex-shrink: 0;
  width: min(1.455026455vw, 22px);
  height: min(1.455026455vw, 22px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.faq-item__icon-minus {
  display: none;
}
.faq-item__icon-plus {
  display: block;
}
.faq-item__answer {
  height: 0;
  overflow: hidden;
}
.faq-item__answer-inner {
  padding: 0 min(1.9841269841vw, 30px) min(1.9841269841vw, 30px) min(5.291005291vw, 80px);
  background: #fff;
  border-radius: 0 0 min(0.9259259259vw, 14px) min(0.9259259259vw, 14px);
}
.faq-item__answer-inner p {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: min(1.1904761905vw, 18px);
  line-height: min(2.2486772487vw, 34px);
  color: #000;
}
.faq-item.is-open .faq-item__question {
  border-radius: min(0.9259259259vw, 14px) min(0.9259259259vw, 14px) 0 0;
}
.faq-item.is-open .faq-item__icon-plus {
  display: none;
}
.faq-item.is-open .faq-item__icon-minus {
  display: block;
}

@media (max-width: 768px) {
  .faq-content {
    width: calc(100% - 10.6666666667vw);
    padding-top: 10.6666666667vw;
    gap: 16vw;
  }
  .faq-section {
    gap: 8vw;
  }
  .faq-section__title {
    font-size: 7.4666666667vw;
  }
  .faq-section__list {
    gap: 3.2vw;
  }
  .faq-item {
    border-radius: 2.6666666667vw;
  }
  .faq-item__question {
    padding: 4.2666666667vw;
    border-radius: 2.6666666667vw;
  }
  .faq-item__question-inner {
    gap: 3.2vw;
  }
  .faq-item__q {
    font-size: 5.8666666667vw;
    line-height: 5.8666666667vw;
    letter-spacing: 0.4vw;
  }
  .faq-item__question-text {
    font-size: 3.7333333333vw;
    line-height: 1.5;
  }
  .faq-item__toggle {
    width: 4.8vw;
    height: 4.8vw;
  }
  .faq-item__answer-inner {
    padding: 0 4.2666666667vw 4.2666666667vw 12.8vw;
    border-radius: 0 0 2.6666666667vw 2.6666666667vw;
  }
  .faq-item__answer-inner p {
    font-size: 3.4666666667vw;
    line-height: 1.7;
  }
  .faq-item.is-open .faq-item__question {
    border-radius: 2.6666666667vw 2.6666666667vw 0 0;
  }
}

/*# sourceMappingURL=app.css.map */
