@charset "UTF-8";
html {
  max-width: 100%;
  overflow-x: clip;
}
@media screen and (min-width: 1440px) {
  html {
    font-size: 16px;
  }
}
@media screen and (min-width: 767.9px) and (max-width: 1440px) {
  html {
    font-size: calc(100vw * 16 / 1440);
  }
}
@media screen and (min-width: 390px) and (max-width: 767.9px) {
  html {
    font-size: 16px;
  }
}
@media screen and (max-width: 389px) {
  html {
    font-size: calc(100vw * 16 / 390);
  }
}

body {
  font-family: "fot-tsukumin-pr6n", sans-serif;
  max-width: 100%;
  overflow-x: clip;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
   -ms-text-size-adjust: 100%;
       text-size-adjust: 100%;
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden;
  }
}
a[href^="tel:"] {
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  a[href^="tel:"] {
    pointer-events: auto;
  }
}

a {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
a:hover {
  opacity: 0.7;
}

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

/* Remove default padding */
ul,
ol {
  padding: 0;
}

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

/* Set core root defaults */
html {
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
}

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

/* Remove list styles on ul, ol elements with a class attribute */
ul,
ol {
  list-style: none;
}

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

a {
  text-decoration: none;
}

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

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

/* Blur images when they have no alt attribute */
/* フォームリセット */
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

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

.top-hero {
  height: 100lvh !important;
  min-height: 100svh !important;
  overflow: hidden;
  overflow: clip;
  background-image: url(../img/top-hero_bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .top-hero {
    height: 100svh !important;
    background-image: url(../img/top-hero_bg-sp.jpg);
  }
}

.top-hero__inner {
  height: inherit;
}

.top-hero__content {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  z-index: 10;
}

.top-hero__title {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 1.5625rem 3.75rem;
}
@media screen and (max-width: 767.9px) {
  .top-hero__title {
    padding: 8.4375rem 2.5rem 5.125rem;
    width: 100%;
    height: inherit;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.top-hero__title::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 0;
  background-color: #fff;
  -webkit-filter: blur(3.75rem);
          filter: blur(3.75rem);
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .top-hero__title::before {
    display: none;
  }
}

.top-hero__title-main {
  display: block;
  font-size: 5.8125rem;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
  background: -webkit-linear-gradient(-90deg, #2D2D2D, #939393);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1.7204301075;
}
@media screen and (max-width: 767.9px) {
  .top-hero__title-main {
    font-size: 3rem;
    line-height: 1.0833333333;
    -moz-text-align-last: left;
         text-align-last: left;
  }
}
.top-hero__title-main span {
  color: #386C95;
  background: none;
  -webkit-text-fill-color: #386C95;
  -webkit-background-clip: border-box;
  background-clip: border-box;
}

.top-hero__title-main > .top-hero__word-new,
.top-hero__title-main > span {
  display: inline-block;
  will-change: transform, opacity;
}

.top-hero__title-main > .top-hero__word-new {
  color: inherit;
  background: inherit;
  -webkit-text-fill-color: inherit;
  -webkit-background-clip: text;
  background-clip: text;
}

.top-hero__title-sub {
  margin-top: -1rem;
  font-weight: 400;
  display: block;
  font-size: 2.3125rem;
  color: #2D2D2D;
  line-height: 1.7297297297;
}
@media screen and (max-width: 767.9px) {
  .top-hero__title-sub {
    font-size: 1.3125rem;
    line-height: 1.5238095238;
    text-align: right;
  }
}

.top-hero__movie {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 0;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .top-hero__movie {
    top: 60%;
  }
}

.top-hero__movie-video {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: opacity 0.8s ease;
  transition: opacity 0.8s ease;
}
.top-hero__movie-video.is-visible {
  opacity: 1;
}
@media (prefers-reduced-motion: reduce) {
  .top-hero__movie-video {
    -webkit-transition-duration: 0.35s;
            transition-duration: 0.35s;
  }
}
.top-hero__movie-video--earth {
  z-index: 0;
  width: 43.75rem;
  height: 43.75rem;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 767.9px) {
  .top-hero__movie-video--earth {
    width: 20rem;
    height: 20rem;
  }
}
.top-hero__movie-video--fire {
  z-index: 1;
  width: 37.5vw;
  max-width: 28.125rem;
  aspect-ratio: 375/730;
  -webkit-transform: translate(-50%, -55%) rotate(30deg);
          transform: translate(-50%, -55%) rotate(30deg);
}
@media screen and (max-width: 767.9px) {
  .top-hero__movie-video--fire {
    width: 58vw;
    max-width: 15rem;
    -webkit-transform: translate(-35%, -65%) rotate(30deg);
            transform: translate(-35%, -65%) rotate(30deg);
  }
}

.top-hero__glass {
  position: absolute;
  inset: 1.875rem;
  z-index: -1;
  border-radius: 0.5rem;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.01) 0%, rgba(255, 255, 255, 0.01) 38%, rgba(255, 255, 255, 0.01) 100%);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-bottom-color: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(0.3px) saturate(1);
  -webkit-backdrop-filter: blur(0.3px) saturate(1);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
}
@media screen and (max-width: 767.9px) {
  .top-hero__glass {
    inset: 6.5625rem 0.625rem 2.625rem 0.625rem;
    background-image: linear-gradient(160deg, rgba(255, 255, 255, 0.28) 0%, rgba(255, 255, 255, 0.06) 55%, rgba(255, 255, 255, 0.02) 100%);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
}

.top-about {
  background-image: url(../img/top-about_bg.jpg);
  background-size: contain;
  background-position: center, top;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .top-about {
    background-image: url(../img/deco_earth.png);
    background-size: 46.875rem auto;
    background-position: center calc(50% + 2.1875rem);
  }
}

.top-about__inner {
  padding-top: 8.125rem;
  padding-bottom: 7.1875rem;
  max-width: 73.75rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .top-about__inner {
    padding: 2.5rem 1.5625rem;
  }
}

.top-about__subtitle {
  margin-top: 6.25rem;
  font-size: 4rem;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: 0.02em;
  text-align: center;
  color: #2B2B2B;
  text-align: center;
  font-weight: 600;
}
@media screen and (max-width: 767.9px) {
  .top-about__subtitle {
    margin-top: 3.125rem;
    font-size: 2.25rem;
    letter-spacing: 0;
    line-height: 1.22;
  }
}

.top-about__text-wrap {
  margin-top: 2.9375rem;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .top-about__text-wrap {
    margin-top: 2.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 1.25rem;
    max-width: 100%;
  }
}

.top-about__text {
  font-size: 3.125rem;
  line-height: 1.08;
  letter-spacing: 0.04em;
  color: #2B2B2B;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
.top-about__text .top-about__word-en {
  font-size: 6rem;
  font-weight: 600;
  color: #2B2B2B;
  letter-spacing: 0.02em;
  font-family: "Cormorant Garamond", serif;
  line-height: 1.2;
}
.top-about__text .top-about__word-ja {
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  color: inherit;
  font-family: inherit;
  font-weight: inherit;
}
@media screen and (max-width: 767.9px) {
  .top-about__text {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 2.25rem;
    line-height: 1.1666666667;
    letter-spacing: 0.04em;
  }
  .top-about__text .top-about__word-en {
    font-size: 4rem;
    letter-spacing: 0.02em;
  }
}

.top-about__word-en,
.top-about__word-ja {
  display: inline-block;
  will-change: transform, opacity;
}

.top-about__text:nth-child(1) {
  gap: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .top-about__text:nth-child(1) {
    gap: 1.5rem;
  }
}

.top-about__text:nth-child(2) {
  margin-top: -0.25rem;
  margin-left: 2.5rem;
  gap: 1.5625rem;
}
@media screen and (max-width: 767.9px) {
  .top-about__text:nth-child(2) {
    margin-top: 2.5rem;
    margin-left: 0;
    gap: 1.5rem;
  }
}

.top-about__text:nth-child(3) {
  margin-top: -1rem;
  margin-left: 12.6875rem;
  gap: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .top-about__text:nth-child(3) {
    margin-top: 7.3125rem;
    margin-left: 0;
    gap: 1.5rem;
  }
}

.top-about__description {
  margin-top: 3.5625rem;
  max-width: 42.5625rem;
  margin-inline: auto;
  text-align: center;
  font-size: 1.125rem;
  letter-spacing: 0.07em;
  line-height: 2.2222222222;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .top-about__description {
    max-width: 31.25rem;
    margin-top: 2.5rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.015em;
    text-align: left;
  }
}

.top-about__btn-wrap {
  margin-top: 11.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767.9px) {
  .top-about__btn-wrap {
    margin-top: 2.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.25rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.top-about__btn {
  display: block;
  max-width: 35.3125rem;
  width: 100%;
  border-radius: 0.5rem;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
  font-size: 1.75rem;
  font-family: "Cormorant Garamond", serif;
  line-height: 1.9285714286;
  letter-spacing: 0.04em;
  color: #2B2B2B;
  font-weight: 600;
  padding: 3.625rem 3.75rem;
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.2);
  -webkit-transition: background-color 0.3s ease, color 0.3s ease, opacity 0.3s ease;
  transition: background-color 0.3s ease, color 0.3s ease, opacity 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .top-about__btn {
    max-width: 31.25rem;
    font-size: 1.125rem;
    -webkit-box-shadow: 0 0 0.875rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 0.875rem rgba(117, 117, 117, 0.25);
    line-height: 1.8055555556;
    padding: 1.90625rem 1.875rem;
  }
}
.top-about__btn::before {
  position: absolute;
  content: "";
  width: 4.25rem;
  height: 1.875rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 3.75rem;
  background-image: url(../img/icon_arrow-gray.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .top-about__btn::before {
    width: 2.5rem;
    height: 1.125rem;
    right: 2.25rem;
  }
}
.top-about__btn:hover {
  background-color: #2B2B2B;
  color: #fff;
  opacity: 1;
}
.top-about__btn:hover::before {
  background-image: url(../img/icon_arrow-white.svg);
}

.top-business {
  background-color: #F5F5F5;
}

.top-business__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 5.375rem;
  padding-bottom: 19.4375rem;
}
@media screen and (max-width: 767.9px) {
  .top-business__inner {
    padding: 2.5rem 1.5625rem 3.75rem;
  }
}

.top-business__subtitle {
  margin-top: 7.5rem;
  font-size: 6rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #2B2B2B;
  line-height: 1.21;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 767.9px) {
  .top-business__subtitle {
    margin-top: 1.875rem;
    font-size: 2.25rem;
  }
}

.top-business__detail-wrap {
  margin-top: 5.1875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail-wrap {
    margin-top: 2.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    margin-inline: auto;
    width: 100%;
    max-width: clamp(19.4375rem, 19.4375rem + 14.625rem * (100vw - 24.375rem) / 23.625rem, 34.0625rem);
  }
}
.top-business__detail-wrap::before {
  position: absolute;
  content: "";
  width: 80.1875rem;
  height: 60.375rem;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-image: url(../img/deco_vortex.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail-wrap::before {
    display: none;
  }
}

.top-business__detail {
  max-width: 34.1875rem;
  width: 100%;
  height: 34.1875rem;
  border-radius: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail {
    width: clamp(14.5625rem, 14.5625rem + 7.3125rem * (100vw - 24.375rem) / 23.625rem, 21.875rem);
    max-width: none;
    aspect-ratio: 1;
    height: auto;
    gap: 0.8125rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -ms-flex-item-align: start;
        align-self: flex-start;
    z-index: 1;
  }
}

.top-business__detail + .top-business__detail {
  margin-left: -5rem;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail + .top-business__detail {
    margin-left: 0;
    margin-top: clamp(-3.9375rem, -2.625rem + -1.3125rem * (100vw - 24.375rem) / 23.625rem, -2.625rem);
    -ms-flex-item-align: end;
        align-self: flex-end;
    z-index: 2;
  }
}

.top-business__fire {
  position: absolute;
  top: calc(50% - 13.75rem);
  left: 0;
  right: 0;
  z-index: 5;
  width: 12.5rem;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  aspect-ratio: 375/730;
  margin-inline: auto;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
}
@media screen and (max-width: 767.9px) {
  .top-business__fire {
    top: calc(50% - 7.5rem);
    left: 5rem;
    width: 5.625rem;
    z-index: 3;
  }
}

.top-business__fire-video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  --business-fire-rotate: 0deg;
}
@media screen and (max-width: 767.9px) {
  .top-business__fire-video {
    --business-fire-rotate: 20deg;
  }
}

.top-business__detail-title {
  font-size: 4rem;
  color: #386C95;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail-title {
    font-size: clamp(1.688rem, 0.847rem + 3.448vw, 2.5rem);
    line-height: 1.22;
  }
}

.top-business__detail-text {
  font-size: 3rem;
  color: #2B2B2B;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  line-height: 1.3;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail-text {
    font-size: clamp(1.281rem, 0.926rem + 1.459vw, 1.625rem);
  }
}

.top-business__detail-text-sub {
  font-size: 1.5rem;
  line-height: 2.25;
  letter-spacing: 0.04em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .top-business__detail-text-sub {
    font-size: clamp(0.625rem, 0.237rem + 1.592vw, 1rem);
    line-height: 2.3;
  }
}

.js-pin {
  position: relative;
  max-width: 100%;
}

.js-pin__inner {
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
  overflow: clip;
  max-width: 100%;
}

.js-fade-overlay {
  position: relative;
  max-width: 100%;
}

.js-fade-overlay__inner {
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
  overflow: clip;
  -webkit-transform-origin: 50% 50%;
          transform-origin: 50% 50%;
  will-change: opacity, transform;
  max-width: 100%;
}

.pin-spacer {
  max-width: 100% !important;
  overflow: hidden !important;
}

.top-scroll-sequence,
.js-scroll-sequence {
  position: relative;
  max-width: 100%;
}

.js-scroll-sequence.is-scroll-sequence-active {
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
  overflow: clip;
}

.top-scroll-sequence.is-scroll-sequence-active {
  background-color: #0f1416;
}

.js-scroll-sequence.is-scroll-sequence-active > .js-sequence-panel {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.js-scroll-sequence.is-scroll-sequence-active > .js-sequence-panel {
  pointer-events: none;
}

.js-scroll-sequence.is-scroll-sequence-active > .js-sequence-base {
  pointer-events: auto;
}

.js-scroll-sequence.is-scroll-sequence-active > .js-sequence-panel .js-fade-overlay__inner {
  pointer-events: auto;
}

.js-crossfade-sequence {
  position: relative;
  max-width: 100%;
}

.js-crossfade-sequence.is-crossfade-sequence-active {
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
  overflow: clip;
}

.js-crossfade-sequence.is-crossfade-sequence-active > .js-crossfade-panel {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.js-crossfade-sequence.is-crossfade-sequence-active > .js-crossfade-base,
.js-crossfade-sequence.is-crossfade-sequence-active > .js-crossfade-panel .js-crossfade-inner {
  pointer-events: auto;
}

.js-crossfade-inner {
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
  overflow: clip;
  -webkit-transform-origin: 50% 50%;
          transform-origin: 50% 50%;
  will-change: opacity, transform;
  max-width: 100%;
}

.split-feature {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767.9px) {
  .split-feature {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: 100%;
    min-height: 0;
  }
}

.split-feature__media {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 36%;
          flex: 0 0 36%;
  max-width: 36%;
  height: 100%;
  overflow: hidden;
  -ms-flex-item-align: stretch;
      align-self: stretch;
}
@media screen and (max-width: 767.9px) {
  .split-feature__media {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 clamp(4.5rem, 11vh, 7rem);
            flex: 0 0 clamp(4.5rem, 11vh, 7rem);
    max-width: 100%;
    height: clamp(4.5rem, 11vh, 7rem);
  }
  .split-feature__media picture {
    display: block;
    width: 100%;
    height: 100%;
  }
}

.split-feature__img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top;
     object-position: top;
}
@media screen and (max-width: 767.9px) {
  .split-feature__img {
    -o-object-position: center;
       object-position: center;
  }
}

.split-feature__body {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-image: url(../img/deco_silver.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .split-feature__body {
    height: auto;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    min-height: 0;
  }
}

.split-feature__body-inner {
  width: 100%;
  max-width: 40.8125rem;
  margin-inline: auto;
  max-height: 100%;
  padding-top: clamp(2rem, 7vh, 5rem);
  padding-bottom: clamp(2.5rem, 8vh, 6.875rem);
}
@media screen and (max-width: 767.9px) {
  .split-feature__body-inner {
    max-width: 33.5rem;
    padding-top: clamp(0.625rem, 2.2vh, 1.125rem);
    padding-bottom: clamp(0.875rem, 3.2vh, 1.5rem);
    padding-inline: 1.125rem;
  }
}

.split-feature__label {
  font-size: clamp(1.5rem, 4vh, 2rem);
  text-align: center;
  color: #ADADAD;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .split-feature__label {
    font-size: clamp(1.5rem, 4vh, 2rem);
  }
}

.split-feature__title {
  font-size: clamp(4rem, 11vh, 6rem);
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #2B2B2B;
  line-height: 1.22;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .split-feature__title {
    font-size: clamp(2.5rem, 7vh, 3rem);
  }
}

.split-feature__subtitle {
  font-size: clamp(1.5rem, 4vh, 2rem);
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #D7D7D7;
  line-height: 1.22;
  text-align: center;
  padding-bottom: clamp(1.5rem, 5vh, 3.75rem);
  border-bottom: 1px solid rgba(169, 169, 169, 0.7);
}
@media screen and (max-width: 767.9px) {
  .split-feature__subtitle {
    font-size: clamp(1.375rem, 4vh, 1.75rem);
    padding-bottom: clamp(0.875rem, 3.2vh, 1.5rem);
  }
}

.split-feature__desc-wrap {
  margin-top: clamp(2rem, 6vh, 5rem);
}
@media screen and (max-width: 767.9px) {
  .split-feature__desc-wrap {
    margin-top: clamp(0.75rem, 2.8vh, 1.375rem);
  }
}

.split-feature__text {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .split-feature__text {
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

@media (min-width: 768px) and (max-height: 850px) {
  .split-feature__label {
    line-height: 1.4;
  }
  .split-feature__title {
    line-height: 1.08;
  }
  .split-feature__subtitle {
    line-height: 1.1;
  }
  .split-feature__text {
    font-size: clamp(0.9375rem, 2.2vh, 1.125rem);
    line-height: 2;
  }
}
.top-ma {
  height: 100lvh;
  min-height: 100svh;
  z-index: 1;
}

.top-ma .js-pin__inner {
  height: 100%;
}

.case-studies {
  height: auto;
  background-color: transparent;
  color: #fff;
  z-index: 2;
}

.case-studies__inner {
  background-color: #0f1416;
  height: 100lvh;
  min-height: 100svh;
}

.case-studies__heading {
  position: absolute;
  top: 2.5rem;
  left: 8.125rem;
  z-index: 20;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .case-studies__heading {
    width: 100%;
    top: 2.9375rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    text-align: center;
  }
}

.case-studies__title {
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 6rem;
  line-height: 1.22;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .case-studies__title {
    font-size: 3.375rem;
    line-height: 1.2;
  }
}

.case-studies__subtitle {
  color: #fff;
  font-size: 1.6875rem;
  letter-spacing: 0.07em;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .case-studies__subtitle {
    margin-top: 0.375rem;
    font-size: 1.125rem;
    letter-spacing: 0.07em;
  }
}

.case-studies__cards {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767.9px) {
  .case-studies__cards {
    display: block;
    position: relative;
  }
}

.case-studies__card {
  position: relative;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 16.875%;
          flex: 0 0 16.875%;
  height: 100%;
  overflow: hidden;
  isolation: isolate;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .case-studies__card {
    position: absolute;
    inset: 0;
    height: 100%;
    opacity: 0;
  }
}

@media screen and (max-width: 767.9px) {
  .case-studies__card.is-active {
    opacity: 1;
  }
}

.case-studies__bg,
.case-studies__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.case-studies__bg {
  z-index: 1;
}
.case-studies__bg img {
  width: 100%;
  height: 100%;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: left;
     object-position: left;
}

.case-studies__card:last-child .case-studies__bg img {
  -o-object-position: right;
     object-position: right;
}

.case-studies__overlay {
  z-index: 2;
}

.case-studies__body {
  position: absolute;
  left: 6.25rem;
  bottom: 10rem;
  z-index: 4;
  width: 39vw;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  -webkit-transition: opacity 0.5s ease, visibility 0s linear 0s;
  transition: opacity 0.5s ease, visibility 0s linear 0s;
}
.case-studies__body::before {
  position: absolute;
  content: "";
  width: 100%;
  max-width: calc(100% - (6rem + 2.5rem));
  height: 1px;
  bottom: -4.6875rem;
  left: 0;
  background-color: #fff;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .case-studies__body::before {
    max-width: calc(100% - (6rem + 2.5rem));
    bottom: -4.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .case-studies__body {
    left: 1.5625rem;
    right: 1.5625rem;
    width: auto;
  }
}

.case-studies__card:not(.is-active) .case-studies__body {
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.5s ease, visibility 0s linear 0.5s;
  transition: opacity 0.5s ease, visibility 0s linear 0.5s;
}

.case-studies__logo-box {
  width: 13.0625rem;
}
.case-studies__logo-box img {
  width: 100%;
  height: auto;
  display: block;
}
@media screen and (max-width: 767.9px) {
  .case-studies__logo-box {
    width: 8.75rem;
  }
}

.case-studies__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 1.875rem;
  margin-top: 1.75rem;
}
@media screen and (max-width: 767.9px) {
  .case-studies__row {
    margin-top: 2rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 1.25rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.case-studies__result {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin: 0;
  font-size: 2.5rem;
  line-height: 1;
  letter-spacing: -0.07em;
}
@media screen and (max-width: 767.9px) {
  .case-studies__result {
    font-size: 1.875rem;
  }
}

.case-studies__result.case-studies__result--long {
  letter-spacing: 0;
  font-size: 1.625rem;
  line-height: 1.4;
}
@media screen and (max-width: 767.9px) {
  .case-studies__result.case-studies__result--long {
    font-size: 1.25rem;
  }
}

.case-studies__more.btn {
  margin-top: 1.5625rem;
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .case-studies__more.btn {
    position: absolute;
    left: 0;
    bottom: -8.75rem;
    z-index: 5;
    width: 11.25rem;
    margin-inline: initial;
    margin-top: 0;
  }
}

.case-studies__result-number {
  font-family: "fot-tsukumin-pr6n", sans-serif;
  font-size: 4.5rem;
  margin-inline: 0.625rem;
  margin-bottom: -0.3125rem;
  line-height: 1;
}
@media screen and (max-width: 767.9px) {
  .case-studies__result-number {
    font-size: 3.3125rem;
    margin-inline: 0.3125rem;
  }
}

.case-studies__number {
  position: absolute;
  right: 3rem;
  bottom: 0;
  z-index: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.5rem;
  font-size: 6rem;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .case-studies__number {
    gap: 1.4375rem;
    right: 1.5625rem;
    bottom: 2.1875rem;
    font-size: 4rem;
  }
}

.top-venture {
  height: auto;
  z-index: 3;
}

.top-venture .js-fade-overlay__inner {
  background-color: #0f1416;
  height: 100lvh;
  min-height: 100svh;
}
@media screen and (max-width: 767.9px) {
  .top-venture .js-fade-overlay__inner {
    height: auto;
    min-height: 100svh;
  }
}

@media screen and (max-width: 767.9px) {
  .top-scroll-sequence.is-scroll-sequence-active > .js-sequence-fade-target .js-fade-overlay__inner {
    height: 100%;
    min-height: 0;
  }
  .top-scroll-sequence.is-scroll-sequence-active > .js-sequence-fade-target .split-feature {
    height: 100%;
    min-height: 0;
  }
  .top-scroll-sequence.is-scroll-sequence-active > .js-sequence-fade-target .split-feature__body {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    min-height: 0;
  }
}
.top-news {
  background-color: #161A1C;
}

.top-news__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .top-news__inner {
    max-width: 34.375rem;
    padding: 2.5rem 1.5625rem;
  }
}

.top-news__body {
  margin-top: 3.125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 12rem;
}
@media screen and (max-width: 767.9px) {
  .top-news__body {
    margin-top: 1.875rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
}

.top-news__lead {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 17.5rem;
          flex: 0 0 17.5rem;
}
@media screen and (max-width: 767.9px) {
  .top-news__lead {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
  }
}

.top-news__heading {
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  color: #fff;
  line-height: 1.22;
}
@media screen and (max-width: 767.9px) {
  .top-news__heading {
    font-size: 2.25rem;
  }
}

.top-news__more-wrap {
  width: 100%;
}

.top-news__more.btn {
  margin-top: 2.8125rem;
}
@media screen and (max-width: 767.9px) {
  .top-news__more.btn {
    margin-top: 2.5rem;
  }
}

.top-news__list {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width: 0;
  margin-top: 2.3125rem;
}
@media screen and (max-width: 767.9px) {
  .top-news__list {
    width: 100%;
    margin-top: 1.875rem;
  }
}

.top-news__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.25rem;
  padding-block: 1.4375rem;
  border-bottom: 1px solid rgba(80, 87, 92, 0.7);
}
@media screen and (max-width: 767.9px) {
  .top-news__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0.5rem;
    padding: 1.125rem 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 0.3125rem;
    -webkit-box-shadow: 0 0 0.875rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 0.875rem rgba(117, 117, 117, 0.25);
    position: relative;
  }
  .top-news__item::before {
    position: absolute;
    content: "";
    width: 2.5625rem;
    height: 1.125rem;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 1.5rem;
    background-image: url(../img/icon_arrow-white.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
  }
}

.top-news__meta {
  display: contents;
}
@media screen and (max-width: 767.9px) {
  .top-news__meta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1.25rem;
  }
}

@media screen and (max-width: 767.9px) {
  .top-news__item + .top-news__item {
    margin-top: 1.25rem;
  }
}

.top-news__date {
  font-size: 1rem;
  color: #fff;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767.9px) {
  .top-news__date {
    font-size: 0.8125rem;
  }
}

.top-news__category {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 4.5rem;
  padding: 0.25rem 0.9375rem;
  border-radius: 100vw;
  background-color: #fff;
  color: #2B2B2B;
  font-family: "Cormorant Garamond", serif;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  border: 1px solid #fff;
  -webkit-transition: color 0.3s, background-color 0.3s;
  transition: color 0.3s, background-color 0.3s;
}
@media screen and (max-width: 767.9px) {
  .top-news__category {
    min-width: 3.125rem;
    padding: 0.15625rem 0.625rem;
    font-size: 0.8125rem;
  }
}
.top-news__category:hover {
  color: #fff;
  background-color: #161A1C;
}
@media screen and (max-width: 767.9px) {
  .top-news__category:hover {
    color: #2B2B2B;
    background-color: #fff;
  }
}

.top-news__link {
  font-size: 1rem;
  color: #fff;
  letter-spacing: 0.05em;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
@media screen and (max-width: 767.9px) {
  .top-news__link {
    font-size: 0.875rem;
    line-height: 1.3571428571;
    -webkit-line-clamp: 4;
    max-width: 40vw;
    width: 48vw;
  }
}

.top-create {
  position: relative;
  background-color: #161A1C;
  color: #fff;
  overflow: clip;
}

.top-create__stage {
  position: relative;
  height: 100lvh;
  min-height: 42.5rem;
  overflow: hidden;
  overflow: clip;
}
@media screen and (max-width: 767.9px) {
  .top-create__stage {
    height: 100lvh;
    min-height: 38.75rem;
  }
}

.top-create__media {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: clamp(25.375rem, 25.375rem * 100lvh / 57.5rem, 28.42rem) clamp(29.375rem, 29.375rem * 100lvh / 57.5rem, 32.9rem) clamp(25.375rem, 25.375rem * 100lvh / 57.5rem, 28.42rem);
  -webkit-column-gap: clamp(4.25rem, 4.25rem * 100lvh / 57.5rem, 4.76rem);
     -moz-column-gap: clamp(4.25rem, 4.25rem * 100lvh / 57.5rem, 4.76rem);
          column-gap: clamp(4.25rem, 4.25rem * 100lvh / 57.5rem, 4.76rem);
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  width: clamp(88.625rem, 88.625rem * 100lvh / 57.5rem, 99.26rem);
  height: clamp(73.3125rem, 73.3125rem * 100lvh / 57.5rem, 82.11rem);
  left: 50%;
  top: 0;
  -webkit-transform: translate3d(-50%, 0, 0);
          transform: translate3d(-50%, 0, 0);
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .top-create__media {
    grid-template-columns: clamp(7.375rem, 7.375rem * 100lvh / 43.75rem, 8.1125rem) clamp(8.5rem, 8.5rem * 100lvh / 43.75rem, 9.35rem) clamp(7.375rem, 7.375rem * 100lvh / 43.75rem, 8.1125rem);
    -webkit-column-gap: clamp(0.8125rem, 0.8125rem * 100lvh / 43.75rem, 0.89375rem);
       -moz-column-gap: clamp(0.8125rem, 0.8125rem * 100lvh / 43.75rem, 0.89375rem);
            column-gap: clamp(0.8125rem, 0.8125rem * 100lvh / 43.75rem, 0.89375rem);
    width: clamp(24.875rem, 24.875rem * 100lvh / 43.75rem, 27.3625rem);
    height: clamp(40.3125rem, 40.3125rem * 100lvh / 43.75rem, 44.34375rem);
  }
}

.top-create__col {
  display: grid;
  gap: clamp(3.25rem, 3.25rem * 100lvh / 57.5rem, 3.64rem);
  will-change: transform, gap;
}
@media screen and (max-width: 767.9px) {
  .top-create__col {
    gap: clamp(1.75rem, 1.75rem * 100lvh / 43.75rem, 1.925rem);
  }
}

.top-create__col--left,
.top-create__col--right {
  margin-top: clamp(12.5rem, 12.5rem * 100lvh / 57.5rem, 14rem);
  width: clamp(25.375rem, 25.375rem * 100lvh / 57.5rem, 28.42rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__col--left,
  .top-create__col--right {
    margin-top: clamp(6.875rem, 6.875rem * 100lvh / 43.75rem, 7.5625rem);
    width: clamp(7.375rem, 7.375rem * 100lvh / 43.75rem, 8.1125rem);
  }
}

.top-create__col--center {
  width: clamp(29.375rem, 29.375rem * 100lvh / 57.5rem, 32.9rem);
  gap: clamp(5.25rem, 5.25rem * 100lvh / 57.5rem, 5.88rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__col--center {
    width: clamp(8.5rem, 8.5rem * 100lvh / 43.75rem, 9.35rem);
    gap: clamp(2.1875rem, 2.1875rem * 100lvh / 43.75rem, 2.40625rem);
  }
}

.top-create__image {
  margin: 0;
  position: relative;
  overflow: hidden;
  background-color: #202423;
  width: 100%;
  height: auto;
}

.top-create__image--left-top,
.top-create__image--right-top {
  height: clamp(30.25rem, 30.25rem * 100lvh / 57.5rem, 33.88rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__image--left-top,
  .top-create__image--right-top {
    height: clamp(16.625rem, 16.625rem * 100lvh / 43.75rem, 18.2875rem);
  }
}

.top-create__image--left-bottom,
.top-create__image--right-bottom {
  height: clamp(27.5rem, 27.5rem * 100lvh / 57.5rem, 30.8rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__image--left-bottom,
  .top-create__image--right-bottom {
    height: clamp(15.0625rem, 15.0625rem * 100lvh / 43.75rem, 16.56875rem);
  }
}

.top-create__image--center-top {
  height: clamp(33.5rem, 33.5rem * 100lvh / 57.5rem, 37.52rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__image--center-top {
    height: clamp(18.375rem, 18.375rem * 100lvh / 43.75rem, 20.2125rem);
  }
}

.top-create__image--center-bottom {
  height: clamp(27.5rem, 27.5rem * 100lvh / 57.5rem, 30.8rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__image--center-bottom {
    height: clamp(15.125rem, 15.125rem * 100lvh / 43.75rem, 16.6375rem);
  }
}

.top-create__image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

.top-create__content {
  position: absolute;
  z-index: 2;
  inset: 50% auto auto 50%;
  width: min(76vw, 53.75rem);
  -webkit-transform: translate3d(-50%, -50%, 0);
          transform: translate3d(-50%, -50%, 0);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  pointer-events: auto;
}
@media screen and (max-width: 767.9px) {
  .top-create__content {
    width: 100%;
    inset: 48% auto auto 50%;
  }
}
@media screen and (max-width: 767.9px) and (min-height: 800px) {
  .top-create__content {
    top: clamp(48%, 52vh, 56%);
  }
}

.top-create__lead {
  margin: 0;
  font-size: clamp(1.125rem, 2.1vw, 2.5rem);
  line-height: 1.35;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767.9px) {
  .top-create__lead {
    font-size: 1.25rem;
    line-height: 1.15;
  }
}

.top-create__title {
  margin-top: 1.875rem;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(4.375rem, 7.4vw, 8rem);
  font-weight: 600;
  line-height: 1;
}
@media screen and (max-width: 767.9px) {
  .top-create__title {
    margin-top: 0.8125rem;
    font-size: 3.375rem;
    line-height: 1.15;
  }
}

.top-create__body {
  margin-top: clamp(2.25rem, 6vh, 4.5rem);
}
@media screen and (max-width: 767.9px) {
  .top-create__body {
    margin-top: 2.25rem;
  }
}

.top-create__text {
  font-size: 1.25rem;
  line-height: 2.7;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .top-create__text {
    font-size: 0.8125rem;
    line-height: 1.7692307692;
  }
}

.top-create__btn.btn {
  text-align: left;
}

.top-create.is-completed .top-create__title,
.top-create.is-completed .top-create__lead,
.top-create.is-completed .top-create__body,
.top-create.is-completed .top-create__btn {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-transform: translate3d(0, 0, 0) !important;
          transform: translate3d(0, 0, 0) !important;
}
@media screen and (max-width: 767.9px) {
  .top-create.is-completed .top-create__media {
    width: calc(36.875rem * var(--create-to-scale, 1));
    height: calc(43.9375rem * var(--create-to-scale, 1));
    grid-template-columns: calc(10.5rem * var(--create-to-scale, 1)) calc(12.125rem * var(--create-to-scale, 1)) calc(10.5rem * var(--create-to-scale, 1));
    -webkit-column-gap: calc(1.875rem * var(--create-to-scale, 1));
       -moz-column-gap: calc(1.875rem * var(--create-to-scale, 1));
            column-gap: calc(1.875rem * var(--create-to-scale, 1));
  }
  .top-create.is-completed .top-create__col--left,
  .top-create.is-completed .top-create__col--right {
    margin-top: 0;
    width: calc(10.5rem * var(--create-to-scale, 1));
    gap: calc(2.5rem * var(--create-to-scale, 1));
  }
  .top-create.is-completed .top-create__col--center {
    width: calc(12.125rem * var(--create-to-scale, 1));
    gap: calc(3.125rem * var(--create-to-scale, 1));
  }
  .top-create.is-completed .top-create__image--left-top,
  .top-create.is-completed .top-create__image--right-top {
    height: calc(23.75rem * var(--create-to-scale, 1));
  }
  .top-create.is-completed .top-create__image--left-bottom,
  .top-create.is-completed .top-create__image--right-bottom {
    height: calc(13.9375rem * var(--create-to-scale, 1));
  }
  .top-create.is-completed .top-create__image--center-top {
    height: calc(26.25rem * var(--create-to-scale, 1));
  }
  .top-create.is-completed .top-create__image--center-bottom {
    height: calc(14.5625rem * var(--create-to-scale, 1));
  }
}

.contact-us {
  background-image: url(../img/deco_silver2.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
}
.contact-us::before {
  position: absolute;
  content: "CONTACT";
  font-size: 15.5rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #fff;
  line-height: 1;
  bottom: -2.8125rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (max-width: 767.9px) {
  .contact-us::before {
    font-size: 5.125rem;
    bottom: -0.9375rem;
  }
}

.contact-us__inner {
  max-width: 50rem;
  margin-inline: auto;
  padding-top: 2.5rem;
  padding-bottom: 16.875rem;
}
@media screen and (max-width: 767.9px) {
  .contact-us__inner {
    padding-top: 1.875rem;
    padding-bottom: 5.3125rem;
  }
}

.contact-us__visual {
  width: 12.5rem;
  margin-inline: auto;
  display: block;
  height: auto;
  aspect-ratio: 375/730;
  -o-object-fit: contain;
     object-fit: contain;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .contact-us__visual {
    width: 7.5rem;
  }
}

.contact-us__text {
  margin-top: -1.875rem;
  font-size: 1.25rem;
  letter-spacing: 0.07em;
  text-align: center;
  line-height: 2.4;
  color: #000;
}
@media screen and (max-width: 767.9px) {
  .contact-us__text {
    margin-top: 0;
    font-size: 0.875rem;
    line-height: 2;
  }
}

.contact-us__btn.btn {
  margin-top: 3.125rem;
  margin-inline: auto;
  max-width: 15.8125rem;
  font-size: 1.5rem;
  background-color: #333333;
  padding: 0.625rem 1.25rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .contact-us__btn.btn {
    margin-top: 2.5rem;
    max-width: 12rem;
    font-size: 1rem;
    padding: 0.625rem 0.9375rem;
  }
}
.contact-us__btn.btn::before {
  width: 4.25rem;
  height: 1.875rem;
  right: 0.625rem;
}
@media screen and (max-width: 767.9px) {
  .contact-us__btn.btn::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.5rem;
  }
}

.company__message {
  position: relative;
  padding-bottom: 5.625rem;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .company__message {
    padding-bottom: 1.875rem;
  }
}

.company__message-hero.js-parallax-section {
  position: relative;
  height: 48.125rem;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .company__message-hero.js-parallax-section {
    height: clamp(17.1875rem, 15rem + 9vw, 20rem);
  }
}

.company__message-bg.js-parallax-bg {
  position: absolute;
  inset: -12% 0;
  background-image: url(../img/deco_black.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  will-change: transform;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  z-index: 0;
}
@media screen and (max-width: 767.9px) {
  .company__message-bg.js-parallax-bg {
    inset: -10% 0;
    background-image: url(../img/deco_black-sp.jpg);
  }
}

.company__message-ceo {
  position: absolute;
  left: max(1.25rem, (100vw - 90rem) / 2 + 3.5rem);
  bottom: 0;
  width: 42.5625rem;
  z-index: 1;
}
.company__message-ceo img {
  width: 100%;
  display: block;
}
@media screen and (max-width: 767.9px) {
  .company__message-ceo {
    width: min(78vw, clamp(15.25rem, 12.875rem + 10vw, 18.25rem));
    left: 0;
    -webkit-transform: none;
            transform: none;
  }
}

.company__message-card {
  position: relative;
  z-index: 2;
  isolation: isolate;
  width: min(100% - 2.5rem, 58.125rem);
  margin-top: -15.3125rem;
  margin-left: auto;
  background-color: transparent;
  padding: 7.5rem 6.25rem 3.75rem;
}
@media screen and (min-width: 1440px) {
  .company__message-card {
    width: 58.125rem;
    margin-left: calc((100vw - 90rem) / 2 + 31.875rem);
  }
}
.company__message-card::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset-block: 0;
  inset-inline-start: 0;
  inset-inline-end: calc(50% - 50vw);
  background-color: #FAFAFA;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .company__message-card {
    margin-top: -3.4375rem;
    width: calc(100% - 2rem);
    margin-left: 2.1875rem;
    padding: 1.875rem 2.1875rem 1.875rem 1.875rem;
    background-color: #FAFAFA;
    -webkit-box-shadow: 0 0 0.875rem rgba(0, 0, 0, 0.13);
            box-shadow: 0 0 0.875rem rgba(0, 0, 0, 0.13);
  }
  .company__message-card::before {
    display: none;
  }
}

.company__message-card-inner {
  max-width: 45.625rem;
}
@media screen and (max-width: 767.9px) {
  .company__message-card-inner {
    max-width: 31.25rem;
    margin-inline: auto;
  }
}

.company__message-title {
  margin-top: 5rem;
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  line-height: 1.22;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .company__message-title {
    margin-top: 1.25rem;
    font-size: 2.25rem;
  }
}

.company__message-body {
  margin-top: 5rem;
  max-width: 36.25rem;
}
.company__message-body p {
  margin: 0;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
.company__message-body p + p {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .company__message-body {
    margin-top: 1.5rem;
    max-width: 100%;
  }
  .company__message-body p {
    font-size: 0.8125rem;
    line-height: 2.3076923077;
    letter-spacing: 0.03em;
  }
  .company__message-body p + p {
    margin-top: 1.875rem;
  }
}

.company__message-signature {
  margin-top: 11.75rem;
  margin-left: auto;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
@media screen and (max-width: 767.9px) {
  .company__message-signature {
    margin-top: 1.25rem;
  }
}

.company__message-signature-name {
  font-size: 1.375rem;
  line-height: 1.7727272727;
  letter-spacing: 0.07em;
  color: #2B2B2B;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-left: auto;
}
@media screen and (max-width: 767.9px) {
  .company__message-signature-name {
    font-size: 0.8125rem;
    line-height: 1.8461538462;
  }
}

.company__message-signature-img {
  margin-left: auto;
  margin-top: 0.625rem;
  width: 12.5rem;
}
@media screen and (max-width: 767.9px) {
  .company__message-signature-img {
    margin-top: 0;
    width: 6.25rem;
  }
}

.company__profile-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 5.625rem;
  padding-bottom: 8.125rem;
}
@media screen and (max-width: 767.9px) {
  .company__profile-inner {
    max-width: 34.375rem;
    padding-top: 1.875rem;
    padding-bottom: 3.125rem;
    padding-inline: 1.5625rem;
  }
}

.company__profile-label {
  font-size: 6rem;
  font-weight: 600;
  line-height: 1.22;
  color: #2B2B2B;
  font-family: "Cormorant Garamond", serif;
  text-transform: uppercase;
}
@media screen and (max-width: 767.9px) {
  .company__profile-label {
    font-size: 2.25rem;
  }
}

.company__profile-title.title {
  margin-top: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .company__profile-title.title {
    margin-top: 1rem;
  }
}

.company__profile-img-wrap {
  margin-top: 3.75rem;
  aspect-ratio: 1180/500;
}
@media screen and (max-width: 767.9px) {
  .company__profile-img-wrap {
    margin-top: 1.875rem;
    width: 100vw;
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    aspect-ratio: 390/220;
  }
}

.company__profile-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.company__profile-list {
  margin-top: 5rem;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .company__profile-list {
    margin-top: 2.5rem;
  }
}

.company__profile-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.25rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: solid 0.0625rem rgba(43, 43, 43, 0.7);
  padding-bottom: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .company__profile-item {
    padding-bottom: 0.625rem;
  }
}

.company__profile-item + .company__profile-item {
  margin-top: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .company__profile-item + .company__profile-item {
    margin-top: 0.625rem;
  }
}

.company__profile-item-label {
  min-width: 30.5rem;
  padding-left: 1.75rem;
  position: relative;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  line-height: 1.8;
}
@media screen and (max-width: 767.9px) {
  .company__profile-item-label {
    min-width: 6.875rem;
    font-size: 0.8125rem;
    padding-left: 0.875rem;
  }
}
.company__profile-item-label::before {
  position: absolute;
  content: "";
  width: 0.75rem;
  height: 0.75rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .company__profile-item-label::before {
    width: 0.375rem;
    height: 0.375rem;
  }
}

.company__profile-item-value {
  font-size: 1rem;
  letter-spacing: 0.05em;
  line-height: 2;
  word-break: break-all;
}
@media screen and (max-width: 767.9px) {
  .company__profile-item-value {
    font-size: 0.8125rem;
    line-height: 1.45;
  }
}

@media screen and (max-width: 767.9px) {
  .company__profile-item-value.company__profile-item-value--small {
    font-size: 0.6875rem;
    line-height: 2;
  }
}

.company__history {
  --history-item-step-pc: 10.9375rem;
  --history-item-step-sp: 5.625rem;
  position: relative;
  background-color: #161A1C;
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
}

@supports not (height: 100lvh) {
  .company__history {
    height: 100vh;
    min-height: 100vh;
  }
}
.company__history-inner {
  height: 100%;
  min-height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
@media screen and (max-width: 767.9px) {
  .company__history-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.company__history-pin {
  height: 100%;
}

.company__history-main {
  max-width: 51.875rem;
  width: 67%;
  margin-inline: auto;
  background-color: #161A1C;
  color: #fff;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 8.125rem clamp(1.5rem, 4.2vw, 3.5rem) clamp(2.125rem, 4.2dvh, 3.875rem) clamp(1.875rem, 6.2vw, 5.25rem);
}
@media screen and (max-width: 767.9px) {
  .company__history-main {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    max-width: 34.375rem;
    margin-inline: auto;
    width: 100%;
    height: calc(100% - clamp(10.625rem, 27dvh, 14.75rem));
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 4.375rem 1.5625rem 2.5rem;
  }
}

.company__history-track-viewport {
  width: min(100%, 53.75rem);
  margin-right: auto;
  height: 43.75rem;
  position: relative;
  overflow: visible;
}
@media screen and (max-width: 767.9px) {
  .company__history-track-viewport {
    width: 100%;
    margin-inline: auto;
    height: calc(9rem + 9.75rem * 3);
  }
}

.company__history-track {
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  height: 100%;
}

.company__history-item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 9rem;
  display: grid;
  grid-template-columns: 9rem minmax(0, 1fr);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  will-change: transform, opacity;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
@media screen and (max-width: 767.9px) {
  .company__history-item {
    height: 5rem;
  }
}

.company__history-dot {
  width: 9rem;
  height: 9rem;
  border-radius: 50%;
  background: #1D2021;
  will-change: transform, opacity;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
@media screen and (max-width: 767.9px) {
  .company__history-dot {
    width: 5rem;
    height: 5rem;
  }
}

.company__history-item:nth-child(even) .company__history-dot {
  background: #313437;
}

.company__history-item-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: 0;
  will-change: transform, opacity;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  margin-left: -6.25rem;
}

.company__history-year {
  font-size: 2.25rem;
  line-height: 1;
  letter-spacing: 0.05em;
  color: #fff;
  min-width: 8.4375rem;
}
@media screen and (max-width: 767.9px) {
  .company__history-year {
    font-size: 0.9375rem;
    min-width: 3.75rem;
  }
}

.company__history-line {
  width: 5.375rem;
  height: 0.0625rem;
  margin-inline: 2.5rem;
  background-color: #fff;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .company__history-line {
    width: 1.875rem;
    margin-inline: 1.25rem;
  }
}

.company__history-event {
  font-size: 1.375rem;
  letter-spacing: 0.09em;
  color: #fff;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .company__history-event {
    font-size: 0.75rem;
  }
}

.company__history-visual {
  width: 33%;
  position: relative;
  height: 100%;
}
@media screen and (max-width: 767.9px) {
  .company__history-visual {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 100%;
    height: 11.25rem;
    z-index: 10;
  }
}
.company__history-visual picture,
.company__history-visual img {
  display: block;
  width: 100%;
  height: 100%;
}
.company__history-visual img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  -webkit-filter: saturate(0.86) brightness(0.72);
          filter: saturate(0.86) brightness(0.72);
}

.company__history-visual-copy {
  position: absolute;
  inset: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  gap: 1.875rem;
  margin-top: -10.625rem;
  margin-right: -10rem;
}
@media screen and (max-width: 767.9px) {
  .company__history-visual-copy {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-right: initial;
  }
}

.company__history-title {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  line-height: 1;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: mixed;
}
@media screen and (max-width: 767.9px) {
  .company__history-title {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 4rem;
    -ms-flex-item-align: end;
        align-self: end;
    justify-self: start;
    margin-bottom: -2.1875rem;
  }
}

.company__history-sub {
  font-size: 2.25rem;
  line-height: 1;
  letter-spacing: 0.14em;
  color: #fff;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: mixed;
}
@media screen and (max-width: 767.9px) {
  .company__history-sub {
    right: clamp(1.125rem, 4vw, 1.5rem);
    bottom: clamp(0.875rem, 3.6dvh, 1.25rem);
    font-size: 2rem;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
  }
}

.company__member {
  background-color: #161A1C;
  background-image: url(../img/deco_black2.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .company__member {
    padding-top: 2.1875rem;
    padding-bottom: 3.3125rem;
    background-image: url(../img/deco_black2-sp.jpg);
  }
}

.company__member-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
@media screen and (max-width: 767.9px) {
  .company__member-inner {
    display: block;
  }
}

.company__member-title-wrap {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 23.5294117647%;
          flex: 0 0 23.5294117647%;
  border-right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.company__member-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  color: #fff;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: mixed;
}
@media screen and (max-width: 767.9px) {
  .company__member-title {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 4rem;
    line-height: 0.9375;
    font-weight: 500;
    opacity: 0.5;
    padding-inline: 1.6875rem;
  }
}

.company__member-list {
  --member-open-width-pc: clamp(22.5rem, 31.6vw, 28.4375rem);
  --member-count: 6;
  --member-closed-min-width-pc: clamp(5.25rem, 7.2vw, 7.25rem);
  --member-closed-width-pc: calc((100% - var(--member-open-width-pc)) / (var(--member-count) - 1));
  --member-height-pc: 58.125rem;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: var(--member-height-pc);
  min-height: var(--member-height-pc);
  min-width: 0;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .company__member-list {
    margin-top: 2.5rem;
    display: block;
    height: auto;
    min-height: 0;
  }
}

.company__member-item {
  --member-bg: #1f2730;
  -webkit-box-flex: 0;
      -ms-flex: 0 1 var(--member-closed-width-pc);
          flex: 0 1 var(--member-closed-width-pc);
  min-width: var(--member-closed-min-width-pc);
  max-width: var(--member-closed-width-pc);
  height: 100%;
  position: relative;
  overflow: hidden;
  border: 0.0625rem solid rgba(255, 255, 255, 0.18);
  background: var(--member-bg);
  -webkit-transition: background-color 0.5s ease, -webkit-flex-basis 0.56s cubic-bezier(0.22, 0.61, 0.36, 1);
  transition: background-color 0.5s ease, -webkit-flex-basis 0.56s cubic-bezier(0.22, 0.61, 0.36, 1);
  transition: flex-basis 0.56s cubic-bezier(0.22, 0.61, 0.36, 1), background-color 0.5s ease;
  transition: flex-basis 0.56s cubic-bezier(0.22, 0.61, 0.36, 1), background-color 0.5s ease, -webkit-flex-basis 0.56s cubic-bezier(0.22, 0.61, 0.36, 1), -ms-flex-preferred-size 0.56s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: flex-basis;
  padding: 0;
}
@media screen and (max-width: 767.9px) {
  .company__member-item {
    border-left: 0.0625rem solid rgba(255, 255, 255, 0.18);
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    max-width: 100%;
    min-width: 0;
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
    -webkit-transition: background-color 0.35s ease;
    transition: background-color 0.35s ease;
    will-change: auto;
    padding: 0;
  }
}

.company__member-item.is-open {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 var(--member-open-width-pc);
          flex: 1 1 var(--member-open-width-pc);
  min-width: 0;
  max-width: var(--member-open-width-pc);
}
@media screen and (max-width: 767.9px) {
  .company__member-item.is-open {
    max-width: 100%;
  }
}

.company__member-item:nth-child(1) {
  background-color: rgba(0, 0, 0, 0.31);
}

.company__member-item:nth-child(2) {
  --member-bg: #213C39;
}

.company__member-item:nth-child(3) {
  --member-bg: #38422F;
}

.company__member-item:nth-child(4) {
  --member-bg: #403A33;
}

.company__member-item:nth-child(5) {
  --member-bg: #2C404D;
}

.company__member-item:nth-child(6) {
  --member-bg: #303C57;
}

.company__member-head {
  position: absolute;
  inset: 0;
  z-index: 3;
  padding: 3.75rem 2.5rem 9.1875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  cursor: pointer;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  -webkit-box-shadow: inset 0 1.25rem 1.5rem rgba(255, 255, 255, 0.05), inset 0 -1.125rem 1.5rem rgba(255, 255, 255, 0.1), inset -0.75rem 0 1.5rem rgba(0, 0, 0, 0.05), inset 1rem 0 1.5rem rgba(0, 0, 0, 0.2);
          box-shadow: inset 0 1.25rem 1.5rem rgba(255, 255, 255, 0.05), inset 0 -1.125rem 1.5rem rgba(255, 255, 255, 0.1), inset -0.75rem 0 1.5rem rgba(0, 0, 0, 0.05), inset 1rem 0 1.5rem rgba(0, 0, 0, 0.2);
}
@media screen and (max-width: 767.9px) {
  .company__member-head {
    position: relative;
    inset: auto;
    opacity: 1;
    pointer-events: auto;
    padding: 0.75rem 1.5625rem 0.75rem 2.5rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    grid-template-rows: auto auto;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    cursor: pointer;
    overflow: visible;
    -webkit-box-shadow: inset 0.625rem 0 1rem -0.75rem rgba(255, 255, 255, 0.36), inset -0.625rem 0 1rem -0.75rem rgba(255, 255, 255, 0.36), inset 0 0.125rem 0.25rem -0.1875rem rgba(0, 0, 0, 0.32), inset 0 -0.125rem 0.25rem -0.1875rem rgba(0, 0, 0, 0.28);
            box-shadow: inset 0.625rem 0 1rem -0.75rem rgba(255, 255, 255, 0.36), inset -0.625rem 0 1rem -0.75rem rgba(255, 255, 255, 0.36), inset 0 0.125rem 0.25rem -0.1875rem rgba(0, 0, 0, 0.32), inset 0 -0.125rem 0.25rem -0.1875rem rgba(0, 0, 0, 0.28);
  }
}

.company__member-name-ja {
  margin-top: 3.125rem;
  font-size: 1.5rem;
  letter-spacing: 0.14em;
  width: 1em;
  height: 8.75rem;
  position: relative;
  -webkit-writing-mode: horizontal-tb;
      -ms-writing-mode: lr-tb;
          writing-mode: horizontal-tb;
  text-orientation: initial;
}
.company__member-name-ja span {
  position: absolute;
  top: 0;
  left: 50%;
  display: inline-block;
  white-space: nowrap;
  line-height: 1;
  -webkit-transform: rotate(90deg) translateY(-50%);
          transform: rotate(90deg) translateY(-50%);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
@media screen and (max-width: 767.9px) {
  .company__member-name-ja {
    margin-top: 0;
    width: auto;
    height: auto;
    font-size: 1.125rem;
    line-height: 2.2777777778;
  }
  .company__member-name-ja span {
    position: static;
    -webkit-transform: none;
            transform: none;
    white-space: normal;
    line-height: inherit;
  }
}

.company__member-name-en {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.3;
  letter-spacing: 0.08em;
  opacity: 0.4;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-orientation: mixed;
  min-height: 10rem;
}
@media screen and (max-width: 767.9px) {
  .company__member-name-en {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 0.8125rem;
    line-height: 1.15;
    font-weight: 400;
    grid-row: 2;
    min-height: 0;
  }
}

.company__member-role {
  margin: auto 0 0;
  font-size: 1.125rem;
  letter-spacing: 0.1em;
  width: 1em;
  height: 13.125rem;
  position: relative;
  -webkit-writing-mode: horizontal-tb;
      -ms-writing-mode: lr-tb;
          writing-mode: horizontal-tb;
  text-orientation: initial;
}
.company__member-role span {
  position: absolute;
  top: 100%;
  left: 50%;
  display: inline-block;
  white-space: nowrap;
  line-height: 1;
  -webkit-transform: rotate(90deg) translate(-100%, -50%);
          transform: rotate(90deg) translate(-100%, -50%);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
@media screen and (max-width: 767.9px) {
  .company__member-role {
    margin: 0;
    width: auto;
    height: auto;
    font-size: 0.875rem;
    grid-column: 2;
    grid-row: 1/3;
    align-self: center;
    min-width: 0;
    padding-right: 0;
    text-align: right;
  }
  .company__member-role span {
    position: static;
    -webkit-transform: none;
            transform: none;
    white-space: normal;
    line-height: inherit;
  }
}

.company__member-toggle {
  width: 2.5rem;
  height: 2.5rem;
  border: 0;
  padding: 0;
  margin: 0;
  background-color: #161515;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.company__member-toggle span {
  width: 1rem;
  height: 1rem;
  position: relative;
  display: block;
}
@media screen and (max-width: 767.9px) {
  .company__member-toggle {
    position: static;
    grid-column: 3;
    grid-row: 1/3;
    justify-self: end;
    align-self: center;
    -webkit-transform: none;
            transform: none;
    z-index: auto;
    margin-left: 0;
    width: 2.125rem;
    height: 2.125rem;
  }
}

.company__member-toggle--plus {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .company__member-toggle--plus {
    margin-top: 0;
    margin-left: 0.9375rem;
  }
}
.company__member-toggle--plus span::before,
.company__member-toggle--plus span::after {
  position: absolute;
  content: "";
  background-color: #fff;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transition: transform 0.3s ease, opacity 0.3s ease, -webkit-transform 0.3s ease;
  border-radius: 100vw;
}
.company__member-toggle--plus span::before {
  width: 100%;
  height: 1px;
}
.company__member-toggle--plus span::after {
  width: 1px;
  height: 100%;
}

.company__member-toggle--minus {
  background-color: #fff;
  margin-left: auto;
}
.company__member-toggle--minus span::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 0.09375rem;
  background-color: #000;
  border-radius: 100vw;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 767.9px) {
  .company__member-toggle--minus {
    display: none;
  }
}

.company__member-item.is-open .company__member-head {
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .company__member-item.is-open .company__member-head {
    opacity: 1;
    pointer-events: auto;
  }
}

.company__member-item.is-open .company__member-toggle--plus {
  display: none;
}
@media screen and (max-width: 767.9px) {
  .company__member-item.is-open .company__member-toggle--plus {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    background-color: #fff;
  }
  .company__member-item.is-open .company__member-toggle--plus span::before,
  .company__member-item.is-open .company__member-toggle--plus span::after {
    background-color: #000;
  }
}

@media screen and (max-width: 767.9px) {
  .company__member-item.is-open .company__member-toggle--plus span::after {
    -webkit-transform: translate(-50%, -50%) scaleY(0);
            transform: translate(-50%, -50%) scaleY(0);
    opacity: 0;
  }
}

.company__member-body {
  position: absolute;
  inset: 1.5rem 1.25rem 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: none;
  transition: none;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  overflow: visible;
  gap: 1rem;
  padding-top: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .company__member-body {
    position: relative;
    inset: auto;
    max-height: 0;
    opacity: 0;
    pointer-events: auto;
    overflow: hidden;
    -webkit-transition: max-height 0.62s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.35s ease;
    transition: max-height 0.62s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.35s ease;
    will-change: max-height, opacity;
    gap: 0;
    padding-top: 0;
  }
}

.company__member-item.is-open .company__member-body {
  opacity: 1;
  pointer-events: auto;
}
@media screen and (max-width: 767.9px) {
  .company__member-item.is-open .company__member-body {
    max-height: 200vh;
  }
}

.company__member-media {
  aspect-ratio: 327/434;
  width: 100%;
  max-width: 20.4375rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .company__member-media {
    margin-top: 1.875rem;
    aspect-ratio: 246/327;
    max-width: 15.375rem;
  }
}
.company__member-media img {
  width: 100%;
  height: 100%;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}

.company__member-detail {
  margin-top: 0;
  max-width: 24.375rem;
  margin-inline: auto;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 0;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail {
    max-width: 100%;
    padding: 1.5625rem 0 1.875rem;
  }
}

.company__member-detail-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail-head {
    padding-top: 0.625rem;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 0;
    padding-inline: 2.8125rem;
    position: relative;
  }
}

.company__member-detail-name-ja {
  font-size: 1.5rem;
  line-height: 1.7083333333;
  letter-spacing: 0.14em;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail-name-ja {
    font-size: 1.125rem;
    line-height: 2.2777777778;
  }
}

.company__member-detail-role {
  font-size: 1.125rem;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail-role {
    font-size: 0.875rem;
  }
}

.company__member-detail-role.company__member-detail-role--small {
  text-align: right;
  font-size: 1rem;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail-role.company__member-detail-role--small {
    font-size: 0.875rem;
  }
}

.company__member-detail-name-en {
  margin-top: 0.625rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 1.25rem;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.4);
  line-height: 1.22;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail-name-en {
    margin-top: 0;
    font-size: 0.8125rem;
    font-weight: 400;
    padding-inline: 2.8125rem;
    position: relative;
    top: 0;
    left: 0;
  }
}

.company__member-detail-text {
  margin-top: 0.9375rem;
  padding-top: 1.5625rem;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  font-size: 0.9375rem;
  line-height: 2.0666666667;
  letter-spacing: 0.1em;
  overflow: auto;
}
@media screen and (max-width: 767.9px) {
  .company__member-detail-text {
    margin-top: 1.0625rem;
    padding-top: 1.5625rem;
    font-size: 0.8125rem;
    line-height: 2.3846153846;
    letter-spacing: 0.07em;
    padding-inline: 2.8125rem;
  }
}

.company__member-detail-text {
  overflow-y: scroll;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.company__member-detail-text::-webkit-scrollbar {
  display: none;
}

.company__policy {
  background-color: #fff;
  color: #202629;
  padding-top: 6.25rem;
  padding-bottom: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .company__policy {
    padding: 1.875rem 0 4.375rem;
  }
}

.company__policy-inner {
  max-width: 104.375rem;
  margin-inline: auto;
  -webkit-transform: translateX(3.75rem);
          transform: translateX(3.75rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 767.9px) {
  .company__policy-inner {
    max-width: 31.25rem;
    -webkit-transform: none;
            transform: none;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 3.125rem 0.625rem;
  }
}

.company__policy-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.75rem;
  padding: 0.625rem 0;
  border-bottom: solid 1px #838383;
  color: #2B2B2B;
  background-color: #fff;
  text-decoration: none;
  -webkit-transition: background-color 0.35s ease, color 0.35s ease, border-color 0.35s ease, padding 0.35s ease;
  transition: background-color 0.35s ease, color 0.35s ease, border-color 0.35s ease, padding 0.35s ease;
}
.company__policy-item:hover {
  background-color: #2B2B2B;
  border-bottom-color: #2B2B2B;
  opacity: 1;
}
.company__policy-item:hover .company__policy-en {
  color: #B2B2B2;
}
@media screen and (max-width: 767.9px) {
  .company__policy-item {
    padding: 0;
    gap: 0.875rem;
    border-bottom: none;
  }
}

.company__policy-item:last-child {
  border-bottom: none;
}

.company__policy-en {
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  line-height: 1.22;
  font-size: 9.3125rem;
}
@media screen and (max-width: 767.9px) {
  .company__policy-en {
    font-size: 2.375rem;
  }
}

.company__policy-ja {
  font-size: 2.25rem;
  line-height: 1.1388888889;
  letter-spacing: 0.5em;
  color: inherit;
  opacity: 0;
  visibility: hidden;
  max-height: 0;
  overflow: hidden;
  padding-bottom: 0;
  -webkit-transition: opacity 0.35s ease, visibility 0.35s ease, max-height 0.35s ease, padding-bottom 0.35s ease;
  transition: opacity 0.35s ease, visibility 0.35s ease, max-height 0.35s ease, padding-bottom 0.35s ease;
}
@media screen and (max-width: 767.9px) {
  .company__policy-ja {
    opacity: 1;
    visibility: visible;
    max-height: none;
    overflow: visible;
  }
}

.company__policy-tag {
  margin-top: -1.25rem;
  display: inline-block;
  vertical-align: middle;
  margin-left: 2.625rem;
  padding: 0.625rem 1.3125rem;
  background-color: #333333;
  color: #fff;
  font-size: 1.5rem;
  -webkit-transition: background-color 0.35s ease, color 0.35s ease, opacity 0.35s ease, visibility 0.35s ease;
  transition: background-color 0.35s ease, color 0.35s ease, opacity 0.35s ease, visibility 0.35s ease;
  border-radius: 0.25rem;
  letter-spacing: 0.07em;
  font-weight: 400;
}
.company__policy-tag span {
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
}
@media screen and (max-width: 767.9px) {
  .company__policy-tag {
    display: block;
    margin-top: 1rem;
    margin-left: 0;
    font-size: 1rem;
    padding: 0.75rem 1.25rem;
    width: 200vw;
  }
}

.company__policy-item:hover .company__policy-tag {
  background-color: #fff;
  color: #2B2B2B;
}

.company__policy-item:hover .company__policy-en {
  color: #fff;
}

.company__policy-item:hover .company__policy-ja {
  opacity: 1;
  visibility: visible;
  max-height: 12.5rem;
  padding-bottom: 1.25rem;
  color: #B2B2B2;
}
@media screen and (max-width: 767.9px) {
  .company__policy-item:hover .company__policy-ja {
    max-height: none;
    padding-bottom: 0;
    color: #B2B2B2;
  }
}

.company__policy-item--lead {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 0.625rem 2.5rem 0.625rem 0;
  gap: 0.625rem;
}
.company__policy-item--lead:hover {
  padding: 0.625rem 2.5rem;
}
.company__policy-item--lead .company__policy-en {
  font-size: 9.375rem;
}
@media screen and (max-width: 767.9px) {
  .company__policy-item--lead {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
    min-width: 0;
    width: auto;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    padding: 1.0625rem 0.5rem;
    min-height: 35rem;
  }
  .company__policy-item--lead:hover {
    padding: 1.0625rem 0.5rem;
  }
  .company__policy-item--lead .company__policy-en {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 4.1875rem;
    white-space: nowrap;
  }
  .company__policy-item--lead .company__policy-ja {
    width: 1rem;
    height: 20.625rem;
    position: relative;
    display: block;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 1rem;
    letter-spacing: 0.5em;
    max-height: none;
    padding-bottom: 0;
  }
  .company__policy-item--lead .company__policy-ja span {
    position: absolute;
    top: 50%;
    left: 50%;
    display: inline-block;
    white-space: nowrap;
    -webkit-transform: translate(-50%, -50%) rotate(90deg);
            transform: translate(-50%, -50%) rotate(90deg);
    -webkit-transform-origin: center;
            transform-origin: center;
    margin-top: 1.875rem;
  }
  .company__policy-item--lead {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .company__policy-item--lead .company__policy-ja {
    top: 0.75rem;
  }
}

.company__policy-item--basic:hover .company__policy-en {
  color: #B2B2B2;
}
.company__policy-item--basic:hover .company__policy-tag {
  opacity: 0;
  visibility: hidden;
}
.company__policy-item--basic .company__policy-en {
  font-size: 6rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  line-height: 1.22;
  color: #B2B2B2;
  position: relative;
}
.company__policy-item--basic .company__policy-en::before {
  position: absolute;
  content: "";
  width: 6.625rem;
  height: 6.625rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -15.1875rem;
  background-image: url(../img/icon_circle-white.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  -webkit-box-shadow: 0 0 1.4375rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.4375rem rgba(117, 117, 117, 0.25);
  border-radius: 100vw;
}
.company__policy-item--basic .company__policy-en:hover .company__policy-en::before {
  opacity: 1;
}
@media screen and (max-width: 767.9px) {
  .company__policy-item--basic:hover .company__policy-tag {
    opacity: 1;
    visibility: visible;
  }
  .company__policy-item--basic {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    width: 100%;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0;
  }
  .company__policy-item--basic .company__policy-en {
    font-size: 2.25rem;
    line-height: 1.25;
    border-bottom: 1px solid #838383;
    padding-bottom: 1.25rem;
    -webkit-transform: translateX(0.9375rem);
            transform: translateX(0.9375rem);
  }
}

.company__policy-item--making {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 0.625rem 2.5rem 0.625rem 0;
  gap: 0.625rem;
}
.company__policy-item--making:hover {
  padding: 0.625rem 2.5rem;
}
.company__policy-item--making .company__policy-en {
  font-size: 9.3125rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  line-height: 1.22;
  gap: 0;
}
@media screen and (max-width: 767.9px) {
  .company__policy-item--making {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
    min-width: 0;
    width: auto;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    padding: 1.0625rem 0.5rem;
    min-height: 35rem;
  }
  .company__policy-item--making:hover {
    padding: 1.0625rem 0.5rem;
  }
  .company__policy-item--making .company__policy-en {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 4.1875rem;
    white-space: nowrap;
  }
  .company__policy-item--making .company__policy-ja {
    width: 1rem;
    height: 20.625rem;
    position: relative;
    display: block;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 1rem;
    letter-spacing: 0.5em;
    max-height: none;
    padding-bottom: 0;
  }
  .company__policy-item--making .company__policy-ja span {
    position: absolute;
    top: 50%;
    left: 50%;
    display: inline-block;
    white-space: nowrap;
    -webkit-transform: translate(-50%, -50%) rotate(90deg);
            transform: translate(-50%, -50%) rotate(90deg);
    -webkit-transform-origin: center;
            transform-origin: center;
    margin-top: 1.875rem;
  }
  .company__policy-item--making {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .company__policy-item--making .company__policy-ja {
    top: 0rem;
  }
}

.company__policy-item--vision {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 0.625rem 2.5rem 0.625rem 0;
  gap: 0.625rem;
}
.company__policy-item--vision:hover {
  padding: 0.625rem 2.5rem;
}
.company__policy-item--vision .company__policy-en {
  font-size: 9.3125rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  line-height: 1.22;
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .company__policy-item--vision {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
    min-width: 0;
    width: auto;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    padding: 1.0625rem 0.5rem;
    min-height: 35rem;
  }
  .company__policy-item--vision:hover {
    padding: 1.0625rem 0.5rem;
  }
  .company__policy-item--vision .company__policy-en {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 4.1875rem;
    white-space: nowrap;
  }
  .company__policy-item--vision .company__policy-ja {
    width: 1rem;
    height: 20.625rem;
    position: relative;
    display: block;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 1rem;
    letter-spacing: 0.5em;
    max-height: none;
    padding-bottom: 0;
  }
  .company__policy-item--vision .company__policy-ja span {
    position: absolute;
    top: 50%;
    left: 50%;
    display: inline-block;
    white-space: nowrap;
    -webkit-transform: translate(-50%, -50%) rotate(90deg);
            transform: translate(-50%, -50%) rotate(90deg);
    -webkit-transform-origin: center;
            transform-origin: center;
    margin-top: 1.875rem;
  }
  .company__policy-item--vision {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .company__policy-item--vision .company__policy-ja {
    top: 4.25rem;
  }
}

.stats-numbers__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 12.5rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__inner {
    max-width: 31.25rem;
    padding-inline: 1.5625rem;
    padding-top: 2.5rem;
    padding-bottom: 3.75rem;
  }
}

.stats-numbers__sub {
  font-size: 2.25rem;
  line-height: 1.1388888889;
  letter-spacing: 0.84em;
  text-align: center;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__sub {
    font-size: 1rem;
    line-height: 2.5625;
  }
}

.stats-numbers__title {
  margin-top: 0.8125rem;
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  line-height: 1.22;
  text-align: center;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__title {
    margin-top: 0;
    font-size: 2.25rem;
  }
}

.stats-numbers__cards {
  margin-top: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 2.5rem;
  border-bottom: 0.0625rem solid #C0C0C0;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__cards {
    max-width: 21.125rem;
    margin-inline: auto;
    margin-top: 1.875rem;
    display: block;
    border-bottom: 0;
    position: relative;
    min-height: 25.625rem;
  }
}

.stats-numbers__card {
  border-radius: 100vw;
  background-color: #fff;
  -webkit-box-shadow: 0 0 1.4375rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.4375rem rgba(117, 117, 117, 0.25);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}

.stats-numbers__card.stats-numbers__card--total {
  width: 26.75rem;
  height: 26.75rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card.stats-numbers__card--total {
    width: 12.1875rem;
    height: 12.1875rem;
    position: absolute;
    top: 0;
    left: 0;
  }
}
.stats-numbers__card.stats-numbers__card--total .stats-numbers__card-en {
  font-size: 2.875rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-en {
    margin-top: -0.625rem;
    font-size: 1.3125rem;
    line-height: 1;
  }
}
.stats-numbers__card.stats-numbers__card--total .stats-numbers__card-ja {
  margin-top: 0.75rem;
  font-size: 2.25rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-ja {
    margin-top: 0.75rem;
    font-size: 1.025rem;
    line-height: 1;
  }
}
.stats-numbers__card.stats-numbers__card--total .stats-numbers__card-count {
  margin-top: 3.125rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-count {
    margin-top: 1.375rem;
  }
}
.stats-numbers__card.stats-numbers__card--total .stats-numbers__card-count-number {
  font-size: 6.6875rem;
  line-height: 0.5794392523;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-count-number {
    font-size: 3.0625rem;
    line-height: 0.5714285714;
  }
}
.stats-numbers__card.stats-numbers__card--total .stats-numbers__card-unit {
  font-size: 3.4375rem;
  line-height: 1.1272727273;
  margin-bottom: -0.9375rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-unit {
    font-size: 1.5625rem;
    line-height: 1.12;
    margin-bottom: -0.3125rem;
  }
}

.stats-numbers__card--ma {
  width: 20.875rem;
  height: 20.875rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--ma {
    width: 9.5rem;
    height: 9.5rem;
    position: absolute;
    top: 9.375rem;
    right: 0;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--ma .stats-numbers__card-en {
    margin-top: -0.625rem;
    font-size: 1.025rem;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--ma .stats-numbers__card-ja {
    margin-top: 0.3125rem;
    font-size: 0.9375rem;
    line-height: 1;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--ma .stats-numbers__card-count {
    margin-top: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--ma .stats-numbers__card-count-number {
    font-size: 2.375rem;
    line-height: 0.5789473684;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--ma .stats-numbers__card-unit {
    font-size: 1.225rem;
    line-height: 1.1224489796;
    margin-bottom: -0.3125rem;
  }
}

.stats-numbers__card--startup {
  width: 20.875rem;
  height: 20.875rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--startup {
    width: 11.125rem;
    height: 11.125rem;
    position: absolute;
    top: 14.6875rem;
    left: 0;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--startup .stats-numbers__card-en {
    margin-top: -0.625rem;
    font-size: 1.1875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--startup .stats-numbers__card-ja {
    margin-top: 0.375rem;
    font-size: 1.1rem;
    line-height: 1;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--startup .stats-numbers__card-count {
    margin-top: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--startup .stats-numbers__card-count-number {
    font-size: 2.8rem;
    line-height: 0.5736607143;
  }
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card--startup .stats-numbers__card-unit {
    font-size: 1.43125rem;
    line-height: 1.1222707424;
    margin-bottom: -0.4375rem;
  }
}

.stats-numbers__card-en {
  font-family: "Cormorant Garamond", serif;
  font-size: 2.25rem;
  font-weight: 600;
  color: #386C95;
  line-height: 1.2;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card-en {
    font-size: 1rem;
  }
}

.stats-numbers__card-ja {
  margin-top: 0.75rem;
  font-size: 1.75rem;
  line-height: 1.1428571429;
  letter-spacing: 0.14em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card-ja {
    margin-top: 0.3125rem;
    font-size: 0.9375rem;
  }
}

.stats-numbers__card-count {
  margin-top: 1.5625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card-count {
    margin-top: 1.375rem;
  }
}

.stats-numbers__card-count-number {
  display: inline-block;
  font-size: 5.25rem;
  line-height: 1;
  letter-spacing: -0.01em;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card-count-number {
    font-size: 2.375rem;
  }
}

.stats-numbers__card-unit {
  display: inline-block;
  margin-bottom: 0.3125rem;
  font-size: 2.6875rem;
  line-height: 1.1162790698;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767.9px) {
  .stats-numbers__card-unit {
    margin-bottom: -0.125rem;
  }
}

.stats-numbers.stats-numbers--sp .stats-numbers__inner {
  padding-top: 1.875rem;
  padding-bottom: 1.875rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__cards {
  margin-top: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  min-height: initial;
  gap: 0.5rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--total, .stats-numbers.stats-numbers--sp .stats-numbers__card--ma, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup {
  position: relative;
  top: initial;
  left: initial;
  right: initial;
  -webkit-box-shadow: 0 0 1rem white;
          box-shadow: 0 0 1rem white;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--total {
  width: 8.25rem;
  height: 8.25rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--ma, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup {
  width: 6.4375rem;
  height: 6.4375rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-en {
  font-size: 0.875rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-ja {
  margin-top: 0.3125rem;
  font-size: 0.875rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-count-number {
  font-size: 2.5rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-unit {
  font-size: 1.25rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card.stats-numbers__card--total .stats-numbers__card-count {
  margin-top: 0.75rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--ma .stats-numbers__card-en, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup .stats-numbers__card-en {
  font-size: 0.6875rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--ma .stats-numbers__card-ja, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup .stats-numbers__card-ja {
  margin-top: 0.3125rem;
  font-size: 0.8125rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--ma .stats-numbers__card-count-number, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup .stats-numbers__card-count-number {
  font-size: 2.25rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--ma .stats-numbers__card-unit, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup .stats-numbers__card-unit {
  font-size: 1.125rem;
}
.stats-numbers.stats-numbers--sp .stats-numbers__card--ma .stats-numbers__card-count, .stats-numbers.stats-numbers--sp .stats-numbers__card--startup .stats-numbers__card-count {
  margin-top: 0.5rem;
}

.philosophy {
  background-color: #161A1C;
  color: #fff;
}

@media screen and (max-width: 767.9px) {
  .page-head-wrap.page-head-wrap--philosophy {
    background-image: url(../img/pilosophy_hero-bg-sp.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
}

.philosophy__hero {
  height: 45rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-image: url(../img/pilosophy_hero-bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .philosophy__hero {
    background-image: none;
    height: auto;
  }
}

.philosophy__hero-inner {
  max-width: 73.75rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .philosophy__hero-inner {
    padding-top: 0.625rem;
    padding-bottom: 3.75rem;
    padding-inline: 1.5625rem;
  }
}

.philosophy__hero-title {
  font-size: 3rem;
  line-height: 1.3333333333;
  letter-spacing: 0.07em;
  text-align: center;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .philosophy__hero-title {
    margin-top: 2.5rem;
    font-size: 1.5rem;
    line-height: 1.5416666667;
    letter-spacing: 0.04em;
  }
}

.philosophy__hero-text {
  margin-top: 5rem;
  font-size: 1.3125rem;
  line-height: 2.2857142857;
  letter-spacing: 0.07em;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .philosophy__hero-text {
    margin-top: 2.5rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

.philosophy__feature {
  padding: 15rem 0 10rem;
}
@media screen and (max-width: 767.9px) {
  .philosophy__feature {
    padding: 3.75rem 1.5625rem 5.625rem;
  }
}

.philosophy__feature-inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.philosophy__feature-bg {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 10.1875rem;
  color: #333F45;
  white-space: nowrap;
  z-index: 0;
}
@media screen and (max-width: 767.9px) {
  .philosophy__feature-bg {
    top: 50%;
    font-size: 3rem;
    text-align: center;
    line-height: 1.2;
  }
}

.philosophy__feature-circles {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767.9px) {
  .philosophy__feature-circles {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    max-width: 23.75rem;
    margin-inline: auto;
    row-gap: 4.875rem;
  }
}

.philosophy__feature-circle {
  width: 15.4375rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #333F45;
  text-align: center;
}
.philosophy__feature-circle + .philosophy__feature-circle {
  margin-left: -1.25rem;
}
@media screen and (max-width: 767.9px) {
  .philosophy__feature-circle {
    width: 7.375rem;
  }
  .philosophy__feature-circle + .philosophy__feature-circle {
    margin-left: -0.625rem;
  }
  .philosophy__feature-circle:nth-child(4) {
    margin-left: 0;
  }
}

.philosophy__feature-circle-en {
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 2.375rem;
  color: #343B3F;
  line-height: 1.22;
}
@media screen and (max-width: 767.9px) {
  .philosophy__feature-circle-en {
    font-size: 1.125rem;
  }
}

.philosophy__feature-circle-ja {
  margin-top: 0.875rem;
  font-size: 1.875rem;
  line-height: 1.1333333333;
  letter-spacing: 0.14em;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .philosophy__feature-circle-ja {
    margin-top: 0.4375rem;
    font-size: 0.875rem;
  }
}

.philosophy__block {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 60.25rem;
  padding-top: 13.9375rem;
  padding-bottom: 9.25rem;
  text-align: center;
  color: #fff;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block {
    padding-top: 11.25rem;
    padding-bottom: 5rem;
    min-height: 45rem;
  }
}
.philosophy__block::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  top: 0;
  left: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to bottom, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block::before {
    height: 2.5rem;
  }
}
.philosophy__block::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  bottom: 0;
  left: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block::after {
    height: 2.5rem;
  }
}

.philosophy__block.philosophy__block--identity {
  background-image: url(../img/pilosophy_identity-bg.png);
}
@media screen and (max-width: 767.9px) {
  .philosophy__block.philosophy__block--identity {
    background-image: url(../img/pilosophy_identity-bg-sp.png);
  }
}

.philosophy__block-inner {
  max-width: 73.75rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block-inner {
    max-width: 31.25rem;
    padding-inline: 1.25rem;
  }
}

.philosophy__block-label {
  position: relative;
  display: inline-block;
  font-size: 1.5rem;
  line-height: 1.22;
  letter-spacing: 0.16em;
  font-weight: 500;
  font-family: "Cormorant Garamond", serif;
  text-transform: uppercase;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block-label {
    font-size: 1.25rem;
  }
}

.philosophy__block-fire {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 1.5rem);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: block;
  width: 10rem;
  height: 10rem;
  -o-object-fit: contain;
     object-fit: contain;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block-fire {
    bottom: calc(100% + 1.125rem);
    width: 7.5rem;
    height: 7.5rem;
  }
}

.philosophy__block-title {
  margin-top: 2.5rem;
  font-size: 6rem;
  line-height: 1.22;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block-title {
    margin-top: 1.875rem;
    font-size: 2.25rem;
  }
}

.philosophy__block-sub-title {
  margin-top: 1.5rem;
  font-size: 2.25rem;
  line-height: 1.7777777778;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block-sub-title {
    margin-top: 0.3125rem;
    font-size: 1.25rem;
    letter-spacing: 0.04em;
  }
}

.philosophy__block-text {
  margin-top: 5rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .philosophy__block-text {
    margin-top: 3.75rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

.philosophy__block--mission {
  background-image: url(../img/bg_grid-glow.png);
}
@media screen and (max-width: 767.9px) {
  .philosophy__block--mission {
    padding-bottom: 2.5rem;
    background-image: url(../img/bg_grid-glow-sp.png);
  }
}

.philosophy__vision {
  height: 100lvh !important;
  min-height: 100svh !important;
  overflow: hidden;
  overflow: clip;
  background-image: url(../img/pilosophy_vision-bg.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.philosophy__vision-inner {
  height: inherit;
}

.philosophy__vision-content {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  z-index: 10;
}

.philosophy__vision-content-inner {
  max-width: 73.125rem;
  width: 100%;
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3.75rem;
}
@media screen and (max-width: 767.9px) {
  .philosophy__vision-content-inner {
    max-width: 31.25rem;
    gap: 1.875rem;
    padding: 4.375rem 2.25rem;
  }
}

.philosophy__vision-label {
  font-size: 1.5rem;
  line-height: 1.22;
  letter-spacing: 0.16em;
  font-weight: 700;
  font-family: "Cormorant Garamond", serif;
  text-transform: uppercase;
}

.philosophy__vision-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 767.9px) {
  .philosophy__vision-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.philosophy__vision-title span {
  display: block;
}

.philosophy__vision-title-en {
  font-size: 6rem;
  line-height: 1.125;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767.9px) {
  .philosophy__vision-title-en {
    font-size: 2.25rem;
    line-height: 1.22;
  }
}

.philosophy__vision-title-ja {
  margin-top: 2.5rem;
  font-size: 2.25rem;
  line-height: 1.7777777778;
  letter-spacing: 0.07em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .philosophy__vision-title-ja {
    margin-top: 1.875rem;
    font-size: 1.25rem;
    line-height: 1.6;
    letter-spacing: 0.04em;
  }
}

.philosophy__vision-text {
  max-width: 33.875rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .philosophy__vision-text {
    max-width: 31.25rem;
    margin-top: 1.25rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.02em;
  }
}

.philosophy__vision-glass {
  position: absolute;
  inset: 2.1875rem;
  z-index: -1;
  border-radius: 0.5rem;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.01) 0%, rgba(255, 255, 255, 0.01) 38%, rgba(255, 255, 255, 0.01) 100%);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-bottom-color: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(2px) saturate(2);
  -webkit-backdrop-filter: blur(2px) saturate(2);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 1.5rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 1.5rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
}
@media screen and (max-width: 767.9px) {
  .philosophy__vision-glass {
    inset: 1.875rem 0.9375rem;
  }
}

.value {
  color: #fff;
}

.value__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding: 7.5rem 0 5rem;
}
@media screen and (max-width: 767.9px) {
  .value__inner {
    max-width: 31.25rem;
    padding: 3.125rem 1.5625rem 0.9375rem;
  }
}

.value__content {
  margin-top: 7.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767.9px) {
  .value__content {
    margin-top: 3.125rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.value__head {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .value__head {
    display: contents;
  }
}

.value__heading {
  font-size: 2.25rem;
  line-height: 1.7777777778;
  letter-spacing: 0.07em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .value__heading {
    font-size: 1.5rem;
    line-height: 1.6666666667;
    width: 100%;
  }
}

.value__heading-text {
  font-size: 1rem;
  line-height: 1.75;
  letter-spacing: 0.08em;
  margin-top: 2.4375rem;
}
@media screen and (max-width: 767.9px) {
  .value__heading-text {
    margin-top: 1.25rem;
    font-size: 0.8125rem;
    line-height: 1.9230769231;
    letter-spacing: 0.07em;
  }
}

.value__bg-text {
  margin-top: 6.125rem;
  font-size: 10.1875rem;
  line-height: 1.22;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
  color: #333F45;
  text-transform: uppercase;
}
@media screen and (max-width: 767.9px) {
  .value__bg-text {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    margin-top: 0.625rem;
    font-size: 6rem;
    text-align: center;
    width: 100%;
  }
}

.value__circles {
  position: relative;
  width: 44.5rem;
  height: 30.875rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-transform: translateX(-2.1875rem);
          transform: translateX(-2.1875rem);
}
@media screen and (max-width: 767.9px) {
  .value__circles {
    margin-top: 1.625rem;
    width: 21.25rem;
    height: 19.625rem;
    margin-inline: auto;
    -webkit-transform: none;
            transform: none;
  }
}

.value__circle {
  position: absolute;
  width: 15.4375rem;
  height: 15.4375rem;
  aspect-ratio: 1/1;
  border-radius: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .value__circle {
    width: 8.125rem;
    height: 8.125rem;
  }
}

.value__circle--speed {
  top: 0;
  left: 0;
}
@media screen and (max-width: 767.9px) {
  .value__circle--speed {
    top: 4rem;
  }
}

.value__circle--courage {
  top: 0;
  left: 50%;
  margin-left: calc(15.4375rem / -2);
}
@media screen and (max-width: 767.9px) {
  .value__circle--courage {
    margin-left: calc(8.125rem / -2);
  }
}

.value__circle--professional {
  top: 0;
  right: 0;
}
@media screen and (max-width: 767.9px) {
  .value__circle--professional {
    top: 4rem;
  }
}

.value__circle--respect {
  bottom: 0;
  left: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .value__circle--respect {
    left: 2.8125rem;
  }
}

.value__circle--integrity {
  bottom: 0;
  right: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .value__circle--integrity {
    right: 2.8125rem;
  }
}

.value__circle-title {
  font-size: 2.375rem;
  line-height: 1.22;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
  color: #386C95;
}
@media screen and (max-width: 767.9px) {
  .value__circle-title {
    font-size: 1.25rem;
  }
}

.value__circle-text {
  margin-top: 1.1875rem;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.08em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .value__circle-text {
    margin-top: 0.75rem;
    font-size: 0.625rem;
    line-height: 1.48;
  }
}

.philosophy__concept-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 5rem;
  padding-bottom: 10.625rem;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-inner {
    max-width: 31.25rem;
    padding-top: 0.9375rem;
    padding-bottom: 3.75rem;
    padding-inline: 1.5625rem;
  }
}

.philosophy__concept-content {
  margin-top: 5.1875rem;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-content {
    margin-top: 2.5rem;
  }
}

.philosophy__concept-read {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-read {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.philosophy__concept-read-en {
  font-size: 10.1875rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #333F45;
  line-height: 1.22;
  text-transform: uppercase;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-read-en {
    font-size: 6rem;
    white-space: nowrap;
  }
}

.philosophy__concept-read-ja {
  font-size: 2.25rem;
  line-height: 1.7777777778;
  letter-spacing: 0.07em;
  margin-left: -4.375rem;
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-read-ja {
    font-size: 1.5rem;
    line-height: 1.6666666667;
    letter-spacing: 0.07em;
    margin-left: 0;
    margin-top: -5rem;
  }
}

.philosophy__concept-borderless {
  position: relative;
  margin-top: 3.75rem;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-borderless {
    margin-top: 12.9375rem;
    text-align: center;
  }
}

.philosophy__concept-fire {
  position: absolute;
  left: 7.5rem;
  top: calc(100% + 2.125rem);
  display: block;
  width: 12.5rem;
  height: 23.75rem;
  -o-object-fit: contain;
     object-fit: contain;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-fire {
    left: 50%;
    top: auto;
    bottom: calc(100% + 0.625rem);
    width: 7.5rem;
    height: 8.75rem;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

.philosophy__concept-borderless-en {
  font-size: 6rem;
  line-height: 1.22;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-borderless-en {
    font-size: 2.125rem;
  }
}

.philosophy__concept-borderless-ja {
  margin-top: 1.5rem;
  font-size: 2.25rem;
  line-height: 1.7777777778;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-borderless-ja {
    margin-top: 0.3125rem;
    font-size: 1.25rem;
    line-height: 1.55;
    letter-spacing: 0.04em;
  }
}

.philosophy__concept-text {
  margin-top: 7.5rem;
  text-align: right;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .philosophy__concept-text {
    margin-top: 2.5rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
    text-align: center;
  }
}

.philosophy__company {
  height: 32.375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-image: url(../img/company_head.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .philosophy__company {
    height: 20rem;
    background-image: url(../img/company_head-sp.jpg);
  }
}

.philosophy__company-link {
  width: 20.1875rem;
  height: 20.1875rem;
  border-radius: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #fff;
  font-size: 2.4375rem;
  line-height: 1.1538461538;
  letter-spacing: 0.14em;
  text-align: center;
  gap: 1.1875rem;
  backdrop-filter: blur(15px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(15px) saturate(1.35) !important;
  -webkit-transition: opacity 0.15s ease, background-color 0.15s ease, color 0.15s ease;
  transition: opacity 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}
@media screen and (max-width: 767.9px) {
  .philosophy__company-link {
    font-size: 1.125rem;
    gap: 0.5rem;
    width: 12.5rem;
    height: 12.5rem;
  }
}
.philosophy__company-link span {
  font-size: 3.125rem;
  line-height: 1.22;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
}
@media screen and (max-width: 767.9px) {
  .philosophy__company-link span {
    font-size: 1.5rem;
  }
}
.philosophy__company-link:hover {
  opacity: 1;
  background-color: #fff;
  color: #2B2B2B;
}

.recruit {
  background-color: #161A1C;
  color: #fff;
}

.page-head-wrap.page-head-wrap--recruit {
  position: relative;
}
.page-head-wrap.page-head-wrap--recruit::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 53.4375rem;
  background-image: url(../img/recruit_hero-bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 0;
}
@media screen and (max-width: 767.9px) {
  .page-head-wrap.page-head-wrap--recruit::before {
    height: 42rem;
  }
}
.page-head-wrap.page-head-wrap--recruit::after {
  content: "";
  position: absolute;
  top: 43.0625rem;
  left: 0;
  width: 100%;
  height: 10.375rem;
  background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  pointer-events: none;
  z-index: 0;
}
.page-head-wrap.page-head-wrap--recruit > * {
  position: relative;
  z-index: 1;
}

.rectuit__hero {
  overflow: hidden;
  padding: 3.75rem 0 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .rectuit__hero {
    padding: 2.5rem 1.5625rem 3.75rem;
  }
}

.recruit__marquee {
  width: 100%;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .recruit__marquee {
    overflow: visible;
  }
}

.recruit__marquee-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  -webkit-animation: recruit-marquee 80s linear infinite;
          animation: recruit-marquee 80s linear infinite;
  will-change: transform;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
@media screen and (max-width: 767.9px) {
  .recruit__marquee-track {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 100%;
    -webkit-animation: none;
            animation: none;
    will-change: auto;
  }
}

.recruit__marquee-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.875rem;
  padding-right: 7.5rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .recruit__marquee-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-right: 0;
    text-align: center;
    gap: 0;
    margin-inline: auto;
  }
  .recruit__marquee-item:nth-child(2) {
    display: none;
  }
}

.recruit__marquee-en {
  font-size: 12.25rem;
  line-height: 1.22;
  letter-spacing: -0.06em;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .recruit__marquee-en {
    font-size: 5.8125rem;
  }
}

.recruit__marquee-ja + .recruit__marquee-en {
  margin-left: -2.5rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__marquee-ja + .recruit__marquee-en {
    margin-left: 3.125rem;
  }
}

.recruit__marquee-ja {
  font-size: 4rem;
  line-height: 1.25;
  letter-spacing: 0.03em;
  font-weight: 400;
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .recruit__marquee-ja {
    font-size: 1.875rem;
    line-height: 1.2666666667;
    white-space: normal;
    text-align: left;
  }
}

@-webkit-keyframes recruit-marquee {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

@keyframes recruit-marquee {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.recruit__hero-text {
  margin-top: 11.875rem;
  font-size: 2rem;
  line-height: 3.125;
  letter-spacing: 0.06em;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .recruit__hero-text {
    margin-top: 3.75rem;
    font-size: 1rem;
    line-height: 2;
    letter-spacing: 0.03em;
  }
}

.recruit__hero-text-line {
  display: block;
}

.rectuit__data {
  background-image: url(../img/bg_grid-glow.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .rectuit__data {
    background-image: url(../img/bg_grid-glow-sp.png);
  }
}
.rectuit__data::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  top: 0;
  left: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to bottom, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .rectuit__data::before {
    height: 2.5rem;
  }
}
.rectuit__data::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  bottom: 0;
  left: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .rectuit__data::after {
    height: 2.5rem;
  }
}

.recruit__data-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 6.25rem;
  padding-bottom: 8.125rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__data-inner {
    max-width: 31.25rem;
    padding-top: 3.75rem;
    padding-bottom: 1.875rem;
    padding-inline: 1.5625rem;
  }
}

.recruit__data-title {
  font-size: 2.25rem;
  letter-spacing: 0.03em;
  text-align: center;
  font-weight: 400;
  line-height: 2;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .recruit__data-title {
    font-size: 1.75rem;
  }
}
.recruit__data-title::before {
  position: absolute;
  content: "DATA";
  font-size: 12.5rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #333F45;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  opacity: 0.4;
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__data-title::before {
    font-size: 6rem;
  }
}

.recruit__items {
  margin-top: 3.75rem;
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(2, 1fr);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .recruit__items {
    margin-top: 3.125rem;
    grid-template-columns: repeat(1, 1fr);
    gap: 0.5rem;
  }
}
.recruit__items::before {
  position: absolute;
  content: "AZ ONE GROUP";
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 12.5rem;
  color: #333F45;
  bottom: -10rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .recruit__items::before {
    display: none;
  }
}

.recruit__item {
  position: relative;
  border-radius: 0.375rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__item {
    border-radius: 0.25rem;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__item:nth-child(2) {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__item:nth-child(3) {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__item:nth-child(4) {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
}

.recruit__item-title {
  position: absolute;
  top: 1.5625rem;
  left: 2.5rem;
  font-size: 2.25rem;
  letter-spacing: 0.03em;
  line-height: 1.3888888889;
}
@media screen and (max-width: 767.9px) {
  .recruit__item-title {
    font-size: 1.3125rem;
    top: 0.875rem;
    left: 1.5rem;
  }
}
.recruit__item-title span {
  font-size: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__item-title span {
    font-size: 0.875rem;
  }
}

.recruit__item-img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.recruit__feature {
  background-image: url(../img/bg_recruit-feature.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature {
    background-image: url(../img/bg_recruit-feature-sp.jpg);
  }
}
.recruit__feature::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  top: 0;
  left: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to bottom, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature::before {
    height: 2.5rem;
  }
}
.recruit__feature::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  bottom: 0;
  left: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature::after {
    height: 2.5rem;
  }
}

.recruit__feature-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-inner {
    max-width: 31.25rem;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    padding-inline: 1.5625rem;
  }
}

.recruit__feature-sub-title {
  margin-top: 5rem;
  font-size: 6rem;
  line-height: 1.22;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-sub-title {
    margin-top: 1.25rem;
    font-size: 2.25rem;
  }
}
.recruit__feature-sub-title span {
  display: inline-block;
  margin-left: 1.25rem;
  font-size: 2.25rem;
  letter-spacing: 0.03em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-sub-title span {
    margin-left: 0.625rem;
    font-size: 1.375rem;
    line-height: 1.8181818182;
  }
}

.recruit__feature-content {
  margin-top: 5rem;
  position: relative;
  width: 100%;
  height: 74.25rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-content {
    margin-top: 2.5rem;
    height: 43.875rem;
  }
}

.recruit__feature-center {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.recruit__feature-lines {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 30.125rem;
  height: 100%;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-lines {
    display: none;
  }
}

.recruit__feature-line {
  position: absolute;
  width: 5.75rem;
  height: 1px;
  background-color: #fff;
  -webkit-transform-origin: left center;
          transform-origin: left center;
}

.recruit__feature-line--01 {
  top: 26.25rem;
  left: 50%;
  -webkit-transform: rotate(90deg) translateX(-50%);
          transform: rotate(90deg) translateX(-50%);
}

.recruit__feature-line--02 {
  width: 11.75rem;
  top: 30rem;
  right: -11.75rem;
  -webkit-transform: rotate(155deg);
          transform: rotate(155deg);
}

.recruit__feature-line--03 {
  width: 11.75rem;
  bottom: 30rem;
  right: -11.75rem;
  -webkit-transform: rotate(-155deg);
          transform: rotate(-155deg);
}

.recruit__feature-line--04 {
  bottom: 26.25rem;
  left: 50%;
  -webkit-transform: rotate(-90deg) translateX(-50%);
          transform: rotate(-90deg) translateX(-50%);
}

.recruit__feature-line--05 {
  width: 11.75rem;
  bottom: 30rem;
  left: 0;
  -webkit-transform: rotate(-25deg);
          transform: rotate(-25deg);
}

.recruit__feature-line--06 {
  width: 11.75rem;
  top: 28.75rem;
  left: 0;
  -webkit-transform: rotate(25deg);
          transform: rotate(25deg);
}

.recruit__feature-fire {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
  width: 22.5rem;
  height: 22.5rem;
  -o-object-fit: contain;
     object-fit: contain;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-fire {
    left: calc(50% + 5.1875rem);
    top: 2.5rem;
    width: 7.5rem;
    height: 7.5rem;
  }
}

.recruit__feature-items {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 2;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-items {
    max-width: 21.25rem;
    margin-inline: auto;
  }
}

.recruit__feature-item {
  position: absolute;
  width: 21.875rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item {
    width: 10.875rem;
  }
}

.recruit__feature-circle {
  width: 100%;
  height: 21.875rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-circle {
    height: 10.875rem;
  }
}

.recruit__feature-number {
  margin-top: -1.875rem;
  font-size: 4rem;
  line-height: 0.703125;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-number {
    margin-top: -0.625rem;
    font-size: 2rem;
    line-height: 0.703125;
  }
}

.recruit__feature-text {
  margin-top: 1.875rem;
  font-size: 1.5rem;
  line-height: 1.75;
  text-align: center;
  letter-spacing: 0.14em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-text {
    margin-top: 0.90625rem;
    font-size: 0.8125rem;
    line-height: 1.6153846154;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__feature-text.recruit__feature-text--small {
    font-size: 0.75rem;
    line-height: 1.75;
  }
}

.recruit__feature-item--01 {
  top: 0;
  left: 0;
  right: 0;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item--01 {
    top: 0;
    left: 0;
    right: auto;
    margin-inline: 0;
  }
}

.recruit__feature-item--02 {
  top: 12.5rem;
  right: 0;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item--02 {
    top: 6.25rem;
    right: 0;
  }
}

.recruit__feature-item--03 {
  bottom: 12.5rem;
  right: 0;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item--03 {
    top: 13.375rem;
    bottom: auto;
    right: auto;
    left: 0;
  }
}

.recruit__feature-item--04 {
  bottom: 0;
  left: 0;
  right: 0;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item--04 {
    top: 19.625rem;
    bottom: auto;
    left: auto;
    right: 0;
    margin-inline: 0;
  }
}

.recruit__feature-item--05 {
  bottom: 12.5rem;
  left: 0;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item--05 {
    top: 26.75rem;
    bottom: auto;
    left: 0;
  }
}

.recruit__feature-item--06 {
  top: 12.5rem;
  left: 0;
}
@media screen and (max-width: 767.9px) {
  .recruit__feature-item--06 {
    top: 33rem;
    left: auto;
    right: 0;
  }
}

.recruit__culture {
  background-image: url(../img/bg_recruit-culture.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture {
    background-image: url(../img/bg_recruit-culture-sp.jpg);
  }
}
.recruit__culture::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  top: 0;
  left: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to bottom, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture::before {
    height: 2.5rem;
  }
}
.recruit__culture::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  bottom: 0;
  left: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture::after {
    height: 2.5rem;
  }
}

.recruit__culture-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 6.25rem;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture-inner {
    padding-top: 2.625rem;
    padding-bottom: 0rem;
    padding-inline: 0.9375rem;
    max-width: 31.25rem;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__culture-title.title {
    margin-inline: 0.625rem;
  }
}

.recruit__culture-sub-title {
  margin-top: 5rem;
  text-align: center;
  font-size: 6rem;
  line-height: 1.22;
  font-weight: 600;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture-sub-title {
    margin-top: 1.25rem;
    font-size: 2.25rem;
  }
}

.recruit__culture-items {
  margin-top: 7.9375rem;
  display: grid;
  gap: 1.125rem;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 767.9px) {
  .recruit__culture-items {
    margin-top: 1.875rem;
    grid-template-columns: repeat(1, 1fr);
    gap: 1.25rem;
  }
}

.recruit__culture-item {
  padding: 1.6875rem 1.25rem;
  text-align: center;
  border-radius: 0.375rem;
  min-height: 13.4375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture-item {
    padding: 1rem 1.25rem;
    min-height: 11.875rem;
  }
}

.recruit__culture-item-title {
  font-size: 1.5625rem;
  line-height: 1.16;
  letter-spacing: 0.07em;
  text-align: center;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture-item-title {
    font-size: 1.25rem;
    line-height: 1.45;
  }
}

.recruit__culture-item-text {
  margin-top: 1.8125rem;
  font-size: 0.896875rem;
  line-height: 1.7421602787;
  text-align: center;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .recruit__culture-item-text {
    font-size: 0.8125rem;
    line-height: 1.9230769231;
  }
}

.recruit__flow {
  --recruit-flow-scroll-step-sp: 380;
  --recruit-flow-item-step-sp: 13.75rem;
  --recruit-flow-circle-size-sp: 12.5rem;
  --recruit-flow-queue-gap-sp: 1.875rem;
  --recruit-flow-queue-stack-step-sp: 1.75rem;
  overflow: hidden;
  position: relative;
  background-image: url(../img/bg_recruit-flow.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 10;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow {
    min-height: 100lvh;
    padding: 0;
    overflow: visible;
    background-image: none;
  }
}
.recruit__flow::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  top: 0;
  left: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to bottom, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow::before {
    display: none;
  }
}
.recruit__flow::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 10.375rem;
  bottom: 0;
  left: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
  background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  z-index: -1;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow::after {
    display: none;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__flow-pin {
    height: 100lvh;
    overflow: hidden;
    position: relative;
    background-image: url(../img/bg_recruit-flow-sp.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 1;
  }
  .recruit__flow-pin::before, .recruit__flow-pin::after {
    position: absolute;
    content: "";
    left: 0;
    width: 100%;
    height: 10.375rem;
    pointer-events: none;
    z-index: 0;
  }
  .recruit__flow-pin::before {
    top: 0;
    background: -webkit-gradient(linear, left top, left bottom, from(#161A1C), to(rgba(22, 26, 28, 0)));
    background: linear-gradient(to bottom, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  }
  .recruit__flow-pin::after {
    bottom: 0;
    background: -webkit-gradient(linear, left bottom, left top, from(#161A1C), to(rgba(22, 26, 28, 0)));
    background: linear-gradient(to top, #161A1C 0%, rgba(22, 26, 28, 0) 100%);
  }
}

.recruit__flow-bg-text {
  display: none;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-bg-text {
    position: absolute;
    left: 50%;
    top: calc(var(--recruit-flow-circle-size-sp) + 2.5rem);
    bottom: auto;
    z-index: 0;
    display: block;
    font-family: "Cormorant Garamond", serif;
    font-size: 3.375rem;
    font-weight: 600;
    line-height: 1;
    color: #fff;
    white-space: nowrap;
    pointer-events: none;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    visibility: hidden;
  }
}

@supports not (height: 100lvh) {
  @media screen and (max-width: 767.9px) {
    .recruit__flow {
      min-height: 100vh;
    }
    .recruit__flow-pin {
      height: 100vh;
    }
  }
}
.recruit__flow-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding: 7.5rem 0 15rem;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-inner {
    max-width: none;
    height: 100%;
    min-height: 0;
    padding: 6rem 1.5625rem 2rem;
    position: relative;
    z-index: 2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.recruit__flow-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 3rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.22;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-title {
    font-size: 2.125rem;
    font-weight: 600;
    letter-spacing: 0;
  }
}

.recruit__flow-sub-title {
  margin-top: 1.25rem;
  font-size: 2.25rem;
  line-height: 2;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-sub-title {
    margin-top: 0.625rem;
    font-size: 1.5rem;
    line-height: 1.6666666667;
    letter-spacing: 0.07em;
  }
}

.recruit__flow-content {
  margin-top: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-content {
    margin-top: 1.25rem;
    width: 100%;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    min-height: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    overflow: visible;
  }
}

.recruit__flow-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-items {
    position: relative;
    display: block;
    width: var(--recruit-flow-circle-size-sp);
    height: calc(var(--recruit-flow-circle-size-sp) + var(--recruit-flow-queue-gap-sp) + var(--recruit-flow-queue-stack-step-sp) * 4 + var(--recruit-flow-circle-size-sp));
    min-height: calc(var(--recruit-flow-circle-size-sp) + var(--recruit-flow-queue-gap-sp) + var(--recruit-flow-queue-stack-step-sp) * 4 + var(--recruit-flow-circle-size-sp));
    overflow: visible;
  }
}
.recruit__flow-items::before {
  position: absolute;
  content: "AZ ONE GROUP";
  font-size: 10.1875rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #fff;
  top: -7.8125rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-items::before {
    display: none;
  }
}

.recruit__flow-item {
  width: 15.4375rem;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-item {
    position: absolute;
    top: 0;
    left: 50%;
    width: 12.5rem;
    height: 12.5rem;
    margin-left: -6.25rem;
  }
}

.recruit__flow-item + .recruit__flow-item {
  margin-left: -0.9375rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-item + .recruit__flow-item {
    margin-left: -6.25rem;
  }
}

.recruit__flow-item--01 {
  z-index: 1;
}

.recruit__flow-item--02 {
  z-index: 2;
}

.recruit__flow-item--03 {
  z-index: 3;
}

.recruit__flow-item--04 {
  z-index: 4;
}

.recruit__flow-item--05 {
  z-index: 5;
}

.recruit__flow-circle {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  text-align: center;
  color: #fff;
  padding: 1.875rem 0.625rem 2.9375rem;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-circle {
    padding: 1.375rem 0.625rem 2.5rem;
  }
}

@media screen and (max-width: 767.9px) {
  .recruit__flow-circle.glass02 {
    background: linear-gradient(145deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.6) 38%, rgba(0, 0, 0, 0.4) 100%);
  }
}

.recruit__flow-number {
  font-size: 2.5rem;
  line-height: 1;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-number {
    font-size: 2rem;
  }
}

.recruit__flow-en {
  font-family: "Cormorant Garamond", serif;
  font-size: 2.375rem;
  line-height: 0.8684210526;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-en {
    margin-top: 0.5rem;
    font-size: 1.9375rem;
  }
}

.recruit__flow-ja {
  font-size: 1.875rem;
  line-height: 1.1333333333;
  letter-spacing: 0.14em;
}
@media screen and (max-width: 767.9px) {
  .recruit__flow-ja {
    margin-top: 0.5rem;
    font-size: 1.5rem;
  }
}

.page-head.page-head--ma .page-head__title-en span {
  font-size: 4.5rem;
}
@media screen and (max-width: 767.9px) {
  .page-head.page-head--ma .page-head__title-en span {
    font-size: 2.625rem;
  }
}

.ma-approach-sequence {
  position: relative;
  max-width: 100%;
}

.ma-approach-sequence.is-scroll-sequence-active {
  height: 100lvh;
  min-height: 100svh;
  overflow: hidden;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main,
.ma-approach-sequence.is-scroll-sequence-active .qa-section__main {
  min-height: 0;
  overflow-x: visible;
  overflow-y: visible;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow,
.ma-approach-sequence.is-scroll-sequence-active .qa-section__main.is-scroll-overflow {
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-width: thin;
  overscroll-behavior-y: contain;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow::-webkit-scrollbar,
.ma-approach-sequence.is-scroll-sequence-active .qa-section__main.is-scroll-overflow::-webkit-scrollbar {
  width: 4px;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow::-webkit-scrollbar-thumb,
.ma-approach-sequence.is-scroll-sequence-active .qa-section__main.is-scroll-overflow::-webkit-scrollbar-thumb {
  background-color: rgba(255, 255, 255, 0.25);
  border-radius: 2px;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel {
  height: 100%;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__layout {
  max-height: 100%;
  min-height: 0;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__layout-inner {
  max-height: 100%;
  min-height: 0;
  overflow: hidden;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main {
  overflow: hidden;
  min-height: 0;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow {
  overflow-x: hidden;
  overflow-y: auto;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__layout--case .split-panel__layout-inner {
  overflow: visible;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main.split-panel__main--case {
  overflow: visible;
}
.ma-approach-sequence.is-scroll-sequence-active .split-panel__main.split-panel__main--case.is-scroll-overflow {
  overflow: visible;
}
.ma-approach-sequence.is-scroll-sequence-active.startup-support-approach-sequence .split-panel__layout-inner,
.ma-approach-sequence.is-scroll-sequence-active.startup-support-approach-sequence .split-panel__main,
.ma-approach-sequence.is-scroll-sequence-active.startup-support-approach-sequence .split-panel__main.is-scroll-overflow {
  overflow: visible;
}
@media screen and (max-width: 767.9px) {
  .ma-approach-sequence.is-scroll-sequence-active .split-panel {
    height: 100%;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__layout {
    height: 100%;
    max-height: 100%;
    min-height: 0;
    overflow: hidden;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__layout-inner {
    height: 100%;
    max-height: 100%;
    min-height: 0;
    overflow: hidden;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__side {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    max-width: 31.25rem;
    margin-inline: auto;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__main {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 auto;
            flex: 0 1 auto;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    max-width: 31.25rem;
    margin-inline: auto;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: auto;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow,
  .ma-approach-sequence.is-scroll-sequence-active .qa-section__main.is-scroll-overflow {
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: rgba(117, 117, 117, 0.45) transparent;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow::-webkit-scrollbar,
  .ma-approach-sequence.is-scroll-sequence-active .qa-section__main.is-scroll-overflow::-webkit-scrollbar {
    width: 4px;
  }
  .ma-approach-sequence.is-scroll-sequence-active .split-panel__main.is-scroll-overflow::-webkit-scrollbar-thumb,
  .ma-approach-sequence.is-scroll-sequence-active .qa-section__main.is-scroll-overflow::-webkit-scrollbar-thumb {
    background-color: rgba(117, 117, 117, 0.45);
    border-radius: 2px;
  }
}

.split-panel {
  position: relative;
  isolation: isolate;
  height: 100lvh;
}

.split-panel__layout {
  position: relative;
  z-index: 1;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  height: 100lvh;
}
.split-panel__layout::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url(../img/deco_silver.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
}

.split-panel__layout-inner {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 90rem;
  height: 100%;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .split-panel__layout-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: none;
    padding: 2.5rem 1.5625rem;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.split-panel__layout.split-panel__layout--value {
  color: #fff;
}
.split-panel__layout.split-panel__layout--value::before {
  background-color: #171B1D;
  background-image: none;
}
.split-panel__layout.split-panel__layout--value .split-panel__title {
  color: #fff;
}
.split-panel__layout.split-panel__layout--value .split-panel__title.split-panel__title--large {
  font-size: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__layout.split-panel__layout--value .split-panel__title.split-panel__title--large {
    font-size: 1.5rem;
  }
}
.split-panel__layout.split-panel__layout--value .split-panel__nav-link {
  color: #fff;
}
.split-panel__layout.split-panel__layout--value .split-panel__nav-link:hover {
  color: rgba(255, 255, 255, 0.5);
}
.split-panel__layout.split-panel__layout--value .split-panel__nav-link.is-current {
  color: rgba(255, 255, 255, 0.5);
}
.split-panel__layout.split-panel__layout--value .split-panel__text {
  color: #fff;
}
.split-panel__layout.split-panel__layout--value .split-panel__bg-title {
  color: #2E363A;
}

@media screen and (max-width: 767.9px) {
  .split-panel__layout.split-panel__layout--case .split-panel__layout-inner {
    padding: 6.25rem 0 2.5rem;
  }
}

@media screen and (max-width: 767.9px) {
  #case[data-ma-case-detached="1"] {
    height: auto;
    min-height: 0;
  }
  #case[data-ma-case-detached="1"] .split-panel__layout {
    height: auto;
    min-height: 100svh;
    overflow: visible;
  }
  #case[data-ma-case-detached="1"] .split-panel__layout-inner {
    height: auto;
    min-height: 0;
    overflow: visible;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.split-panel__side {
  -webkit-box-flex: 530;
      -ms-flex: 530;
          flex: 530;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  min-height: 0;
  padding: clamp(3rem, 15.5vh, 8.75rem) 4.375rem clamp(3rem, 15.5vh, 8.75rem) 8.125rem;
  padding: 7.5rem 4.375rem 8.5rem 8.125rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__side {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
    padding: 0;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.split-panel__side.split-panel__side--value {
  background-color: #171B1D;
}

@media screen and (max-width: 767.9px) {
  .split-panel__side.split-panel__side--case {
    padding-inline: 1.5625rem;
  }
}

.split-panel__side-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-height: 0;
  width: 100%;
  max-width: 22.5rem;
  margin-top: clamp(2.5rem, 6vh, 8.75rem);
}
@media screen and (max-width: 767.9px) {
  .split-panel__side-inner {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    max-width: none;
    margin-top: 0;
  }
}

.split-panel__number {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 2rem;
  line-height: 2;
  color: #ADADAD;
}
@media screen and (max-width: 767.9px) {
  .split-panel__number {
    font-size: 1.75rem;
    line-height: 1.5;
  }
}

.split-panel__title {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 2.0625rem;
  line-height: 2;
  color: #2B2B2B;
  letter-spacing: 0.03em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .split-panel__title {
    font-size: 1.5rem;
  }
}
.split-panel__title span {
  font-family: "Cormorant Garamond", serif;
  font-size: 2.5rem;
  line-height: 1.22;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .split-panel__title span {
    font-size: 1.75rem;
  }
}

.split-panel__divider {
  display: block;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  margin-top: clamp(1rem, 2.8vh, 2.5rem);
  width: 1px;
  min-height: 3rem;
  max-height: 16.875rem;
  background-color: rgba(169, 169, 169, 0.4);
}
@media screen and (max-width: 767.9px) {
  .split-panel__divider {
    display: none;
  }
}

.split-panel__nav {
  width: 100%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-top: clamp(1rem, 2.8vh, 2.5rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0.5625rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__nav {
    margin-top: 0.625rem;
    gap: 0;
  }
}

.split-panel__nav-link {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 2;
  color: #2B2B2B;
  letter-spacing: 0.07em;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.split-panel__nav-link:hover {
  color: rgba(43, 43, 43, 0.5);
}
.split-panel__nav-link.is-current {
  color: rgba(43, 43, 43, 0.5);
}
@media screen and (max-width: 767.9px) {
  .split-panel__nav-link {
    font-size: 1rem;
    color: #B3B3B3;
  }
}

.split-panel__title-row {
  width: 100%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .split-panel__title-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 0.75rem;
  }
}
@media screen and (max-width: 767.9px) {
  .split-panel__title-row .split-panel__title {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    min-width: 0;
  }
}
@media screen and (min-width: 768px) {
  .split-panel__title-row {
    display: contents;
  }
}

@media screen and (min-width: 768px) {
  .split-panel__side-inner:has(.split-panel__title-row) .split-panel__number {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .split-panel__side-inner:has(.split-panel__title-row) .split-panel__title {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .split-panel__side-inner:has(.split-panel__title-row) .split-panel__divider {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .split-panel__side-inner:has(.split-panel__title-row) .split-panel__nav {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
  .split-panel__side-inner:has(.split-panel__title-row) .split-panel__nav-more {
    -webkit-box-ordinal-group: 6;
        -ms-flex-order: 5;
            order: 5;
  }
}

.split-panel__nav-more.btn {
  margin-top: 8.5rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__nav-more.btn {
    margin-top: 0;
    margin-inline: 0;
    width: 11.25rem;
    max-width: none;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.split-panel__main {
  position: relative;
  z-index: 0;
  -webkit-box-flex: 910;
      -ms-flex: 910;
          flex: 910;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 8.75rem 8.125rem 8.75rem 7.9375rem;
  background-color: transparent;
}
.split-panel__main::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset-block: 0;
  inset-inline-start: 0;
  inset-inline-end: calc(50% - 50vw);
  background-color: rgba(255, 255, 255, 0.4);
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .split-panel__main::before {
    display: none;
  }
}
@media screen and (max-width: 767.9px) {
  .split-panel__main {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
    padding: 0;
  }
}

.split-panel__layout--value .split-panel__main::before {
  background-color: #151819;
}

@media screen and (max-width: 767.9px) {
  .split-panel__main.split-panel__main--case .split-panel__main-inner, .split-panel__main.split-panel__main--case .split-panel__case-studies-description-title, .split-panel__main.split-panel__main--case .split-panel__bg-title, .split-panel__main.split-panel__main--case .split-panel__case-studies-text {
    padding-inline: 1.5625rem;
  }
}
.split-panel__main.split-panel__main--case .split-panel__case-studies-description-title {
  margin-top: 4.0625rem;
}

.split-panel__main:has(.split-panel__case-studies-content) {
  padding: 8.75rem 0 8.75rem 7.9375rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__main:has(.split-panel__case-studies-content) {
    padding: 1.25rem 0 0;
  }
}

.split-panel__main-inner {
  width: 100%;
  max-width: 40.8125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
  max-height: 43.75rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__main-inner {
    max-width: none;
  }
}

.split-panel__bg-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  line-height: 1.22;
  color: #B5B5B5;
}
@media screen and (max-width: 767.9px) {
  .split-panel__bg-title {
    font-size: 2.25rem;
  }
}

.split-panel__text {
  margin-top: clamp(3rem, 35vh, 19.75rem);
  margin-top: auto;
  color: #2B2B2B;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .split-panel__text {
    margin-top: 1.25rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

.split-panel__accordion {
  margin-top: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion {
    margin-top: 0;
  }
}

.split-panel__accordion-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  padding: 1.875rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  border-bottom: 1px solid rgba(169, 169, 169, 0.4);
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-header {
    padding: 1.25rem 0;
  }
}

.split-panel__accordion-title {
  font-size: 1.75rem;
  line-height: 1.22;
  letter-spacing: 0.07em;
}
.split-panel__layout--value .split-panel__accordion-title {
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-title {
    font-size: 1.125rem;
  }
}

.split-panel__accordion-icon {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  background-color: #2E363A;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.is-open .split-panel__accordion-icon {
  background-color: #fff;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-icon {
    width: 2rem;
    height: 2rem;
  }
}
.split-panel__accordion-icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 1.25rem;
  height: 2px;
  background-color: #fff;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.split-panel__layout--value .split-panel__accordion-icon::before {
  background-color: #fff;
}
.is-open .split-panel__accordion-icon::before {
  background-color: #2E363A;
}
.split-panel__layout--value .is-open .split-panel__accordion-icon::before {
  background-color: #2E363A;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-icon::before {
    width: 1rem;
  }
}
.split-panel__accordion-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 2px;
  height: 1.25rem;
  background-color: #fff;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease;
}
.split-panel__layout--value .split-panel__accordion-icon::after {
  background-color: #fff;
}
.is-open .split-panel__accordion-icon::after {
  opacity: 0;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-icon::after {
    height: 1rem;
  }
}

.split-panel__accordion-content {
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.3s ease;
  transition: max-height 0.3s ease;
}

.split-panel__accordion-content-inner {
  padding-bottom: 2rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-content-inner {
    padding-bottom: 1.5rem;
  }
}

.split-panel__accordion-text {
  margin-top: 1.25rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
}
@media screen and (max-width: 767.9px) {
  .split-panel__accordion-text {
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

.qa-section {
  position: relative;
  isolation: isolate;
  height: 100lvh;
}
@media screen and (max-width: 767.9px) {
  .qa-section {
    height: auto;
  }
}

.qa-section[data-ma-faq-detached="1"] {
  height: auto;
}
.qa-section[data-ma-faq-detached="1"] .qa-section__layout,
.qa-section[data-ma-faq-detached="1"] .qa-section__layout-inner,
.qa-section[data-ma-faq-detached="1"] .qa-section__main-inner {
  height: auto;
  max-height: none;
}
.qa-section[data-ma-faq-detached="1"] .qa-section__layout,
.qa-section[data-ma-faq-detached="1"] .qa-section__layout-inner {
  overflow: visible;
}

@media screen and (max-width: 767.9px) {
  .startup-support-faq-sequence {
    height: auto;
    min-height: 0;
    overflow: visible;
  }
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section,
  #faq.qa-section[data-ma-faq-detached="1"] {
    position: relative;
    inset: auto;
    width: 100%;
    height: auto;
    min-height: 0;
  }
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section {
    pointer-events: auto;
  }
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section .qa-section__layout,
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section .qa-section__layout-inner,
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section .qa-section__main-inner,
  #faq.qa-section[data-ma-faq-detached="1"] .qa-section__layout,
  #faq.qa-section[data-ma-faq-detached="1"] .qa-section__layout-inner,
  #faq.qa-section[data-ma-faq-detached="1"] .qa-section__main-inner {
    height: auto;
    max-height: none;
  }
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section .qa-section__layout,
  .ma-approach-sequence.is-scroll-sequence-active > #faq.qa-section .qa-section__layout-inner,
  #faq.qa-section[data-ma-faq-detached="1"] .qa-section__layout,
  #faq.qa-section[data-ma-faq-detached="1"] .qa-section__layout-inner {
    overflow: visible;
  }
  #faq.qa-section .qa-section__layout-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: none;
    padding: 6.25rem 1.5625rem 2.5rem;
  }
  #faq.qa-section .qa-section__side,
  #faq.qa-section .qa-section__main {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
    max-width: 31.25rem;
    margin-inline: auto;
  }
  #faq.qa-section .qa-section__side {
    padding: 0;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  #faq.qa-section .qa-section__main {
    margin-top: 1rem;
    padding: 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.qa-section__layout {
  position: relative;
  z-index: 1;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  height: 100lvh;
  color: #fff;
}
.qa-section__layout::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-color: #171B1D;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .qa-section__layout {
    height: auto;
    overflow: visible;
  }
}

.qa-section__layout-inner {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 90rem;
  height: 100%;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .qa-section__layout-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: none;
    height: auto;
    overflow: visible;
    padding: 6.25rem 1.5625rem 2.5rem;
  }
}

.qa-section__side {
  -webkit-box-flex: 530;
      -ms-flex: 530;
          flex: 530;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 7.5rem 4.375rem 8.5rem 8.125rem;
  background-color: #171B1D;
}
@media screen and (max-width: 767.9px) {
  .qa-section__side {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
    padding: 0;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    max-width: 31.25rem;
    margin-inline: auto;
  }
}

.qa-section__side-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: 100%;
  max-width: 22.5rem;
  margin-top: clamp(5rem, 8vh, 8.75rem);
}
@media screen and (max-width: 767.9px) {
  .qa-section__side-inner {
    max-width: none;
    margin-top: 0;
  }
}

.qa-section__number {
  font-size: 2rem;
  line-height: 2;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .qa-section__number {
    font-size: 1.75rem;
  }
}

.qa-section__title {
  font-size: 2.0625rem;
  line-height: 1.22;
  color: #fff;
  letter-spacing: 0.03em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .qa-section__title {
    font-size: 1.5rem;
  }
}

.qa-section__title.qa-section__title--large {
  font-size: 2.5rem;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .qa-section__title.qa-section__title--large {
    font-size: 1.5rem;
    line-height: 1.5;
  }
}

.qa-section__divider {
  display: block;
  margin-top: 2.5rem;
  width: 1px;
  height: 16.875rem;
  background-color: rgba(255, 255, 255, 0.4);
}
@media screen and (max-width: 767.9px) {
  .qa-section__divider {
    display: none;
  }
}

.qa-menu {
  margin-top: 1.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0;
  width: 100%;
  padding-left: 1.875rem;
  border-left: 1px solid rgba(169, 169, 169, 0.4);
}
@media screen and (max-width: 767.9px) {
  .qa-menu {
    display: none;
  }
}

.qa-menu__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  padding: 0.75rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .qa-menu__item {
    padding: 1.5rem 0;
  }
}
.qa-menu__item:first-child {
  padding-top: 0;
}
.qa-menu__item:last-child {
  padding-bottom: 0;
}

.qa-menu__text {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.07em;
  padding-right: 2.5rem;
  color: #DBDBDB;
  padding-left: 1.2em;
  text-indent: -1.2em;
}
@media screen and (max-width: 767.9px) {
  .qa-menu__text {
    font-size: 1rem;
  }
}
.qa-menu__text span {
  color: #386C95;
}

.qa-menu__icon {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  background-color: #2E363A;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.is-active .qa-menu__icon {
  background-color: #fff;
}
@media screen and (max-width: 767.9px) {
  .qa-menu__icon {
    width: 2rem;
    height: 2rem;
  }
}
.qa-menu__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 0.625rem;
  height: 1px;
  background-color: #fff;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.is-active .qa-menu__icon::before {
  background-color: #2E363A;
}
@media screen and (max-width: 767.9px) {
  .qa-menu__icon::before {
    width: 1rem;
  }
}
.qa-menu__icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 1px;
  height: 0.625rem;
  background-color: #fff;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease;
}
.is-active .qa-menu__icon::after {
  opacity: 0;
}
@media screen and (max-width: 767.9px) {
  .qa-menu__icon::after {
    height: 1rem;
    opacity: 1;
    background-color: #fff;
  }
  .is-active .qa-menu__icon::after {
    opacity: 0;
  }
}

.qa-section__main {
  position: relative;
  z-index: 0;
  -webkit-box-flex: 910;
      -ms-flex: 910;
          flex: 910;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 7.5rem 8.125rem 8.25rem 7.9375rem;
  background-color: transparent;
}
.qa-section__main::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset-block: 0;
  inset-inline-start: 0;
  inset-inline-end: calc(50% - 50vw);
  background-color: #151819;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .qa-section__main::before {
    display: none;
  }
}
@media screen and (max-width: 767.9px) {
  .qa-section__main {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
    padding: 0;
    margin-top: 1rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    max-width: 31.25rem;
    margin-inline: auto;
  }
}

.qa-section__main-inner {
  width: 100%;
  max-width: 40.8125rem;
  height: 100%;
  max-height: 43.75rem;
}
@media screen and (max-width: 767.9px) {
  .qa-section__main-inner {
    max-width: none;
    height: auto;
    max-height: none;
  }
}

.qa-section__bg-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 6rem;
  font-weight: 600;
  line-height: 1.22;
  color: #2E363A;
}
@media screen and (max-width: 767.9px) {
  .qa-section__bg-title {
    font-size: 1.75rem;
  }
}

.qa-content {
  margin-top: 2.5rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .qa-content {
    margin-top: 0;
  }
}

@media (min-width: 768px) {
  .qa-content__item {
    display: none;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  .qa-content__item.is-active {
    display: block;
    opacity: 1;
  }
}

.qa-content__question {
  font-size: 1.75rem;
  line-height: 1.4;
  font-weight: 400;
  letter-spacing: 0.07em;
  color: #fff;
  padding-bottom: 1.875rem;
  border-bottom: 1px solid rgba(169, 169, 169, 0.4);
  padding-left: 1.2em;
  text-indent: -1.2em;
}
@media screen and (max-width: 767.9px) {
  .qa-content__question {
    position: relative;
    font-size: 0.9375rem;
    padding: 1.25rem 2.8125rem 1.25rem 1.5625rem;
    cursor: pointer;
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    line-height: 1.5333333333;
    letter-spacing: 0.03em;
  }
  .qa-content__question::after {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 2rem;
    height: 2rem;
    background-color: #2E363A;
    background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff)), -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff));
    background-image: linear-gradient(#fff, #fff), linear-gradient(#fff, #fff);
    background-size: 1rem 2px, 2px 1rem;
    background-position: center;
    background-repeat: no-repeat;
    -webkit-transition: background-color 0.3s ease;
    transition: background-color 0.3s ease;
  }
  .is-active .qa-content__question::after {
    background-color: #fff;
    background-image: -webkit-gradient(linear, left top, left bottom, from(#2E363A), to(#2E363A));
    background-image: linear-gradient(#2E363A, #2E363A);
    background-size: 1rem 2px;
  }
}
.qa-content__question span {
  color: #386C95;
}

.qa-content__answer {
  margin-top: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .qa-content__answer {
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height 0.3s ease;
    transition: max-height 0.3s ease;
    margin-top: 0;
  }
  .is-active .qa-content__answer {
    max-height: 2000px;
  }
}
@media screen and (max-width: 767.9px) {
  .qa-content__answer p:first-child {
    padding-top: 0;
  }
  .qa-content__answer p:last-child {
    padding-bottom: 1.5rem;
  }
}

.qa-content__answer-text {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .qa-content__answer-text {
    margin-top: 1.25rem;
    font-size: 0.8125rem;
    line-height: 2.4615384615;
    letter-spacing: 0.03em;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
}

@media screen and (max-width: 767.9px) {
  .qa-content__answer-img-scroll {
    position: relative;
    margin-top: 1.25rem;
    margin-left: -1.5625rem;
    margin-right: -1.5625rem;
    padding-left: 1.5625rem;
    padding-right: 1.5625rem;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
  }
  .qa-content__answer-img-scroll::-webkit-scrollbar {
    display: none;
  }
  .qa-content__answer-img-scroll.is-scrollable:not(.is-scrolled)::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 3.75rem;
    height: 100%;
    pointer-events: none;
    background: -webkit-gradient(linear, left top, right top, from(rgba(21, 24, 25, 0)), to(rgba(21, 24, 25, 0.75)));
    background: linear-gradient(to right, rgba(21, 24, 25, 0), rgba(21, 24, 25, 0.75));
  }
}

.scroll-hint {
  display: none;
}

@media screen and (max-width: 767.9px) {
  .qa-content__answer-img-scroll.is-scrollable:not(.is-scrolled) .scroll-hint {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0.375rem;
    position: absolute;
    z-index: 1;
    right: 2rem;
    bottom: 0.75rem;
    padding: 0.3125rem 0.625rem;
    border-radius: 1.25rem;
    background-color: rgba(255, 255, 255, 0.92);
    color: #151819;
    font-family: "Cormorant Garamond", serif;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1;
    pointer-events: none;
  }
  .scroll-hint__icon {
    position: relative;
    width: 1.125rem;
    height: 0.625rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .scroll-hint__icon::before, .scroll-hint__icon::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 0.3125rem;
    height: 0.3125rem;
    border-right: 0.125rem solid currentColor;
    border-bottom: 0.125rem solid currentColor;
    -webkit-transform: translateY(-50%) rotate(-45deg);
            transform: translateY(-50%) rotate(-45deg);
    -webkit-animation: qa-scroll-hint-arrow 1.4s ease-in-out infinite;
            animation: qa-scroll-hint-arrow 1.4s ease-in-out infinite;
  }
  .scroll-hint__icon::before {
    left: 0;
  }
  .scroll-hint__icon::after {
    left: 0.4375rem;
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
    opacity: 0.55;
  }
}
@-webkit-keyframes qa-scroll-hint-arrow {
  0%, 100% {
    -webkit-transform: translateY(-50%) translateX(0) rotate(-45deg);
            transform: translateY(-50%) translateX(0) rotate(-45deg);
    opacity: 1;
  }
  50% {
    -webkit-transform: translateY(-50%) translateX(0.1875rem) rotate(-45deg);
            transform: translateY(-50%) translateX(0.1875rem) rotate(-45deg);
    opacity: 0.45;
  }
}
@keyframes qa-scroll-hint-arrow {
  0%, 100% {
    -webkit-transform: translateY(-50%) translateX(0) rotate(-45deg);
            transform: translateY(-50%) translateX(0) rotate(-45deg);
    opacity: 1;
  }
  50% {
    -webkit-transform: translateY(-50%) translateX(0.1875rem) rotate(-45deg);
            transform: translateY(-50%) translateX(0.1875rem) rotate(-45deg);
    opacity: 0.45;
  }
}
.qa-content__answer-img {
  margin-top: clamp(0rem, 2vh, 1.25rem);
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .qa-content__answer-img {
    margin-top: 0;
  }
}

.qa-content__answer-img.qa-content__answer-img--01 {
  margin-left: -1.5625rem;
}
@media screen and (max-width: 767.9px) {
  .qa-content__answer-img.qa-content__answer-img--01 {
    margin-left: 0;
    display: block;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 125%;
    max-width: 28.75rem;
    height: auto;
  }
}

.split-panel__case-studies-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
}

.split-panel__case-studies {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.split-panel__case-studies-img-wrap {
  position: relative;
  margin-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .split-panel__case-studies-img-wrap {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    margin-top: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

@media screen and (max-width: 767.9px) {
  .split-panel__case-studies .split-panel__bg-title {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-top: 0.5rem;
  }
}

.split-panel__case-studies-visual {
  position: relative;
  width: calc(100% + (100vw - min(100vw, 90rem)) / 2);
}
@media screen and (max-width: 767.9px) {
  .split-panel__case-studies-visual {
    width: 100%;
  }
}

.split-panel__case-studies-img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}

.split-panel__case-studies-description-wrap {
  position: absolute;
  bottom: -3.75rem;
  left: 3.9375rem;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  min-height: 5.875rem;
  padding: 1.3125rem 8.125rem 1.3125rem 2.5rem;
  background-color: #F8F8F8;
  -webkit-box-shadow: 0 0.25rem 0.25rem rgba(205, 205, 205, 0.25);
          box-shadow: 0 0.25rem 0.25rem rgba(205, 205, 205, 0.25);
}
.split-panel__case-studies-description-wrap::before {
  position: absolute;
  content: "";
  width: 18.75rem;
  height: 100%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #fff;
  z-index: -1;
  clip-path: polygon(0 0, 100% 0, 90% 100%, 0 100%);
}
@media screen and (max-width: 767.9px) {
  .split-panel__case-studies-description-wrap {
    bottom: -2.5625rem;
    left: 0;
    right: 0;
    width: 90%;
    min-height: 5.125rem;
    padding: 0.9375rem 1.5625rem 0.9375rem 4.1875rem;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    margin-left: auto;
    clip-path: polygon(10% 0%, 100% 0, 100% 100%, 0 100%);
  }
  .split-panel__case-studies-description-wrap::before {
    display: none;
  }
}

.split-panel__case-studies-description-title {
  position: absolute;
  bottom: -3.75rem;
  left: 6.4375rem;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 5.875rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .split-panel__case-studies-description-title {
    position: static;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    min-height: 0;
    margin-top: 1rem;
    font-size: 1rem;
    line-height: 3;
    letter-spacing: 0.07em;
    color: #2B2B2B;
  }
}

.split-panel__case-studies-description-text {
  max-width: 17.0625rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .split-panel__case-studies-description-text {
    max-width: none;
    font-size: 0.875rem;
    line-height: 1.7142857143;
    letter-spacing: 0.03em;
    color: #2B2B2B;
  }
}

.split-panel__case-studies-text {
  max-width: 40.8125rem;
  margin-top: 6.875rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .split-panel__case-studies-text {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
    max-width: none;
    margin-top: 1.25rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

@media screen and (max-width: 767.9px) {
  .page-head.page-head--startup-support .page-head__title-en {
    font-size: 2.5rem;
    white-space: nowrap;
  }
}

@media screen and (max-width: 767.9px) {
  .split-panel__main.split-panel__main--startup-support .split-panel__accordion-title {
    font-size: 1.75rem;
    letter-spacing: 0;
  }
}

.startup__support-inner {
  padding-bottom: 2.5rem;
}

.startup__support-head {
  background-image: url(../img/startup-support_head-bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .startup__support-head {
    background-image: url(../img/startup-support_head-bg-sp.jpg);
  }
}

.startup__support-head-inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767.9px) {
  .startup__support-head-inner {
    max-width: 31.25rem;
    padding-top: 1.875rem;
    padding-bottom: 6.5625rem;
  }
}

.startup__support-label {
  font-size: 6rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #fff;
  line-height: 1.17;
}
@media screen and (max-width: 767.9px) {
  .startup__support-label {
    font-size: 3rem;
    text-align: center;
  }
}

.startup__support-title {
  margin-top: 2.5rem;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: 0.07em;
  color: #fff;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .startup__support-title {
    margin-top: 1rem;
    font-size: 1rem;
    text-align: center;
  }
}

.startup__support-content {
  max-width: 86.25rem;
  margin-inline: auto;
  margin-top: -3.75rem;
}
@media screen and (max-width: 767.9px) {
  .startup__support-content {
    max-width: 37.5rem;
    padding-inline: 1.125rem;
    margin-top: -6.75rem;
  }
}

.startup__support-item {
  border-radius: 0.25rem;
  padding: 2.25rem 6.25rem 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 6.25rem;
  -webkit-transition: padding 0.45s ease;
  transition: padding 0.45s ease;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item {
    padding: 1.5rem 2.5rem 1.5rem 1rem;
    gap: 0.8125rem;
  }
}

.startup__support-item.glass {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.7) 0%, rgba(255, 255, 255, 0.7) 38%, rgba(255, 255, 255, 0.7) 100%);
  backdrop-filter: blur(3px) saturate(1.35);
  -webkit-backdrop-filter: blur(3px) saturate(1.35);
  -webkit-box-shadow: 0 0 1.5625rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5625rem rgba(117, 117, 117, 0.25);
}

.startup__support-item.is-active {
  padding-top: 6.9375rem;
  padding-bottom: 4.75rem;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item.is-active {
    padding-top: 1.5rem;
    padding-bottom: 1.875rem;
  }
}

.startup__support-item-text {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.06em;
  color: #2B2B2B;
  max-width: 42.5rem;
  overflow: hidden;
  max-height: 0;
  margin-top: 0;
  opacity: 0;
  -webkit-transition: max-height 0.45s ease, margin-top 0.45s ease, opacity 0.35s ease;
  transition: max-height 0.45s ease, margin-top 0.45s ease, opacity 0.35s ease;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item-text {
    margin-top: 0.625rem;
    font-size: 0.875rem;
    line-height: 2.2857142857;
    letter-spacing: 0.03em;
  }
}

.startup__support-item.is-active .startup__support-item-text {
  max-height: 20rem;
  margin-top: 2.5rem;
  opacity: 1;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item.is-active .startup__support-item-text {
    margin-top: 1.25rem;
  }
}

.startup__support-item-number {
  font-size: 6rem;
  color: #386C95;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item-number {
    font-size: 2.25rem;
    line-height: 0.7;
  }
}

.startup__support-item-label {
  font-size: 2.9375rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #151819;
  line-height: 1.22;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item-label {
    font-size: 1.75rem;
  }
}

@media screen and (max-width: 767.9px) {
  .startup__support-item-label.startup__support-item-label--small {
    font-size: 1.5625rem;
  }
}

.startup__support-item-title {
  margin-top: 0.625rem;
  font-size: 1.5rem;
  line-height: 2;
  letter-spacing: 0.07em;
  color: #171B1D;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .startup__support-item-title {
    font-size: 1rem;
  }
}

@media screen and (max-width: 767.9px) {
  .page-head.page-head--news .page-head__inner {
    padding-bottom: 3.75rem;
  }
}

.news {
  background-color: #F9F9F9;
}

.news__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .news__inner {
    max-width: 34.375rem;
    padding: 1.875rem 1.5625rem 3.75rem;
  }
}

.news__items {
  display: grid;
  gap: 2.5rem 3.125rem;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 767.9px) {
  .news__items {
    grid-template-columns: repeat(1, 1fr);
    gap: 1.25rem;
  }
}

.news__item {
  padding: 1.875rem 3.75rem;
  border-radius: 0.5rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .news__item {
    padding: 1.125rem 1.5rem;
  }
}
.news__item::before {
  position: absolute;
  content: "";
  width: 4.25rem;
  height: 1.875rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 3.75rem;
  background-image: url(../img/icon_arrow-gray.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 1;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .news__item::before {
    width: 2.5625rem;
    height: 1.125rem;
    right: 1.5rem;
  }
}

.news__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5rem;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .news__meta {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.news__date {
  font-size: 1rem;
  letter-spacing: 0.05em;
  color: #2B2B2B;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767.9px) {
  .news__date {
    font-size: 0.8125rem;
    margin-bottom: 0;
  }
}

.news__category {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  z-index: 2;
  pointer-events: auto;
  background-color: #242A2E;
  color: #fff;
  font-size: 1rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  letter-spacing: 0.05em;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  min-height: 1.75rem;
  border-radius: 100vw;
  padding: 0 0.9375rem;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
@supports (text-box-trim: trim-both) {
  .news__category {
    text-box-trim: trim-both;
    text-box-edge: cap alphabetic;
  }
}
@media screen and (max-width: 767.9px) {
  .news__category {
    font-size: 0.8125rem;
    min-height: 1.375rem;
    padding: 0 0.5625rem;
  }
}
.news__category:hover {
  opacity: 1;
  background-color: #fff;
  color: #242A2E;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
}
@media screen and (max-width: 767.9px) {
  .news__category:hover {
    background-color: #242A2E;
    color: #fff;
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

.news__title {
  margin-top: 1rem;
  font-size: 1.375rem;
  font-weight: 400;
  line-height: 1.4545454545;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}
@media screen and (max-width: 767.9px) {
  .news__title {
    margin-top: 0.6875rem;
    font-size: 0.875rem;
    line-height: 1.3571428571;
  }
}

.news__link {
  display: block;
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  letter-spacing: 0.07em;
  color: #2B2B2B;
  text-decoration: none;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  padding-right: 5.75rem;
}
@media screen and (max-width: 767.9px) {
  .news__link {
    padding-right: 4.0625rem;
  }
}
.news__link::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .news__item.glass {
    -webkit-transition: -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
    transition: -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
    transition: box-shadow 0.3s ease, transform 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
  }
  .news__item.glass:has(.news__link:hover), .news__item.glass:has(.news__link:focus-visible) {
    -webkit-transform: translateY(-0.125rem);
            transform: translateY(-0.125rem);
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.16), 0 0.75rem 2.5rem rgba(45, 45, 45, 0.18), 0 0.25rem 0.75rem rgba(255, 255, 255, 0.28);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.16), 0 0.75rem 2.5rem rgba(45, 45, 45, 0.18), 0 0.25rem 0.75rem rgba(255, 255, 255, 0.28);
  }
  .news__item.glass:has(.news__link:hover)::before, .news__item.glass:has(.news__link:focus-visible)::before {
    -webkit-transform: translateY(-50%) translateX(0.375rem);
            transform: translateY(-50%) translateX(0.375rem);
  }
  .news__link:hover,
  .news__link:focus-visible {
    opacity: 0.65;
  }
}
.page-head.page-head--cases {
  background-color: #fff;
}

.page-head.page-head--cases .page-head__title-en span {
  font-size: 4.5rem;
}
@media screen and (max-width: 767.9px) {
  .page-head.page-head--cases .page-head__title-en span {
    font-size: 2.625rem;
  }
}

.cases__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding: 5rem 0 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .cases__inner {
    max-width: 31.25rem;
    padding: 1.875rem 1.5625rem 3.75rem;
  }
}

.cases__items {
  display: grid;
  gap: 3.75rem 3.125rem;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 767.9px) {
  .cases__items {
    grid-template-columns: repeat(1, 1fr);
    gap: 1.25rem;
  }
}

.cases__item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 2.5rem;
  border-radius: 0.5rem;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .cases__item {
    border-radius: 0.3125rem;
    padding: 1.25rem;
  }
}
.cases__item::before {
  position: absolute;
  content: "";
  width: 4.25rem;
  height: 1.875rem;
  bottom: 2.5rem;
  right: 2.5rem;
  background-image: url(../img/icon_arrow-black.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 1;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .cases__item::before {
    width: 2.5625rem;
    height: 1.125rem;
    right: 1.25rem;
    bottom: 1.25rem;
  }
}

.cases__media {
  aspect-ratio: 485/280;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .cases__media {
    aspect-ratio: 300/165;
  }
}

.cases__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  pointer-events: none;
}

.cases__body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding-top: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .cases__body {
    padding-top: 1.25rem;
  }
}

.cases__title {
  font-size: 1.5625rem;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.05em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .cases__title {
    font-size: 1.125rem;
    line-height: 1.4444444444;
  }
}

.cases__link {
  display: block;
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  color: inherit;
  text-decoration: none;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
.cases__link::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
}

.cases__category {
  color: #fff;
  position: relative;
  z-index: 2;
  display: inline-block;
  margin-top: 1.1875rem;
  pointer-events: auto;
  background-color: #242A2E;
  font-size: 1rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  letter-spacing: 0.05em;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  border-radius: 100vw;
  padding: 0.1875rem 0.9375rem;
  line-height: 1.22;
  text-decoration: none;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .cases__category {
    font-size: 0.8125rem;
    padding: 0.1875rem 0.625rem;
    margin-top: 0.6875rem;
  }
}
.cases__category:hover {
  background-color: #fff;
  color: #242A2E;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
}
@media screen and (max-width: 767.9px) {
  .cases__category:hover {
    background-color: #242A2E;
    color: #fff;
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

.cases__text {
  margin-top: 1rem;
  font-size: 1.375rem;
  line-height: 1.4545454545;
  letter-spacing: 0.07em;
  color: #2B2B2B;
  pointer-events: none;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  padding-right: 8.4375rem;
}
@media screen and (max-width: 767.9px) {
  .cases__text {
    margin-top: 0.5rem;
    font-size: 0.875rem;
    line-height: 1.3571428571;
    padding-right: 3.5rem;
  }
}

@media screen and (min-width: 768px) {
  .cases__item.glass {
    -webkit-transition: -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
    transition: -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
    transition: box-shadow 0.3s ease, transform 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
  }
  .cases__item.glass:has(.cases__link:hover), .cases__item.glass:has(.cases__link:focus-visible) {
    -webkit-transform: translateY(-0.125rem);
            transform: translateY(-0.125rem);
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.16), 0 0.75rem 2.5rem rgba(45, 45, 45, 0.18), 0 0.25rem 0.75rem rgba(255, 255, 255, 0.28);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.16), 0 0.75rem 2.5rem rgba(45, 45, 45, 0.18), 0 0.25rem 0.75rem rgba(255, 255, 255, 0.28);
  }
  .cases__item.glass:has(.cases__link:hover)::before, .cases__item.glass:has(.cases__link:focus-visible)::before {
    -webkit-transform: translateX(0.375rem);
            transform: translateX(0.375rem);
  }
  .cases__link:hover,
  .cases__link:focus-visible {
    opacity: 0.65;
  }
}
@media screen and (max-width: 767.9px) {
  .page-head.page-head--privacy-policy .page-head__inner {
    padding-bottom: 3.75rem;
  }
}

.privacy-policy {
  background-color: #F9F9F9;
}

.privacy-policy__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding: 7.5rem 0 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__inner {
    max-width: 34.375rem;
    padding: 2.5rem 1.5625rem 3.75rem;
  }
}

.privacy-policy__title {
  font-size: 1.75rem;
  line-height: 1.7142857143;
  font-weight: 400;
  letter-spacing: 0.07em;
  color: #2B2B2B;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__title {
    font-size: 1.25rem;
    line-height: 2.4;
    text-align: left;
  }
}

.privacy-policy__content {
  margin-top: 4.375rem;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__content {
    margin-top: 1.25rem;
  }
}

.privacy-policy__text + .privacy-policy__section,
.privacy-policy__section + .privacy-policy__section {
  margin-top: 3.75rem;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__text + .privacy-policy__section,
  .privacy-policy__section + .privacy-policy__section {
    margin-top: 2.5rem;
  }
}

.privacy-policy__heading {
  font-size: 1.125rem;
  font-weight: 400;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__heading {
    font-size: 0.875rem;
  }
}

.privacy-policy__heading + .privacy-policy__text,
.privacy-policy__heading + .privacy-policy__list {
  margin-top: 0.75rem;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__heading + .privacy-policy__text,
  .privacy-policy__heading + .privacy-policy__list {
    margin-top: 0.5rem;
  }
}

.privacy-policy__text {
  font-size: 1.125rem;
  line-height: 2.6666666667;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__text {
    font-size: 0.875rem;
    line-height: 2.2857142857;
  }
}

.privacy-policy__text.privacy-policy__text--mt {
  margin-top: 3.75rem;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__text.privacy-policy__text--mt {
    margin-top: 2.5rem;
  }
}

.privacy-policy__list {
  margin-top: 3.75rem;
  list-style: none;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__list {
    margin-top: 0;
  }
}

.privacy-policy__list li {
  font-size: 1.125rem;
  line-height: 2.6666666667;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__list li {
    font-size: 0.875rem;
    line-height: 2.2857142857;
  }
}

.privacy-policy__link {
  color: #2B2B2B;
  text-decoration: underline;
  text-underline-offset: 0.1875rem;
}

.privacy-policy__date {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .privacy-policy__date {
    margin-top: 1.75rem;
  }
}

.page-head.page-head--news {
  background-color: #fff;
}

.single {
  background-color: #F9F9F9;
}

.single__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.6875rem;
  padding-bottom: 12.5rem;
}
@media screen and (max-width: 767.9px) {
  .single__inner {
    max-width: 40.625rem;
    padding: 1.875rem 1.5625rem 3.75rem;
  }
}

.detail__content.glass {
  padding: 3.75rem 7.5rem;
  border-radius: 0.5rem;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.11) 0%, rgba(255, 255, 255, 0.11) 38%, rgba(255, 255, 255, 0.11) 100%);
}
@media screen and (max-width: 767.9px) {
  .detail__content.glass {
    padding: 1.25rem 1.5rem 1.875rem;
    border-radius: 0.3125rem;
  }
}

.detail__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem 1.4375rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 767.9px) {
  .detail__meta {
    gap: 0.625rem 1.25rem;
  }
}

.detail__date {
  font-size: 1.25rem;
  letter-spacing: 0.05em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .detail__date {
    font-size: 0.8125rem;
  }
}

.detail__category {
  font-size: 1rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: #fff;
  background-color: #242A2E;
  padding: 0.1875rem 0.9375rem;
  border-radius: 100vw;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .detail__category {
    font-size: 0.8125rem;
    padding: 0.1875rem 0.625rem 0.0625rem 0.625rem;
  }
}
.detail__category:hover {
  opacity: 1;
  background-color: #fff;
  color: #242A2E;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
}
@media screen and (max-width: 767.9px) {
  .detail__category:hover {
    background-color: #242A2E;
    color: #fff;
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

.detail__title {
  margin-top: 1.4375rem;
  font-size: 1.5rem;
  line-height: 1.3333333333;
  letter-spacing: 0.07em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .detail__title {
    font-size: 1.125rem;
    line-height: 1.5555555556;
  }
}

.detail__thumb-wrap {
  margin-top: 3.75rem;
  aspect-ratio: 940/518;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .detail__thumb-wrap {
    margin-top: 1.25rem;
    aspect-ratio: 292/153;
  }
}

.detail__thumb {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.detail {
  word-break: break-all;
}

.detail ul {
  margin-top: 2.5rem;
  list-style-type: disc;
  padding-left: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .detail ul {
    margin-top: 1.25rem;
  }
}

.detail li {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .detail li {
    font-size: 0.875rem;
    line-height: 2;
  }
}

.detail ol {
  margin-top: 2.5rem;
  list-style-type: decimal;
  padding-left: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .detail ol {
    margin-top: 1.25rem;
  }
}

.detail dl {
  margin-top: 3rem;
  list-style-type: decimal;
}
@media screen and (max-width: 767.9px) {
  .detail dl {
    margin-top: 1.25rem;
  }
}

.detail dt,
.detail dd {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .detail dt,
  .detail dd {
    font-size: 0.875rem;
    line-height: 2;
  }
}

.detail dd {
  padding-left: 1.25rem;
}

.detail blockquote {
  margin-top: 3.75rem;
  font-style: italic;
  border-left: 0.1875rem solid #ccc;
  padding-left: 1.25rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
.detail blockquote p {
  color: #555;
}
@media screen and (max-width: 767.9px) {
  .detail blockquote {
    margin-top: 1.25rem;
    padding-left: 0.625rem;
  }
  .detail blockquote p {
    font-size: 0.875rem;
    line-height: 2;
  }
}

.detail p {
  margin-top: 2.5rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .detail p {
    margin-top: 1rem;
    font-size: 0.875rem;
    line-height: 2;
  }
}

.detail a {
  display: inline-block;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  text-decoration: underline;
  color: #348fd3;
}
@media screen and (max-width: 767.9px) {
  .detail a {
    font-size: 0.875rem;
    line-height: 2;
  }
}

.detail h1,
.detail h2 {
  margin-top: 3.75rem;
  font-size: 1.375rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(43, 43, 43, 0.4);
  font-weight: 400;
  letter-spacing: 0.05em;
  padding-left: 1.875rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .detail h1,
  .detail h2 {
    margin-top: 1.25rem;
    font-size: 1rem;
    line-height: 1.5;
    padding-left: 1.25rem;
    padding-bottom: 1rem;
  }
}
.detail h1::before,
.detail h2::before {
  position: absolute;
  content: "";
  width: 1.25rem;
  height: 1.25rem;
  top: calc(50% - 1.25rem);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .detail h1::before,
  .detail h2::before {
    top: calc(50% - 0.5rem);
    width: 0.625rem;
    height: 0.625rem;
  }
}

.detail h3 {
  margin-top: 3.75rem;
  font-size: 1.25rem;
  line-height: 1.6;
  letter-spacing: 0.05em;
  font-weight: 400;
  position: relative;
  padding-left: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(43, 43, 43, 0.4);
}
@media screen and (max-width: 767.9px) {
  .detail h3 {
    margin-top: 1.25rem;
    font-size: 1rem;
    line-height: 1.5;
    padding-left: 1.25rem;
    padding-bottom: 1rem;
  }
}
.detail h3::before {
  position: absolute;
  content: "";
  width: 0.375rem;
  height: 2rem;
  top: calc(50% - 0.625rem);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .detail h3::before {
    top: calc(50% - 0.5rem);
    width: 0.25rem;
    height: 1.25rem;
  }
}

.detail h4,
.detail h5,
.detail h6 {
  margin-top: 3.75rem;
  margin-bottom: 0;
  font-size: 1.125rem;
  line-height: 1.3333333333;
  letter-spacing: 0.05em;
  font-weight: 400;
  padding: 1rem;
  background-color: #f3f3f3;
}
@media screen and (max-width: 767.9px) {
  .detail h4,
  .detail h5,
  .detail h6 {
    margin-top: 1.25rem;
    font-size: 0.875rem;
    padding-bottom: 1rem;
  }
}

.detail img {
  margin-top: 2.5rem;
  height: auto;
  max-width: 100%;
}
@media screen and (max-width: 767.9px) {
  .detail img {
    margin-top: 1.25rem;
  }
}

.detail figure {
  height: auto;
  max-width: 100%;
}

.detail figcaption {
  margin-top: 0.5rem;
  font-size: 0.875rem;
}
@media screen and (max-width: 767.9px) {
  .detail figcaption {
    font-size: 0.75rem;
  }
}

.detail table {
  width: 100%;
  border-collapse: collapse;
  margin: 2.5rem 0;
  font-size: 1.125rem;
  text-align: left;
}
@media screen and (max-width: 767.9px) {
  .detail table {
    margin-top: 1.25rem;
    font-size: 0.875rem;
  }
}

.detail th,
.detail td {
  border: 1px solid #ddd;
  padding: 0.75rem;
  line-height: 2.2222222222;
}
@media screen and (max-width: 767.9px) {
  .detail th,
  .detail td {
    line-height: 2;
  }
}

.detail thead th {
  background-color: #f4f4f4;
  font-weight: bold;
  text-align: center;
}

.detail tbody th {
  background-color: #f9f9f9;
}

.detail pre {
  white-space: pre-wrap;
}

.single-cases-detail {
  position: relative;
  padding-bottom: 5.625rem;
  overflow: hidden;
  background-color: #fff;
}
@media screen and (max-width: 767.9px) {
  .single-cases-detail {
    padding-bottom: 1.875rem;
  }
}

.single-cases__hero.js-parallax-section {
  position: relative;
  height: 32.0625rem;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .single-cases__hero.js-parallax-section {
    height: clamp(17.1875rem, 15rem + 9vw, 20rem);
  }
}

.single-cases__bg.js-parallax-bg {
  position: absolute;
  inset: -12% 0;
  background-image: url(../img/deco_black.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  will-change: transform;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  z-index: 0;
}
@media screen and (max-width: 767.9px) {
  .single-cases__bg.js-parallax-bg {
    inset: -10% 0;
    background-image: url(../img/deco_black-sp.jpg);
  }
}

.single-cases__ceo {
  position: absolute;
  left: max(1.25rem, (100vw - 90rem) / 2 + 8.75rem);
  bottom: 0;
  width: 28.625rem;
  z-index: 1;
}
.single-cases__ceo img {
  width: 100%;
  display: block;
}
@media screen and (max-width: 767.9px) {
  .single-cases__ceo {
    width: min(78vw, clamp(15.25rem, 12.875rem + 10vw, 18.25rem));
    left: 0;
    -webkit-transform: none;
            transform: none;
  }
}

.single-cases__card {
  position: relative;
  z-index: 2;
  isolation: isolate;
  width: min(100% - 2.5rem, 58.125rem);
  margin-top: -13.125rem;
  margin-left: auto;
  background-color: transparent;
  padding: 10rem 6.25rem 7.5rem;
}
@media screen and (min-width: 1440px) {
  .single-cases__card {
    width: 58.125rem;
    margin-left: calc((100vw - 90rem) / 2 + 31.875rem);
  }
}
.single-cases__card::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset-block: 0;
  inset-inline-start: 0;
  inset-inline-end: calc(50% - 50vw);
  background-color: #FAFAFA;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .single-cases__card {
    margin-top: -3.4375rem;
    width: calc(100% - 2rem);
    margin-left: 2.1875rem;
    padding: 1.875rem 2.1875rem 2.5rem 1.875rem;
    background-color: #FAFAFA;
    -webkit-box-shadow: 0 0 0.875rem rgba(0, 0, 0, 0.13);
            box-shadow: 0 0 0.875rem rgba(0, 0, 0, 0.13);
  }
  .single-cases__card::before {
    display: none;
  }
}

.single-cases__card-inner {
  max-width: 45.625rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__card-inner {
    max-width: 31.25rem;
    margin-inline: auto;
  }
}

.single-cases__heading {
  margin-top: 5rem;
  font-size: 3rem;
  color: #2B2B2B;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .single-cases__heading {
    margin-top: 1.25rem;
    font-size: 1.5rem;
  }
}

.single-cases__items {
  margin-top: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__items {
    margin-top: 1.25rem;
  }
}

.single-cases__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.5rem;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  color: #2B2B2B;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(43, 43, 43, 0.4);
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .single-cases__item {
    gap: 1rem;
    font-size: 0.8125rem;
    padding-bottom: 1rem;
    line-height: 1.5833333333;
  }
}
.single-cases__item + .single-cases__item {
  margin-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__item + .single-cases__item {
    margin-top: 1rem;
  }
}

.single-cases__item-head {
  min-width: 12.5rem;
  max-width: 12.5rem;
  padding-left: 1.75rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .single-cases__item-head {
    min-width: 6.875rem;
    max-width: 6.875rem;
    padding-left: 0.875rem;
  }
}
.single-cases__item-head::before {
  position: absolute;
  content: "";
  width: 0.75rem;
  height: 0.75rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .single-cases__item-head::before {
    width: 0.375rem;
    height: 0.375rem;
  }
}

.single-cases__detail {
  margin-top: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__detail {
    margin-top: 1.25rem;
  }
}

.single-cases__detail-title-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3.75rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767.9px) {
  .single-cases__detail-title-wrap {
    gap: 1.25rem;
  }
}

.single-cases__detail-title-head {
  width: 9.25rem;
  height: 9.25rem;
  border-radius: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1.78125rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #386C95;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}
@media screen and (max-width: 767.9px) {
  .single-cases__detail-title-head {
    width: 5.375rem;
    height: 5.375rem;
    font-size: 1.0625rem;
  }
}

.single-cases__detail-title-body {
  font-size: 2.25rem;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .single-cases__detail-title-body {
    font-size: 1.25rem;
  }
}

.single-cases__detail-text {
  max-width: 40.8125rem;
  margin-top: 5rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .single-cases__detail-text {
    margin-top: 1.25rem;
    font-size: 0.8125rem;
    line-height: 2.3076923077;
    letter-spacing: 0.03em;
  }
}

.single-cases__content {
  padding-top: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__content {
    padding-top: 2.5rem;
  }
}

.single-cases__content.single-cases__content--cases {
  background-color: #fff;
  padding: 4.375rem 0;
}
@media screen and (max-width: 767.9px) {
  .single-cases__content.single-cases__content--cases {
    padding: 1.875rem 0;
  }
}

.single-cases__content-inner {
  max-width: 73.75rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .single-cases__content-inner {
    max-width: 34.375rem;
    padding-inline: 1.5625rem;
  }
}

.single-cases__content .detail h2 {
  font-size: 1.75rem;
  padding-bottom: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__content .detail h2 {
    margin-top: 2.5rem;
    font-size: 1rem;
  }
}
.single-cases__content .detail h2::before {
  width: 0.75rem;
  height: 0.75rem;
  top: calc(55% - 0.625rem);
}

.single-cases__cta-content {
  background-image: url(../img/single-cases_cta-bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 9.625rem 1.25rem 1.25rem;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .single-cases__cta-content {
    padding: 3.75rem 1.5625rem 2.5rem;
  }
}

.single-cases__cta-text {
  font-size: 2.25rem;
  line-height: 1.5277777778;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .single-cases__cta-text {
    font-size: 1rem;
    line-height: 2;
  }
}

.single-cases__cta-btn.btn.btn--white {
  margin-top: 1.25rem;
  margin-inline: auto;
  font-size: 1.8125rem;
  font-weight: 400;
  max-width: 22.3125rem;
  padding: 0.75rem 1.625rem 0.5rem;
  text-align: left;
  position: relative;
  border-radius: 0.3125rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__cta-btn.btn.btn--white {
    font-size: 1.125rem;
    max-width: 15.625rem;
  }
}
.single-cases__cta-btn.btn.btn--white::before {
  width: 5.5rem;
  height: 2.4375rem;
  right: 1.125rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__cta-btn.btn.btn--white::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.5rem;
  }
}

.single-cases__cta-caption {
  margin-top: 6.875rem;
  font-size: 1.5rem;
  line-height: 2.2916666667;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .single-cases__cta-caption {
    margin-top: 3.75rem;
    font-size: 0.875rem;
    line-height: 2;
  }
}

.singe-cases__more {
  padding: 5rem 1.25rem 10rem;
}
@media screen and (max-width: 767.9px) {
  .singe-cases__more {
    padding: 2.5rem 1.5625rem 5rem;
  }
}

.single-cases__more-btn.btn {
  margin-top: 0;
  margin-inline: auto;
  background-color: #333;
  font-size: 1.25rem;
  max-width: 17.0625rem;
  padding: 0.625rem 1.25rem;
  position: relative;
  border-radius: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__more-btn.btn {
    font-size: 1rem;
    max-width: 13.75rem;
  }
}
.single-cases__more-btn.btn::before {
  width: 4.25rem;
  height: 1.875rem;
  right: 0.875rem;
}
@media screen and (max-width: 767.9px) {
  .single-cases__more-btn.btn::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.5rem;
  }
}

@media screen and (max-width: 767.9px) {
  .page-head.page-head--contact .page-head__inner {
    padding-bottom: 3.75rem;
  }
}

.contact {
  background-color: #F9F9F9;
}

.contact__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .contact__inner {
    max-width: 40.625rem;
    padding: 2.5rem 1.5625rem;
  }
}

.form {
  width: 100%;
}

.form__category {
  padding-inline: 6.25rem;
}
@media screen and (max-width: 767.9px) {
  .form__category {
    padding-inline: 0;
  }
}

.form__category-title {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .form__category-title {
    font-size: 0.875rem;
  }
}

.form__data-radio {
  margin-top: 3rem;
}
@media screen and (max-width: 767.9px) {
  .form__data-radio {
    margin-top: 1.25rem;
  }
}

.form__radio {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .form__radio {
    gap: 1.1875rem;
  }
}
.form__radio .wpcf7-list-item {
  margin: 0;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
.form__radio label {
  display: block;
  cursor: pointer;
}
.form__radio input[type=radio] {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  overflow: hidden;
  white-space: nowrap;
}
.form__radio .wpcf7-list-item-label {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  white-space: nowrap;
  min-height: 4.5rem;
  padding: 1.125rem 2.5rem 1.375rem;
  font-size: 1.375rem;
  letter-spacing: 0.07em;
  color: #2B2B2B;
  border-radius: 0.5rem;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.42) 0%, rgba(255, 255, 255, 0.18) 38%, rgba(255, 255, 255, 0.08) 100%);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-bottom-color: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(0.3px) saturate(1.35);
  -webkit-backdrop-filter: blur(0.3px) saturate(1.35);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
  -webkit-transition: color 0.3s ease, background-color 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
  transition: color 0.3s ease, background-color 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
  transition: color 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
  transition: color 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-transform 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .form__radio .wpcf7-list-item-label {
    min-height: 3.25rem;
    font-size: 0.9375rem;
    padding: 0.875rem 1.75rem;
  }
}
.form__radio input[type=radio]:checked + .wpcf7-list-item-label {
  color: #fff;
  background: #333;
  -webkit-box-shadow: 0 0.5rem 1.5rem rgba(45, 45, 45, 0.16);
          box-shadow: 0 0.5rem 1.5rem rgba(45, 45, 45, 0.16);
}
.form__radio input[type=radio]:focus-visible + .wpcf7-list-item-label {
  outline: 2px solid #2B2B2B;
  outline-offset: 2px;
}
@media (any-hover: hover) {
  .form__radio label:hover .wpcf7-list-item-label {
    color: #fff;
    background: #333;
    -webkit-transform: translateY(-0.125rem);
            transform: translateY(-0.125rem);
    -webkit-box-shadow: 0 0.625rem 1.75rem rgba(45, 45, 45, 0.18);
            box-shadow: 0 0.625rem 1.75rem rgba(45, 45, 45, 0.18);
  }
}

.form__card {
  margin-top: 5rem;
  padding: 5rem;
  border-radius: 0.5rem;
}
@media screen and (max-width: 767.9px) {
  .form__card {
    margin-top: 2.5rem;
    padding: 1.875rem 1.25rem 2.5rem 1.25rem;
  }
}

.form__list {
  margin: 0;
}

.form__field {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.5rem;
  padding-bottom: 1.875rem;
  border-bottom: 1px solid rgba(226, 226, 226, 0.6);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767.9px) {
  .form__field {
    display: block;
    padding-bottom: 1.5rem;
  }
}
.form__field + .form__field {
  margin-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .form__field + .form__field {
    margin-top: 0.625rem;
  }
}

.form__field--textarea {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.form__label {
  position: relative;
  max-width: 18.75rem;
  padding-left: 1.75rem;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  color: #2B2B2B;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .form__label {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    max-width: none;
    padding-left: 1.375rem;
    font-size: 1rem;
  }
}
.form__label label {
  cursor: pointer;
}
.form__label::before {
  position: absolute;
  content: "";
  width: 0.75rem;
  height: 0.75rem;
  top: 1.125rem;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .form__label::before {
    width: 0.5rem;
    height: 0.5rem;
  }
}

.form__required {
  margin-left: 1rem;
  font-size: 0.9375rem;
  color: #AF0000;
}
@media screen and (max-width: 767.9px) {
  .form__required {
    margin-left: 0.875rem;
    font-size: 0.8125rem;
  }
}

.form__note {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.75rem;
  letter-spacing: 0.03em;
  color: #8A8A8A;
}
@media screen and (max-width: 767.9px) {
  .form__note {
    font-size: 0.6875rem;
    margin-top: 0;
  }
}

.form__data {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width: 0;
  max-width: 36.3125rem;
}
@media screen and (max-width: 767.9px) {
  .form__data {
    margin-top: 0.5rem;
  }
}

.form__input,
.form__textarea {
  width: 100%;
  max-width: 36.3125rem;
  padding: 0.78125rem 1.25rem;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  color: #2B2B2B;
  background-color: #EDEDED;
  border-radius: 0.125rem;
}
@media screen and (max-width: 767.9px) {
  .form__input,
  .form__textarea {
    font-size: 0.875rem;
    padding: 0.625rem 0.875rem;
  }
}
.form__input::-webkit-input-placeholder, .form__textarea::-webkit-input-placeholder {
  color: #C6C6C6;
}
.form__input::-moz-placeholder, .form__textarea::-moz-placeholder {
  color: #C6C6C6;
}
.form__input:-ms-input-placeholder, .form__textarea:-ms-input-placeholder {
  color: #C6C6C6;
}
.form__input::-ms-input-placeholder, .form__textarea::-ms-input-placeholder {
  color: #C6C6C6;
}
.form__input::placeholder,
.form__textarea::placeholder {
  color: #C6C6C6;
}

.form__input[type=email] {
  padding: 0.625rem 1.25rem 0.9375rem;
}
@media screen and (max-width: 767.9px) {
  .form__input[type=email] {
    padding: 0.5rem 0.875rem 0.75rem;
  }
}

.form__textarea {
  height: 16.25rem;
  resize: vertical;
  padding: 1rem 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .form__textarea {
    height: 9.375rem;
  }
}

.form__submit-button.btn {
  margin-top: 5.625rem;
  text-align: center;
  margin-inline: auto;
  max-width: 15.8125rem;
  padding: 0.5rem 1.25rem 0.375rem 3rem;
  background-color: #333;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .form__submit-button.btn {
    margin-top: 0.625rem;
    padding: 0.5rem 1.0625rem 0.375rem;
    max-width: 13.8125rem;
  }
}
.form__submit-button.btn {
  position: relative;
}
.form__submit-button.btn::before {
  position: absolute;
  content: "";
  width: 4.25rem;
  height: 1.875rem;
  right: 0.625rem;
}
@media screen and (max-width: 767.9px) {
  .form__submit-button.btn::before {
    width: 3.6875rem;
    height: 1.625rem;
    right: 0.5rem;
  }
}
.form__submit-button.btn:hover .form__submit-input {
  color: #333;
}

.form__submit-input {
  color: #fff;
  margin-inline: auto;
  font-size: 1.3125rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 400;
  -moz-text-align-last: left;
       text-align-last: left;
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .form__submit-input {
    font-size: 1.0625rem;
  }
}
.form__submit-input:hover {
  color: #333;
}

div.wpcf7 .wpcf7-spinner {
  display: none !important;
}

.thanks {
  background-color: #F9F9F9;
}

.thanks__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 9.625rem;
}
@media screen and (max-width: 767.9px) {
  .thanks__inner {
    max-width: 37.5rem;
    padding: 2.5rem 1.9375rem;
  }
}

.thanks__content {
  text-align: center;
}

.thanks__title {
  font-size: 1.75rem;
  line-height: 1.7142857143;
  letter-spacing: 0.07em;
  font-weight: 400;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .thanks__title {
    font-size: 1.25rem;
    line-height: 2;
  }
}

.thanks__read {
  margin-top: 3.75rem;
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  font-weight: 400;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .thanks__read {
    margin-top: 2.5rem;
    font-size: 1rem;
    line-height: 2;
  }
}

.thanks__text {
  margin-top: 3.5rem;
  font-size: 1rem;
  line-height: 2;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .thanks__text {
    margin-top: 1.875rem;
    font-size: 0.8125rem;
    letter-spacing: 0.03em;
  }
}

.thanks__text.thanks__text--attention {
  margin-top: 0;
}
@media screen and (max-width: 767.9px) {
  .thanks__text.thanks__text--attention {
    margin-top: 1.25rem;
    color: #B0B0B0;
    text-align: left;
  }
}

.thanks__btn.btn {
  max-width: 15.8125rem;
  text-align: left;
  margin-top: 6.25rem;
  margin-inline: auto;
  font-size: 1.3125rem;
  background-color: #333333;
  letter-spacing: 0.04em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .thanks__btn.btn {
    margin-top: 2.5rem;
    max-width: 12rem;
    font-size: 1rem;
  }
}
.thanks__btn.btn::before {
  width: 4.25rem;
  height: 1.875rem;
  right: 0.625rem;
}
@media screen and (max-width: 767.9px) {
  .thanks__btn.btn::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.5rem;
  }
}

.error-404 {
  background-color: #F9F9F9;
}

.error-404__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 7.5rem;
  padding-bottom: 9.625rem;
}
@media screen and (max-width: 767.9px) {
  .error-404__inner {
    max-width: 37.5rem;
    padding: 2.5rem 1.9375rem;
  }
}

.error-404__content {
  text-align: center;
}

.error-404__text {
  margin-top: 3.5rem;
  font-size: 1rem;
  line-height: 2;
  letter-spacing: 0.07em;
  color: #2B2B2B;
}
@media screen and (max-width: 767.9px) {
  .error-404__text {
    margin-top: 1.875rem;
    font-size: 0.8125rem;
    letter-spacing: 0.03em;
  }
}

.error-404__btn.btn {
  max-width: 15.8125rem;
  text-align: left;
  margin-top: 6.25rem;
  margin-inline: auto;
  font-size: 1.3125rem;
  background-color: #333333;
  letter-spacing: 0.04em;
  font-weight: 400;
}
@media screen and (max-width: 767.9px) {
  .error-404__btn.btn {
    margin-top: 2.5rem;
    max-width: 12rem;
    font-size: 1rem;
  }
}
.error-404__btn.btn::before {
  width: 4.25rem;
  height: 1.875rem;
  right: 0.625rem;
}
@media screen and (max-width: 767.9px) {
  .error-404__btn.btn::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.5rem;
  }
}

.header {
  position: fixed;
  top: 2.5rem;
  left: 1.875rem;
  right: 1.875rem;
  width: auto;
  -webkit-transform: none;
          transform: none;
  z-index: 1000;
  height: auto;
  padding: 1.25rem 0;
  background-color: transparent;
  -webkit-transition: opacity 0.4s ease, visibility 0.4s ease, top 0.45s ease, -webkit-transform 0.4s ease;
  transition: opacity 0.4s ease, visibility 0.4s ease, top 0.45s ease, -webkit-transform 0.4s ease;
  transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s ease, top 0.45s ease;
  transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s ease, top 0.45s ease, -webkit-transform 0.4s ease;
}
@media screen and (max-width: 767.9px) {
  .header {
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    padding: 1.5rem 0 1.25rem;
    background-color: #fff;
    border: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
    -webkit-transition: opacity 0.4s ease, visibility 0.4s ease, background-color 0.4s ease, -webkit-transform 0.4s ease;
    transition: opacity 0.4s ease, visibility 0.4s ease, background-color 0.4s ease, -webkit-transform 0.4s ease;
    transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s ease, background-color 0.4s ease;
    transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s ease, background-color 0.4s ease, -webkit-transform 0.4s ease;
  }
  .header .header__name img {
    -webkit-filter: none;
            filter: none;
  }
  .header .hamburger span {
    background-color: #2B2B2B;
  }
  .header .hamburger.is-active span {
    background-color: #2B2B2B;
  }
}

@media screen and (min-width: 768px) {
  .header.is-scrolled {
    top: 1.25rem;
  }
}
.header.is-hidden {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(-0.75rem);
          transform: translateY(-0.75rem);
  pointer-events: none;
}

@media screen and (min-width: 768px) {
  .header.header--black .header__name img {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
  .header.header--black .hamburger span {
    background-color: #fff;
  }
  .header.header--black .hamburger.is-active span {
    background-color: #000;
  }
  .header.header--black .header__nav-link {
    -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
  }
}
@media screen and (max-width: 767.9px) {
  .header.header--black {
    background-color: #000;
  }
  .header.header--black .header__name img {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
  .header.header--black .hamburger span {
    background-color: #fff;
  }
  .header.header--black .hamburger.is-active span {
    background-color: #000;
  }
  .header.header--black .header__nav-link {
    -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
  }
}

@media screen and (min-width: 768px) {
  .header-glass,
  .js-header.change-color {
    background-color: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
    border-radius: 0.5rem;
  }
}

.header__inner {
  width: 100%;
  margin-inline: auto;
  padding-left: 2.8125rem;
  padding-right: 2.8125rem;
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767.9px) {
  .header__inner {
    padding-left: 1.5625rem;
    padding-right: 1.5625rem;
  }
}

.header__name img {
  width: 16.25rem;
}
@media screen and (max-width: 767.9px) {
  .header__name img {
    width: 10.125rem;
  }
}
.header__name a:hover {
  opacity: 1;
}

.header__nav {
  height: inherit;
}

.header__nav-items {
  margin-right: 5rem;
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__nav-item {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__nav-link {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  background-color: #333333;
  font-size: 1.5rem;
  border-radius: 0.25rem;
  padding: 0.625rem 7.375rem 0.625rem 1.25rem;
  position: relative;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
.header__nav-link::before {
  position: absolute;
  content: "";
  width: 4.25rem;
  height: 1.875rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0.625rem;
  background-image: url(../img/icon_arrow-white.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
.header__nav-link:hover {
  opacity: 1;
  background-color: #fff;
  color: #333333;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
}
.header__nav-link:hover::before {
  background-image: url(../img/icon_arrow-black.svg);
}

.hamburger {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 2.1875rem;
  z-index: 9999;
  width: 2.5rem;
  height: 0.6875rem;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  -webkit-transition: width 0.3s ease, height 0.3s ease, right 0.3s ease, background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: width 0.3s ease, height 0.3s ease, right 0.3s ease, background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: width 0.3s ease, height 0.3s ease, right 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease;
  transition: width 0.3s ease, height 0.3s ease, right 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .hamburger {
    top: 50%;
    width: 2rem;
    height: 0.40625rem;
    right: 1.5625rem;
  }
}
.hamburger.is-active {
  width: 3.375rem;
  height: 3.375rem;
  right: 1.75rem;
  border-radius: 0.3125rem;
  background-color: rgba(0, 0, 0, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-bottom-color: rgba(255, 255, 255, 0.18);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
}
@media screen and (max-width: 767.9px) {
  .hamburger.is-active {
    width: 2rem;
    height: 2rem;
    right: 1.5625rem;
  }
}

.hamburger span {
  position: absolute;
  left: 0;
  background-color: #333333;
  width: 100%;
  height: 1px;
  display: inline-block;
  -webkit-transition: top 0.3s ease, width 0.3s ease, left 0.3s ease, -webkit-transform 0.3s ease;
  transition: top 0.3s ease, width 0.3s ease, left 0.3s ease, -webkit-transform 0.3s ease;
  transition: transform 0.3s ease, top 0.3s ease, width 0.3s ease, left 0.3s ease;
  transition: transform 0.3s ease, top 0.3s ease, width 0.3s ease, left 0.3s ease, -webkit-transform 0.3s ease;
}

.hamburger span:nth-child(1) {
  top: 0;
}

.hamburger span:nth-child(2) {
  top: 0.625rem;
}
@media screen and (max-width: 767.9px) {
  .hamburger span:nth-child(2) {
    top: 0.375rem;
  }
}

.hamburger.is-active span {
  width: 1.875rem;
  left: 0.75rem;
  top: 1.65625rem;
  background-color: #333333;
}
@media screen and (max-width: 767.9px) {
  .hamburger.is-active span {
    width: 1.125rem;
    left: 0.4375rem;
    top: 0.96875rem;
  }
}

.hamburger.is-active span:nth-child(1) {
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
}

.hamburger.is-active span:nth-child(2) {
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
}

html.is-drawer-open,
body.is-drawer-open {
  overflow: hidden;
  -ms-scroll-chaining: none;
      overscroll-behavior: none;
  -ms-touch-action: none;
      touch-action: none;
}

.drawer-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: var(--drawer-vh, 100dvh);
  z-index: 5000;
  display: none;
  -ms-scroll-chaining: none;
      overscroll-behavior: none;
  overflow: hidden;
  border: none;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  -webkit-transform: none;
          transform: none;
  background-image: url(../img/drawer_bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: var(--drawer-vh, 100dvh);
    width: 100%;
    padding: 1.5rem 0.625rem max(0.625rem, env(safe-area-inset-bottom));
    overflow: hidden;
    background-color: #ececec;
    background-image: url(../img/drawer_bg-sp.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
}

.drawer-menu__inner {
  position: relative;
  z-index: 1;
  margin: 1.875rem;
  width: auto;
  height: calc(100dvh - 3.75rem);
  overflow-x: hidden;
  overflow-y: auto;
  -ms-scroll-chaining: none;
      overscroll-behavior: contain;
  border-radius: 0.5rem;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.7) 0%, rgba(255, 255, 255, 0.7) 38%, rgba(255, 255, 255, 0.7) 100%);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-bottom-color: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(8px) saturate(1.35);
  -webkit-backdrop-filter: blur(8px) saturate(1.35);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
  scrollbar-width: thin;
  scrollbar-color: rgba(117, 117, 117, 0.35) transparent;
}
.drawer-menu__inner::-webkit-scrollbar {
  width: 4px;
}
.drawer-menu__inner::-webkit-scrollbar-thumb {
  background-color: rgba(117, 117, 117, 0.35);
  border-radius: 2px;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__inner {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 auto;
            flex: 0 1 auto;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    min-height: 0;
    margin: 1.5rem 0 0;
    width: 100%;
    height: auto;
    max-height: calc(var(--drawer-vh, 100dvh) - 1.5rem - 1.625rem - max(0.625rem, env(safe-area-inset-bottom)) - 2.5rem);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    background: #fff;
    border: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-radius: 0.5rem;
    -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
  }
}

.drawer-menu__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .drawer-menu__body {
    min-height: 100%;
    height: auto;
  }
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__body {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
  }
}

.drawer-menu__logo {
  width: 16.25rem;
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .drawer-menu__nav > .drawer-menu__logo {
    position: absolute;
    top: 2.3125rem;
    left: 2.8125rem;
    z-index: 1;
  }
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__logo {
    width: 12rem;
    padding-inline: 0.9375rem;
  }
}

.drawer-menu__nav {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 58%;
          flex: 1 1 58%;
  min-height: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 2.3125rem 2.8125rem;
}
@media screen and (min-width: 768px) {
  .drawer-menu__nav {
    min-height: 100%;
    padding-top: 6.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__nav {
    max-width: 31.25rem;
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    min-height: auto;
    position: relative;
    padding: 1.5rem 2.5rem;
    padding-bottom: 4.0625rem;
  }
}

.drawer-menu__nav-columns {
  width: 100%;
  max-width: 43.75rem;
  margin-inline: auto;
  margin-top: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 3.75rem;
  padding: 0 6.25rem;
}
@media screen and (min-width: 768px) {
  .drawer-menu__nav-columns {
    margin-top: auto;
  }
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__nav-columns {
    margin-top: 0;
    gap: 1.25rem;
    padding: 0;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
}

.drawer-menu__nav-col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.drawer-menu__nav-col--secondary {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  padding-top: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__nav-col--secondary {
    padding-top: 0;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 5.625rem;
            flex: 0 0 5.625rem;
  }
}

.drawer-menu__section + .drawer-menu__section {
  margin-top: 2.375rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__section + .drawer-menu__section {
    margin-top: 1.4375rem;
  }
}

.drawer-menu__heading {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #386C95;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__heading {
    font-size: 1rem;
  }
}

.drawer-menu__list {
  margin-top: 0.875rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__list {
    margin-top: 0.5rem;
  }
}

.drawer-menu__list-item + .drawer-menu__list-item {
  margin-top: 1rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__list-item + .drawer-menu__list-item {
    margin-top: 0.5rem;
  }
}

.drawer-menu__sublink {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.75rem;
  font-size: 1.09375rem;
  line-height: 1.8;
  letter-spacing: 0.07em;
  color: #1F1F1F;
  position: relative;
  padding-left: 3.5625rem;
  white-space: nowrap;
  -webkit-transition: opacity 0.3s ease, color 0.3s ease;
  transition: opacity 0.3s ease, color 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__sublink {
    gap: 0.625rem;
    font-size: 0.6875rem;
    padding-left: 1.75rem;
  }
}
.drawer-menu__sublink::before {
  position: absolute;
  content: "";
  width: 1.625rem;
  height: 1px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #1F1F1F;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__sublink::before {
    width: 1.03125rem;
  }
}
.drawer-menu__sublink:hover {
  opacity: 1;
  color: #B5B5B5;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__sublink:hover {
    color: #1F1F1F;
  }
}

.drawer-menu__plain {
  margin: 0;
  padding: 0;
  list-style: none;
}

.drawer-menu__plain-item + .drawer-menu__plain-item {
  margin-top: 7.8125rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__plain-item + .drawer-menu__plain-item {
    margin-top: 2.375rem;
  }
}

.drawer-menu__plain-link {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #386C95;
  -webkit-transition: opacity 0.3s ease, color 0.3s ease;
  transition: opacity 0.3s ease, color 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__plain-link {
    font-size: 1rem;
  }
}
.drawer-menu__plain-link:hover {
  opacity: 1;
  color: #B5B5B5;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__plain-link:hover {
    color: #386C95;
  }
}

.drawer-menu__legal {
  width: 100%;
  max-width: 43.75rem;
  margin-inline: auto;
  display: inline-block;
  -ms-flex-item-align: start;
      align-self: flex-start;
  padding: 3.75rem 6.25rem;
  font-size: 0.8125rem;
  line-height: 1.22;
  letter-spacing: 0.07em;
  color: #1F1F1F;
  text-decoration: underline;
  text-underline-offset: 0.1875rem;
}
@media screen and (min-width: 768px) {
  .drawer-menu__legal {
    margin-bottom: auto;
  }
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__legal {
    position: absolute;
    left: 2.5rem;
    bottom: 1.875rem;
    width: auto;
    max-width: calc(100% - 8.75rem);
    margin-inline: 0;
    margin-top: 0;
    -ms-flex-item-align: auto;
        align-self: auto;
    padding: 0;
    font-size: 0.5625rem;
    z-index: 2;
  }
}

.drawer-menu__cta {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 42%;
          flex: 0 0 42%;
  -ms-flex-item-align: stretch;
      align-self: stretch;
  min-height: -webkit-max-content;
  min-height: -moz-max-content;
  min-height: max-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 6.25rem 4.25rem;
  background-image: url(../img/deco_silver.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .drawer-menu__cta {
    -ms-flex-item-align: stretch;
        align-self: stretch;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__cta {
    position: relative;
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    -ms-flex-item-align: auto;
        align-self: auto;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    min-height: auto;
    padding: 2.0625rem 1.5625rem;
  }
}

.drawer-menu__cta-visual {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__cta-visual {
    position: absolute;
    right: calc(3.125rem + max(0px, 100% - 31.25rem));
    bottom: 21.875rem;
    margin-bottom: -9.375rem;
    width: 7.5rem;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    pointer-events: none;
    z-index: 1;
  }
}

.drawer-menu__fire {
  display: block;
  width: 11.875rem;
  height: auto;
  aspect-ratio: 375/730;
  -o-object-fit: contain;
     object-fit: contain;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__fire {
    width: 100%;
  }
}

.drawer-menu__cta-text {
  margin-top: -1.25rem;
  font-size: 1rem;
  line-height: 2.33;
  letter-spacing: 0.07em;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__cta-text {
    margin-top: 0;
    font-size: 0.75rem;
    line-height: 2.3076923077;
    letter-spacing: 0.04em;
  }
}

.drawer-menu__btn.btn {
  margin-top: 3.875rem;
  max-width: 18.75rem;
  background-color: #242A2E;
  font-size: 1.78125rem;
  padding: 0.5625rem 1.4375rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__btn.btn {
    margin-top: 1.875rem;
    max-width: 12rem;
    font-size: 1rem;
    padding: 0.625rem 1rem;
  }
}
.drawer-menu__btn.btn::before {
  width: 5rem;
  height: 2.25rem;
  right: 0.75rem;
}
@media screen and (max-width: 767.9px) {
  .drawer-menu__btn.btn::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.5rem;
  }
}

.footer {
  background-color: #161a1c;
  color: #fff;
  padding-top: 6.25rem;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  padding-bottom: 1.5625rem;
}
@media screen and (max-width: 767.9px) {
  .footer {
    padding-top: 2.5rem;
    padding-left: 1.5625rem;
    padding-right: 1.5625rem;
    padding-bottom: 1.5625rem;
  }
}

.footer__inner {
  max-width: 73.75rem;
  margin-left: auto;
  margin-right: auto;
}

.footer__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
@media screen and (max-width: 767.9px) {
  .footer__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
}

.footer__logo {
  display: inline-block;
}
.footer__logo img {
  width: 16.25rem;
}
@media screen and (max-width: 767.9px) {
  .footer__logo img {
    width: 11.875rem;
  }
}

.footer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-left: auto;
  gap: 5.25rem;
}
@media screen and (max-width: 767.9px) {
  .footer__nav {
    margin-top: 3.75rem;
    margin-left: 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    width: 100%;
    max-width: 100%;
    gap: 2.8125rem;
  }
}

.footer__nav-primary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.footer__nav-section {
  min-width: 0;
}
.footer__nav-section:not(:first-child) {
  margin-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-section:not(:first-child) {
    margin-top: 1.4375rem;
  }
}

.footer__nav-secondary {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.footer__nav-heading {
  min-width: 12.25rem;
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.3;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-heading {
    min-width: 9.6875rem;
    font-size: 1.125rem;
    letter-spacing: 0.04em;
  }
}

.footer__nav-list {
  margin-top: 0.8125rem;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-list {
    margin-top: 0.625rem;
  }
}

.footer__nav-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.footer__nav-item + .footer__nav-item {
  margin-top: 0.8125rem;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-item + .footer__nav-item {
    margin-top: 0.625rem;
  }
}

.footer__nav-sublink {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.9375rem;
  font-family: "fot-tsukumin-pr6n", sans-serif;
  font-size: 0.875rem;
  color: #fff;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-sublink {
    gap: 0.75rem;
    font-size: 0.75rem;
    letter-spacing: 0.07em;
  }
}
.footer__nav-sublink::before {
  content: "";
  -webkit-box-flex: 0;
      -ms-flex: none;
          flex: none;
  width: 1.3125rem;
  height: 0.5px;
  background-color: #fff;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-sublink::before {
    width: 1rem;
  }
}

.footer__nav-sublink-sub {
  display: contents;
}

.footer__nav-plain {
  min-width: 12.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-plain {
    min-width: 9.6875rem;
  }
}

.footer__nav-plain-item + .footer__nav-plain-item {
  margin-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-plain-item + .footer__nav-plain-item {
    margin-top: 1.5625rem;
  }
}

.footer__nav-plain-link {
  color: #fff;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.3;
}
@media screen and (max-width: 767.9px) {
  .footer__nav-plain-link {
    font-size: 1.125rem;
    letter-spacing: 0.04em;
  }
}

.footer__middle {
  margin-top: 1.25rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  -webkit-column-gap: 5.625rem;
     -moz-column-gap: 5.625rem;
          column-gap: 5.625rem;
  row-gap: 2.5rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 767.9px) {
  .footer__middle {
    margin-top: 0;
    grid-template-columns: 1fr;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    row-gap: 0;
  }
}

.footer__block {
  min-width: 0;
}

.footer__heading {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.2;
}
@media screen and (max-width: 767.9px) {
  .footer__heading {
    font-size: 1.125rem;
  }
}

.footer__heading + .footer__text,
.footer__heading + .footer__accounts {
  margin-top: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .footer__heading + .footer__text,
  .footer__heading + .footer__accounts {
    margin-top: 0.625rem;
  }
}

.footer__text {
  font-size: 0.875rem;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .footer__text {
    font-size: 0.75rem;
    letter-spacing: 0.07em;
  }
}

.footer__accounts {
  margin-top: 3.125rem;
}

.footer__accounts-item + .footer__accounts-item {
  margin-top: 0.3125rem;
}

.footer__account-link {
  font-size: 0.75rem;
  line-height: 2;
  color: #fff;
  position: relative;
}
.footer__account-link::after {
  content: "";
  position: absolute;
  top: 55%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -1.5625rem;
  width: 0.625rem;
  height: 0.625rem;
  background-image: url(../img/icon_blank.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

@media screen and (max-width: 767.9px) {
  .footer__block--location,
  .footer__block--links {
    margin-top: 1.5625rem;
  }
}

.footer__block--cta {
  justify-self: end;
  -ms-flex-item-align: end;
      align-self: end;
}
@media screen and (max-width: 767.9px) {
  .footer__block--cta {
    margin-top: 2.5rem;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    grid-column: 1;
    justify-self: stretch;
    width: 100%;
    max-width: 12rem;
  }
}

@media screen and (max-width: 767.9px) {
  .footer__block--location {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}

@media screen and (max-width: 767.9px) {
  .footer__block--links {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}

.footer__contact {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0.9375rem 8.75rem 0.9375rem 1.4375rem;
  position: relative;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.75rem;
  line-height: 1;
  color: #242A2E;
  background-color: #e6e6e6;
  border-radius: 0.25rem;
  font-weight: 600;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease;
}
.footer__contact::before {
  position: absolute;
  content: "";
  width: 5rem;
  height: 2.1875rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0.75rem;
  background-image: url(../img/icon_arrow-black.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .footer__contact::before {
    width: 3.25rem;
    height: 1.4375rem;
    right: 0.46875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .footer__contact {
    font-size: 1rem;
    padding: 0.625rem 6.25rem 0.625rem 0.9375rem;
  }
}
.footer__contact:hover {
  opacity: 1;
  background-color: #161a1c;
  color: #fff;
  -webkit-box-shadow: 0 0 1.5rem rgba(255, 255, 255, 0.25);
          box-shadow: 0 0 1.5rem rgba(255, 255, 255, 0.25);
}
.footer__contact:hover::before {
  background-image: url(../img/icon_arrow-white.svg);
}

.footer__bottom {
  margin-top: 4.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  border-top: 0.5px solid #8E8E8E;
}
@media screen and (max-width: 767.9px) {
  .footer__bottom {
    margin-top: 2.8125rem;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.footer__legal {
  margin-top: 1.5625rem;
  font-size: 0.8125rem;
  line-height: 2;
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 0.1875rem;
}
@media screen and (max-width: 767.9px) {
  .footer__legal {
    margin-top: 1.25rem;
    font-size: 0.625rem;
  }
}

.footer__copyright {
  margin-top: 1.875rem;
  font-family: "Cormorant Garamond", serif;
  font-size: 0.8125rem;
  line-height: 2;
}
@media screen and (max-width: 767.9px) {
  .footer__copyright {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    text-align: right;
    margin-top: 1.5625rem;
    font-size: 0.625rem;
  }
}

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

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

.glass {
  overflow: hidden;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.42) 0%, rgba(255, 255, 255, 0.18) 38%, rgba(255, 255, 255, 0.08) 100%);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-bottom-color: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(0.3px) saturate(1.35);
  -webkit-backdrop-filter: blur(0.3px) saturate(1.35);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.12), 0 0.5rem 2rem rgba(45, 45, 45, 0.14), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.2);
}

.glass02 {
  overflow: hidden;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.01) 0%, rgba(255, 255, 255, 0.01) 38%, rgba(255, 255, 255, 0.01) 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
  border-bottom-color: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px) saturate(1.35);
  -webkit-backdrop-filter: blur(10px) saturate(1.35);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.1), 0 0.5rem 1.8125rem rgba(45, 45, 45, 0.1), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.1);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.1), 0 0.5rem 1.8125rem rgba(45, 45, 45, 0.1), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.1);
}
@media screen and (max-width: 767.9px) {
  .glass02 {
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.1), 0 0.5rem 0.5625rem rgba(45, 45, 45, 0.1), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.1);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), inset 0 -0.0625rem 0.75rem rgba(255, 255, 255, 0.1), 0 0.5rem 0.5625rem rgba(45, 45, 45, 0.1), 0 0.125rem 0.5rem rgba(255, 255, 255, 0.1);
  }
}

.btn {
  margin-top: clamp(2.5rem, 7vh, 6.75rem);
  display: block;
  background-color: #000;
  border-radius: 0.1875rem;
  width: 100%;
  max-width: 13rem;
  color: #fff;
  font-size: 1rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  padding: 0.53125rem 1rem;
  position: relative;
  -webkit-transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
  transition: opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .btn {
    margin-top: clamp(1.5rem, 5vh, 2.5rem);
    margin-inline: auto;
    max-width: 12rem;
  }
}
.btn::before {
  position: absolute;
  content: "";
  width: 3.5rem;
  height: 1.6875rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0.5rem;
  background-image: url(../img/icon_arrow-white.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767.9px) {
  .btn::before {
    width: 3.25rem;
    height: 1.4375rem;
  }
}
.btn:hover {
  opacity: 1;
  background-color: #fff;
  color: #000;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
}
.btn:hover::before {
  background-image: url(../img/icon_arrow-black.svg);
}

.btn.btn--white {
  background-color: #fff;
  color: #242A2E;
}
.btn.btn--white::before {
  background-image: url(../img/icon_arrow-black.svg);
}
.btn.btn--white:hover {
  opacity: 1;
  background-color: #000;
  color: #fff;
  -webkit-box-shadow: 0 0 1.5rem rgba(255, 255, 255, 0.25);
          box-shadow: 0 0 1.5rem rgba(255, 255, 255, 0.25);
}
.btn.btn--white:hover::before {
  background-image: url(../img/icon_arrow-white.svg);
}

.ls-m-016 {
  letter-spacing: -0.16em;
}

.ls-m-018 {
  letter-spacing: -0.18em;
}

.ls-p-004 {
  letter-spacing: 0.04em;
}

.breadcrumb {
  margin-top: 3.4375rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  color: #242A2E;
  text-align: right;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 767.9px) {
  .breadcrumb {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    margin-top: 0;
    margin-left: auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    font-size: 0.75rem;
    letter-spacing: 0.03em;
    padding: 0.4375rem 1rem;
    background-color: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(0.3px);
    -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
            box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
    border-radius: 0.125rem;
  }
}

.breadcrumb.breadcrumb--white {
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .breadcrumb.breadcrumb--white {
    color: #242A2E;
  }
}
.breadcrumb.breadcrumb--white .breadcrumb__between {
  background-color: #fff;
}
@media screen and (max-width: 767.9px) {
  .breadcrumb.breadcrumb--white .breadcrumb__between {
    background-color: #2B2B2B;
  }
}

.breadcrumb__between {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 2.8125rem;
  height: 0.03125rem;
  margin: 0 1.875rem;
  background-color: #000;
}
@media screen and (max-width: 767.9px) {
  .breadcrumb__between {
    width: 1.25rem;
    margin: 0 0.625rem;
  }
}

.breadcrumb span[property=name]:not(.current-item) {
  color: #ABABAB;
}
@media screen and (max-width: 767.9px) {
  .breadcrumb span[property=name]:not(.current-item) {
    color: #2B2B2B;
  }
}

.breadcrumb span[property=itemListElement]:has(.current-item) {
  min-width: 0;
  max-width: 30em;
}
@media screen and (max-width: 767.9px) {
  .breadcrumb span[property=itemListElement]:has(.current-item) {
    max-width: 11em;
  }
}

.breadcrumb span[property=name].current-item {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-head {
  position: relative;
}

.page-head__inner {
  max-width: 73.75rem;
  margin-inline: auto;
  padding-top: 9.375rem;
  padding-bottom: 1.4375rem;
}
@media screen and (max-width: 767.9px) {
  .page-head__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
    max-width: none;
    width: 100%;
    padding: 6.25rem 1.5625rem 0;
  }
}

@media screen and (max-width: 767.9px) {
  .page-head:has(.page-head__img-wrap) .page-head__inner {
    position: absolute;
    inset: 0 0 auto 0;
    z-index: 2;
    padding-bottom: 3.75rem;
  }
}

.page-head__title {
  margin-top: 6.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3.75rem;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
@media screen and (max-width: 767.9px) {
  .page-head__title {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-top: 1.875rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.375rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.page-head__title-en {
  font-size: 6rem;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  color: #2B2B2B;
  text-transform: uppercase;
  line-height: 1.22;
}
@media screen and (max-width: 767.9px) {
  .page-head__title-en {
    font-size: 2.625rem;
  }
}

.page-head__title-en.page-head__title-en--white {
  color: #fff;
}

@media screen and (max-width: 767.9px) {
  .page-head__title-en.page-head__title-en--spwhite {
    color: #fff;
  }
}

.page-head__title-ja {
  font-size: 1.125rem;
  line-height: 2.2222222222;
  letter-spacing: 0.07em;
  color: #2B2B2B;
  font-weight: 400;
}
.page-head__title-ja span {
  font-family: "Cormorant Garamond", serif;
  line-height: 2.6666666667;
  font-weight: 500;
}
@media screen and (max-width: 767.9px) {
  .page-head__title-ja span {
    line-height: 1.22;
  }
}
@media screen and (max-width: 767.9px) {
  .page-head__title-ja {
    font-size: 0.96875rem;
    line-height: 1.22;
  }
}

.page-head__title-ja.page-head__title-ja--white {
  color: #fff;
}

@media screen and (max-width: 767.9px) {
  .page-head__title-ja.page-head__title-ja--spwhite {
    color: #fff;
  }
}

@media screen and (max-width: 767.9px) {
  .page-head .label {
    margin-top: 0.625rem;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.8);
    text-shadow: 0 0.125rem 0.5rem rgba(0, 0, 0, 0.22);
  }
  .page-head .label::before {
    background-color: #fff;
  }
}

.page-head__img-wrap {
  height: 32.375rem;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .page-head__img-wrap {
    position: relative;
    height: 20.375rem;
  }
}

.page-head__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 767.9px) {
  .page-head__img {
    display: block;
  }
}

.page-head__img-wrap.js-parallax-section {
  position: relative;
}
.page-head__img-wrap.js-parallax-section picture {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  line-height: 0;
}
.page-head__img-wrap.js-parallax-section .page-head__img.js-parallax-bg {
  position: absolute;
  top: -12%;
  left: 0;
  width: 100%;
  height: 124%;
  max-height: none;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  will-change: transform;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
@media screen and (max-width: 767.9px) {
  .page-head__img-wrap.js-parallax-section .page-head__img.js-parallax-bg {
    top: -14%;
    height: 128%;
  }
}

.label {
  font-size: 0.8125rem;
  font-weight: 400;
  color: #2B2B2B;
  border-bottom: 1px solid #2B2B2B;
  padding-bottom: 0.3125rem;
  padding-left: 1.125rem;
  position: relative;
  letter-spacing: 0.05em;
}
.label::before {
  position: absolute;
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  background-color: #2B2B2B;
}

.label.label--white {
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.7);
}
.label.label--white::before {
  background-color: #fff;
}

.label.label--black {
  color: #2B2B2B;
  border-bottom: 1px solid #2B2B2B;
}
.label.label--black::before {
  background-color: #2B2B2B;
}

.slideInBottom {
  opacity: 0;
  -webkit-transform: translateY(3.125rem);
          transform: translateY(3.125rem);
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

.slideInBottom.active {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.pagination {
  margin-top: 7.5rem;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .pagination {
    margin-top: 3.125rem;
  }
}
.pagination .nav-links {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .pagination .nav-links {
    gap: 1.125rem;
  }
}
.pagination .page-numbers {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 0.5rem;
  background-color: #fff;
  color: #2B2B2B;
  font-size: 1rem;
  line-height: 1;
  text-decoration: none;
  -webkit-box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
          box-shadow: 0 0 1.5rem rgba(117, 117, 117, 0.25);
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 767.9px) {
  .pagination .page-numbers {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 0.9375rem;
  }
}
.pagination .page-numbers:hover {
  opacity: 0.7;
}
.pagination .page-numbers.current {
  background-color: #2B2B2B;
  color: #fff;
  -webkit-box-shadow: 0 0.125rem 0.625rem rgba(0, 0, 0, 0.2);
          box-shadow: 0 0.125rem 0.625rem rgba(0, 0, 0, 0.2);
}
.pagination .page-numbers.dots {
  background-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
  width: auto;
  padding: 0 0.25rem;
}

body:has(main.philosophy),
body:has(main.recruit) {
  background-color: #161A1C;
}

@media screen and (max-width: 767.9px) {
  html.is-cursor-fire-active,
  html.is-cursor-fire-active.is-cursor-fire-dot-on {
    cursor: auto;
  }
  html.is-cursor-fire-active a,
  html.is-cursor-fire-active button,
  html.is-cursor-fire-active input,
  html.is-cursor-fire-active textarea,
  html.is-cursor-fire-active select,
  html.is-cursor-fire-active label {
    cursor: auto;
  }
  .cursor-fire-glow-portal,
  .cursor-fire-ui,
  .cursor-fire-glow,
  .cursor-fire,
  .cursor-fire-dot,
  .cursor-fire__video {
    display: none !important;
    visibility: hidden !important;
  }
}
@media screen and (min-width: 768px) {
  html.is-cursor-fire-active.is-cursor-fire-dot-on {
    cursor: none;
  }
  html.is-cursor-fire-active.is-cursor-fire-dot-on a,
  html.is-cursor-fire-active.is-cursor-fire-dot-on button,
  html.is-cursor-fire-active.is-cursor-fire-dot-on input,
  html.is-cursor-fire-active.is-cursor-fire-dot-on textarea,
  html.is-cursor-fire-active.is-cursor-fire-dot-on select,
  html.is-cursor-fire-active.is-cursor-fire-dot-on label {
    cursor: none;
  }
  .cursor-fire-glow-portal {
    position: fixed;
    inset: 0;
    z-index: 2147483646;
    pointer-events: none;
    overflow: visible;
  }
  .cursor-fire-ui {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2147483647;
    pointer-events: none;
    overflow: visible;
  }
  .cursor-fire-ui.is-visible .cursor-fire-dot,
  .cursor-fire-ui.is-visible .cursor-fire {
    opacity: 1;
    visibility: visible;
  }
  .cursor-fire-dot {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    will-change: transform;
    background: #386C95;
    -webkit-transition: opacity 0.2s ease, visibility 0.2s ease;
    transition: opacity 0.2s ease, visibility 0.2s ease;
  }
  .cursor-fire-glow {
    position: fixed;
    top: 0;
    left: 0;
    width: 17.5rem;
    height: 17.5rem;
    border-radius: 50%;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    will-change: transform;
    -webkit-transition: opacity 0.2s ease, visibility 0.2s ease;
    transition: opacity 0.2s ease, visibility 0.2s ease;
    background: radial-gradient(circle, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0.78) 14%, rgba(255, 255, 255, 0.42) 32%, rgba(255, 255, 255, 0.2) 46%, rgba(255, 255, 255, 0.08) 58%, rgba(255, 255, 255, 0.025) 70%, rgba(255, 255, 255, 0.008) 82%, transparent 94%);
    mix-blend-mode: difference;
  }
  .cursor-fire-glow.is-visible {
    opacity: 1;
    visibility: visible;
  }
  .cursor-fire {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
    width: 4.5rem;
    aspect-ratio: 375/730;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    will-change: transform;
    -webkit-transition: opacity 0.2s ease, visibility 0.2s ease;
    transition: opacity 0.2s ease, visibility 0.2s ease;
    --cursor-fire-offset-x: 2.5rem;
    --cursor-fire-offset-y: 1rem;
    --cursor-fire-anchor-x: 0.28;
    --cursor-fire-anchor-y: 0.9;
  }
  .cursor-fire__video {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
}/*# sourceMappingURL=style.css.map */