@charset "UTF-8";
html {
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

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

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul, summary {
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

:root {
  --color-text: #100e0f;
  --color-bg: #fff;
  --color-black-800: #100e0f;
  --color-black-700: #302d2d;
  --color-black-600: #656565;
  --color-black-500: #a0a0a0;
  --color-black-400: #dbdbdb;
  --color-black-300: #eeeeee;
  --color-black-200: #f4f4f4;
  --color-white: #fff;
  --color-blue-400: #053a86;
  --color-blue-500: #042d68;
  --color-blue-100: #e6ebf3;
  --color-red-100: #f7eae6;
  --color-red-200: #d99580;
  --color-red-300: #c96a4d;
  --color-red-400: #b22a00;
  --color-red-500: #8e2200;
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
}

@media screen and (max-width: 1319px) and (min-width: 768px) {
  html {
    font-size: calc(16 / 1320 * 100vw);
  }
}
@media screen and (max-width: 374px) {
  html {
    font-size: calc(16 / 375 * 100vw);
  }
}

body {
  color: var(--color-text);
  background-color: var(--color-bg);
  font-family: "Instrument Sans", "Noto Sans JP", sans-serif;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
}
body:has(.p-drawer.js-show) {
  overflow: hidden;
}

body {
  --header-height: 132;
}
@media screen and (max-width: 767.9px) {
  body {
    --header-height: 84;
  }
}
body:has(.l-header.is-hidden) {
  --header-height: 0;
}
@media screen and (max-width: 767.9px) {
  body:has(.l-header.is-hidden) {
    --header-height: 0;
  }
}

[lang=en] {
  font-family: "Instrument Sans", sans-serif;
}

[lang=ja] {
  font-family: "Instrument Sans", "Noto Sans JP", sans-serif;
}

.l-container {
  opacity: 0;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}

.l-container.js-show {
  opacity: 1;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}

.l-container.js-page-transition {
  opacity: 0;
}

a {
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  color: inherit;
}
@media (hover: hover) {
  a:hover {
    cursor: pointer;
  }
}

picture,
img,
a,
span {
  display: inline-block;
}

picture {
  display: contents;
}

video,
img,
svg {
  width: 100%;
  height: 100%;
}

button {
  font: inherit;
  color: inherit;
  background: transparent;
  background: none;
  border: none;
  cursor: pointer;
}

input,
textarea,
select {
  font: inherit;
}

address {
  font-style: normal;
}

@media (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}
.l-header {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  height: max(8.25rem, 105.6px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: opacity 0.2s ease, background-color 0.24s ease, -webkit-transform 0.28s ease, -webkit-box-shadow 0.24s var(--ease-out-quint);
  transition: opacity 0.2s ease, background-color 0.24s ease, -webkit-transform 0.28s ease, -webkit-box-shadow 0.24s var(--ease-out-quint);
  transition: transform 0.28s ease, opacity 0.2s ease, background-color 0.24s ease, box-shadow 0.24s var(--ease-out-quint);
  transition: transform 0.28s ease, opacity 0.2s ease, background-color 0.24s ease, box-shadow 0.24s var(--ease-out-quint), -webkit-transform 0.28s ease, -webkit-box-shadow 0.24s var(--ease-out-quint);
  will-change: transform;
  --header-hide-offset: 100%;
}
.l-header.is-background {
  background-color: rgba(255, 255, 255, 0.6);
  -webkit-filter: drop-shadow(0 2px 16px rgba(0, 0, 0, 0.15));
          filter: drop-shadow(0 2px 16px rgba(0, 0, 0, 0.15));
}
.l-header.is-hidden {
  -webkit-transform: translateY(calc(-1 * var(--header-hide-offset)));
          transform: translateY(calc(-1 * var(--header-hide-offset)));
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 767.9px) {
  .l-header {
    height: 5.5rem;
  }
}
.l-header:has(~ .p-drawer.js-show) {
  -webkit-box-shadow: initial;
          box-shadow: initial;
  background-color: transparent;
}
.l-header:has(.js-has-sub:hover) {
  background-color: rgba(255, 255, 255, 0.6);
}

.l-header__inner {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
  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: 1.5rem;
  padding-inline: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-header__inner {
    padding-inline: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .l-header__inner {
    gap: 0.25rem;
  }
}

.l-header__logo {
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .l-header__logo:hover {
    opacity: 0.5;
  }
}

.l-header__logo-img {
  width: max(9.0625rem, 116px);
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 767.9px) {
  .l-header__logo-img {
    width: 5.8125rem;
  }
}

.l-header__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: max(1rem, 12.8px);
  max-width: max(70rem, 896px);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
}
@media (width < 1100px) {
  .l-header__content {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
  }
}

.l-header__nav {
  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: end;
  gap: 3.75rem;
}
@media screen and (max-width: 767.9px) {
  .l-header__nav {
    display: none;
  }
}

.l-header__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 2rem;
     -moz-column-gap: 2rem;
          column-gap: 2rem;
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  position: relative;
  z-index: 1;
  display: flex;
}
@media screen and (max-width: 767.9px) {
  .l-header__list {
    font-size: 0.9375rem;
  }
}
.l-header__list > li .l-header__link-text {
  -webkit-transition: color 0.3s var(--ease-out-quint);
  transition: color 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .l-header__list > li:hover .l-header__link-text {
    color: #e60013;
  }
  .l-header__list > li:hover .l-header__link-arrow path {
    fill: #e60013;
  }
  .l-header__list > li:hover .l-header__link-toggle:after,
  .l-header__list > li:hover .l-header__link-toggle:before {
    background-color: #e60013;
  }
  .l-header__list > li:hover .l-header__link-toggle:after {
    rotate: 90deg;
  }
}
.l-header__list > li .l-header__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: max(0.375rem, 4.8px);
}
.l-header__list > li .l-header__link:after {
  opacity: 0;
  position: absolute;
  bottom: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: var(--color-red);
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .l-header__list > li:hover:after {
    opacity: 1;
  }
}

.l-header__link-toggle {
  position: relative;
  width: max(0.875rem, 11.2px);
}
.l-header__link-toggle::after, .l-header__link-toggle::before {
  content: "";
  position: absolute;
  background-color: var(--color-black-800);
  display: block;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  -webkit-transition: background 0.3s var(--ease-out-quint), rotate 0.3s var(--ease-out-quint);
  transition: background 0.3s var(--ease-out-quint), rotate 0.3s var(--ease-out-quint);
}
.l-header__link-toggle:before {
  width: 10px;
  height: 2px;
}
.l-header__link-toggle:after {
  width: 2px;
  height: 10px;
}

.l-header__link-arrow-wrap,
.l-header__link-text-wrap {
  overflow: hidden;
  position: relative;
}
.l-header__link-arrow-wrap > *:nth-child(2),
.l-header__link-text-wrap > *:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
}

.l-header__link-arrow-wrap > * {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.l-header__link-arrow {
  width: max(0.8125rem, 10.4px);
  height: auto;
  rotate: -45deg;
}
.l-header__link-arrow path {
  -webkit-transition: fill 0.3s var(--ease-out-quint);
  transition: fill 0.3s var(--ease-out-quint);
}

.l-header__item {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-header__item.js-has-sub:hover .l-header__sub-menu-wrap {
  opacity: 1;
  visibility: visible;
}

.l-header__sub-menu-wrap {
  position: fixed;
  top: max(8.25rem, 105.6px);
  left: 0;
  right: 0;
  z-index: 50;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.6);
  padding-top: 40px;
  padding-bottom: 40px;
  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;
  gap: 1.5rem;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.3s ease, visibility 0.3s var(--ease-out-quint);
  transition: opacity 0.3s ease, visibility 0.3s var(--ease-out-quint);
}

.l-header__sub-menu-title {
  font-size: max(1.25rem, 16px);
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .l-header__sub-menu-title {
    font-size: 1.25rem;
  }
}

.l-header__sub-menu-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 3.5rem 1.5rem;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0em;
  --card-items: 4;
  --card-gap: 24;
  gap: calc(var(--card-gap) / 16 * 1rem);
}
@media screen and (max-width: 767.9px) {
  .l-header__sub-menu-list {
    font-size: 1rem;
  }
}

.l-header__sub-menu-list-item {
  -ms-flex-preferred-size: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
      flex-basis: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
}

.l-header__sub-link {
  -webkit-transition: color 0.3s var(--ease-out-quint);
  transition: color 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .l-header__sub-link:hover .l-header__sub-link-img {
    scale: 1.1;
  }
}

.l-header__sub-link-img-wrap {
  width: 18.25rem;
  height: 12.625rem;
  aspect-ratio: 292/202;
  overflow: hidden;
}

.l-header__sub-link-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
  -webkit-transition: scale 0.3s var(--ease-out-quint);
  transition: scale 0.3s var(--ease-out-quint);
}

.l-header__sub-link-text-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 0.5rem;
}

.l-header__sub-list-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .l-header__sub-list-text {
    font-size: 0.875rem;
  }
}

.l-header__contact-sub-list-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0em;
  color: var(--color-white);
}
@media screen and (max-width: 767.9px) {
  .l-header__contact-sub-list-text {
    font-size: 0.875rem;
  }
}

.l-header__sub-list-arrow-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  translate: 0 -1px;
}

.l-header__sub-list-arrow {
  width: 0.9375rem;
  height: auto;
}

.l-header__sub-link-arrow-wrap {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.l-header__sub-link-arrow {
  width: 1rem;
  height: auto;
}

.l-header__btn-wrap {
  display: grid;
  justify-items: center;
  position: relative;
  gap: 0.25rem;
  margin-left: auto;
}

.l-header__btn-balloon {
  font-size: max(0.625rem, 8px);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0em;
  position: absolute;
  top: -1.3125rem;
  left: 50%;
  translate: -50%;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
@media screen and (max-width: 767.9px) {
  .l-header__btn-balloon {
    font-size: 0.625rem;
  }
}
@media screen and (max-width: 767.9px) {
  .l-header__btn-balloon {
    font-size: max(0.625rem, 8px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .l-header__btn-balloon {
    font-size: 0.625rem;
  }
}

.l-header__btn-block {
  background-color: var(--color-black-800);
  color: var(--color-white);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-inline: max(1rem, 12.8px) max(1.0625rem, 13.6px);
  padding-block: max(0.5rem, 6.4px);
  border-radius: max(0.25rem, 3.2px);
  min-height: max(3.4375rem, 44px);
  width: max(19.5625rem, 250.4px);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  cursor: pointer;
  position: relative;
}
.l-header__btn-block::before {
  content: "";
  position: absolute;
  width: 1px;
  height: max(2.6875rem, 34.4px);
  display: block;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  background-color: var(--color-black-700);
}
.l-header__btn-block:hover .l-header__contact-sub-menu {
  -webkit-transform: scaleY(1);
          transform: scaleY(1);
}
.l-header__btn-block:hover .l-header__contact-btn-toggle:after {
  rotate: 90deg;
}

.l-header__tel-btn,
.l-header__contact-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(0.25rem, 3.2px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.l-header__btn-icon {
  width: max(1rem, 12.8px);
}

.l-header__tel-btn-text-wrap {
  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;
}

.l-header__tel-btn-no {
  font-size: max(1rem, 12.8px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .l-header__tel-btn-no {
    font-size: 1rem;
  }
}

.l-header__tel-btn-hours {
  font-size: max(0.5625rem, 7.2px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0em;
  color: var(--color-black-400);
  margin-top: -1px;
}
@media screen and (max-width: 767.9px) {
  .l-header__tel-btn-hours {
    font-size: 0.5625rem;
  }
}

.l-header__contact-btn-text-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(0.125rem, 1.6px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.l-header__contact-btn-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0em;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .l-header__contact-btn-text {
    font-size: 0.875rem;
  }
}

.l-header__contact-btn-toggle {
  position: relative;
  width: max(0.875rem, 11.2px);
}
.l-header__contact-btn-toggle::after, .l-header__contact-btn-toggle::before {
  content: "";
  position: absolute;
  background-color: #fff;
  display: block;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
.l-header__contact-btn-toggle:before {
  width: 10px;
  height: 2px;
}
.l-header__contact-btn-toggle:after {
  width: 2px;
  height: 10px;
  -webkit-transition: rotate 0.3s var(--ease-out-quint);
  transition: rotate 0.3s var(--ease-out-quint);
}

.l-header__contact-sub-menu {
  position: absolute;
  top: calc(100% - 4px);
  right: 0;
  left: 0;
  background-color: var(--color-black-800);
  padding: max(1.5rem, 19.2px);
  z-index: 1;
  border-radius: max(0.25rem, 3.2px);
  -webkit-transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint), -webkit-transform 0.3s var(--ease-out-quint);
  -webkit-transform: scaleY(0);
          transform: scaleY(0);
  -webkit-transform-origin: top center;
          transform-origin: top center;
}

.l-header__contact-sub-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: max(1rem, 12.8px);
}

.l-header__contact-sub-link {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.7230769231;
  letter-spacing: 0em;
  color: var(--color-black-400);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: max(0.25rem, 3.2px);
}
@media screen and (max-width: 767.9px) {
  .l-header__contact-sub-link {
    font-size: 0.8125rem;
  }
}

.l-main {
  min-height: 100svh;
}

.l-inner {
  position: relative;
  width: 100%;
  max-width: 1320px;
  height: inherit;
  padding: 0 2.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .l-inner {
    width: 100%;
    max-width: 640px;
    padding: 0 1.25rem;
  }
}

.l-inner__narrow {
  max-width: 50rem;
}
@media screen and (max-width: 767.9px) {
  .l-inner__narrow {
    padding: 0 1.25rem;
    max-width: 600px;
  }
}

.l-footer {
  background-color: var(--color-black-800);
  color: #fff;
  padding-block: 7.5625rem 4rem;
}
@media screen and (max-width: 767.9px) {
  .l-footer {
    padding-block: 4.75rem 2.5rem;
  }
}

.l-footer__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1320px;
  padding-inline: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-footer__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-inline: 1.25rem;
  }
}

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

.l-footer__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-footer__top {
    display: contents;
  }
}

.l-footer__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.5rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .l-footer__info {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    margin-top: 4.5rem;
  }
}

.l-footer__logo-wrap a {
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .l-footer__logo-wrap a:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767.9px) {
  .l-footer__logo-wrap {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.l-footer__logo-img {
  width: max(9.375rem, 120px);
  height: auto;
  display: block;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .l-footer__logo-img {
    width: 9.375rem;
  }
}

.l-footer__address-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}

.l-footer__address {
  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;
}

.l-footer__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  max-width: max(42.5rem, 544px);
}
@media screen and (max-width: 767.9px) {
  .l-footer__body {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
}

.l-footer__nav-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.5rem;
  padding-bottom: max(3rem, 38.4px);
  border-bottom: 1px solid var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .l-footer__nav-container {
    gap: 2rem;
    padding-bottom: 3rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.l-footer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.l-footer__nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: max(2rem, 25.6px) max(2.5rem, 32px);
  height: max(12.5625rem, 160.8px);
}
@media screen and (max-width: 767.9px) {
  .l-footer__nav-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
  }
}

.l-footer__nav-item {
  width: max(12.5rem, 160px);
}

.l-footer__nav-link {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .l-footer__nav-link {
    font-size: 0.9375rem;
  }
}

.l-footer__body .l-footer__nav-list-btn {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  min-width: max(12.5rem, 160px) !important;
  min-height: max(3.5rem, 44.8px);
}
.l-footer__body .l-footer__nav-list-btn-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .l-footer__body .l-footer__nav-list-btn-text {
    font-size: 0.9375rem;
  }
}
.l-footer__body .l-footer__nav-list-btn-arrow-wrap {
  width: max(2.5rem, 32px);
  height: max(2.5rem, 32px);
}

.l-footer__address-name {
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .l-footer__address-name {
    font-size: 1rem;
  }
}

.l-footer__address-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: var(--color-black-500);
}
@media screen and (max-width: 767.9px) {
  .l-footer__address-text {
    font-size: 0.875rem;
  }
}

.l-footer__address-text-arrow {
  width: max(0.6875rem, 8.8px);
  height: auto;
  rotate: -45deg;
  margin-inline: 0.125rem 0rem;
  translate: 0 1px;
}
@media screen and (max-width: 767.9px) {
  .l-footer__address-text-arrow {
    width: 0.6875rem;
  }
}

.l-footer__address-text-link {
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
  color: var(--color-red-400);
}
@media (any-hover: hover) {
  .l-footer__address-text-link:hover {
    opacity: 0.7;
  }
}

.l-footer__btn-wrap {
  margin-top: 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  --card-items: 2;
  --card-gap: 20;
  gap: calc(var(--card-gap) / 16 * 1rem);
}
@media screen and (max-width: 767.9px) {
  .l-footer__btn-wrap {
    --card-gap: 12;
  }
}
.l-footer__btn-wrap .l-footer__btn-wrap-btn {
  -ms-flex-preferred-size: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
      flex-basis: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
  height: max(4.5rem, 57.6px);
  padding-inline: 1rem 0.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-footer__btn-wrap .l-footer__btn-wrap-btn {
    max-width: 20.9375rem;
    min-width: auto;
    width: 100%;
  }
}
.l-footer__btn-wrap .l-footer__btn-wrap-btn-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .l-footer__btn-wrap .l-footer__btn-wrap-btn-text {
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .l-footer__btn-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.l-footer__bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 5.5625rem;
  color: var(--color-black-500);
}
@media screen and (max-width: 767.9px) {
  .l-footer__bottom {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
    margin-top: 3.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: initial;
        -ms-flex-pack: initial;
            justify-content: initial;
    -webkit-box-align: initial;
        -ms-flex-align: initial;
            align-items: initial;
    gap: 1.5rem;
  }
}

.l-footer__bottom-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-footer__bottom-nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.75rem;
  }
}

.l-footer__bottom-nav-item-link {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media screen and (max-width: 767.9px) {
  .l-footer__bottom-nav-item-link {
    font-size: 0.8125rem;
  }
}
@media (any-hover: hover) {
  .l-footer__bottom-nav-item-link:hover {
    opacity: 0.7;
  }
}

.l-footer__copyright {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .l-footer__copyright {
    font-size: 0.8125rem;
  }
}

.l-under-main {
  min-height: 100svh;
  padding-top: 13.75rem;
  overflow-x: clip;
}
@media screen and (max-width: 767.9px) {
  .l-under-main {
    padding-top: 6.5rem;
  }
}
.l-under-main.--grid {
  background-color: var(--color-white);
  background-image: linear-gradient(to right, rgba(220, 220, 220, 0.2) 1px, transparent 1px), linear-gradient(to bottom, rgba(220, 220, 220, 0.2) 1px, transparent 1px);
  background-size: 28px 28px;
  background-position: 0 -14px;
  overflow-x: clip;
}

.l-under-main__inner {
  position: relative;
  width: 100%;
  max-width: 1320px;
  height: inherit;
  padding: 0 2.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__inner {
    width: 100%;
    max-width: 640px;
    padding: 0 1.25rem;
  }
}

.l-under-main__top {
  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;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__top {
    -webkit-box-pack: initial;
        -ms-flex-pack: initial;
            justify-content: initial;
  }
}

.l-under-main__content {
  margin-top: 5rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content {
    margin-top: 3rem;
  }
}
.l-under-main__content.--member {
  margin-top: 6.5625rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--member {
    margin-top: 3.5rem;
  }
}
.l-under-main__content.--member-single {
  margin-top: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--member-single {
    margin-top: 2rem;
  }
}
.l-under-main__content.--news-single {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--news-single {
    margin-top: 2.5rem;
  }
}
.l-under-main__content.--media {
  margin-top: 5.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--media {
    margin-top: 4rem;
  }
}
.l-under-main__content.--sitemap {
  margin-top: 4rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--sitemap {
    margin-top: 2.5rem;
  }
}
.l-under-main__content.--thanks {
  margin-top: 4rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--thanks {
    margin-top: 4rem;
  }
}
.l-under-main__content.--contact {
  margin-top: 5.5rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__content.--contact {
    margin-top: 4rem;
  }
}

.l-under-main__top-sentence {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  margin-top: 2rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-main__top-sentence {
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .l-under-main__top-sentence {
    margin-top: 2.5rem;
  }
}

.l-under-main__top-sentence a {
  color: var(--color-red-400);
  font-weight: 500;
  text-decoration: underline;
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .l-under-main__top-sentence a:hover {
    opacity: 0.7;
  }
}

.l-2column {
  position: relative;
}

@media screen and (max-width: 767.9px) {
  .l-2column__content {
    margin-top: 4rem;
  }
}

.l-2column__full {
  margin-inline: calc(50% - 50vw);
  width: 100vw;
}
.l-2column__full.--gray {
  background-color: var(--color-black-200);
}
.l-2column__full.--grid {
  background-image: linear-gradient(to right, #ededed 1px, transparent 1px), linear-gradient(to bottom, #ededed 1px, transparent 1px);
  background-size: 28px 28px;
}

.l-2column__full-inner {
  max-width: 77.5rem;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
}
@media screen and (max-width: 767.9px) {
  .l-2column__full-inner {
    max-width: 40rem;
    padding-inline: 1.25rem;
  }
}

.l-2column__section {
  min-width: 600px;
  width: 57.5rem;
  margin-left: auto;
}
@media screen and (max-width: 767.9px) {
  .l-2column__section {
    width: 100%;
    min-width: initial;
    margin-left: 0;
  }
}
.l-2column__section h2 {
  scroll-margin-top: 18.75rem;
}
@media screen and (max-width: 767.9px) {
  .l-2column__section h2 {
    scroll-margin-top: 6.25rem;
  }
}

.l-under-section {
  border-bottom: 1px solid var(--color-black-400);
  padding-bottom: 2.5rem;
  padding-top: 2.5rem;
}
.l-under-section:first-child {
  padding-top: 0;
}
.l-under-section:last-child {
  border-bottom: none;
}
@media screen and (max-width: 767.9px) {
  .l-under-section.--sitemap {
    padding-bottom: 1.5rem;
    padding-top: 1.5rem;
  }
  .l-under-section.--sitemap:first-child {
    padding-top: 0;
  }
  .l-under-section.--sitemap:last-child {
    border-bottom: none;
  }
}

.l-under-section__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  gap: 4rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-section__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
}

.l-under-section__content {
  max-width: 560px;
  width: 100%;
  margin-top: 4.4375rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-section__content {
    margin-top: 1.5rem;
    max-width: 100%;
  }
}
.l-under-section__content.--sitemap {
  margin-top: 3.8125rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-section__content.--sitemap {
    margin-top: 1rem;
  }
}

.l-under-section__header-group {
  position: sticky;
  top: calc(5rem + var(--header-height) / 16 * 1rem);
  will-change: top;
  -webkit-transition: top 0.28s var(--ease-out-quint);
  transition: top 0.28s var(--ease-out-quint);
  height: 100%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  max-width: 25.125rem;
  -ms-flex-preferred-size: 25.125rem;
      flex-basis: 25.125rem;
}
@media screen and (max-width: 767.9px) {
  .l-under-section__header-group {
    position: initial;
    top: initial;
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
    max-width: 100%;
  }
}

.c-cta-btn {
  --bg-color: var(--color-red-400);
  --bg-arrow-color: var(--color-red-500);
  --arrow-deg: 0deg;
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: var(--bg-color);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: var(--color-white);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: max(16.375rem, 209.6px);
  padding-inline: max(1.25rem, 16px) max(0.5rem, 6.4px);
  padding-block: max(0.5rem, 6.4px);
  border-radius: max(0.25rem, 3.2px);
  gap: max(1rem, 12.8px);
  -webkit-transition: outline 0s var(--ease-out-quint);
  transition: outline 0s var(--ease-out-quint);
}
.c-cta-btn.--red {
  --bg-color: var(--color-red-400);
  --bg-arrow-color: var(--color-red-500);
}
.c-cta-btn.--blue {
  --bg-color: var(--color-blue-400);
  --bg-arrow-color: var(--color-blue-500);
}
.c-cta-btn.--black {
  --bg-color: var(--color-black-700);
  --bg-arrow-color: var(--color-black-800);
}
.c-cta-btn.--white {
  --bg-color: var(--color-white);
  --bg-arrow-color: var(--color-black-800);
  color: var(--color-black-800);
  border: 1px solid var(--color-black-800);
  padding-block: max(0.4375rem, 5.6px);
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn.--white {
    padding-block: 0.1875rem;
  }
}
.c-cta-btn.--wide {
  width: 100%;
}
.c-cta-btn:has(.js-icon1) {
  padding-left: 0px;
}
.c-cta-btn.--bg-white-blue {
  --bg-color: var(--color-white);
  --bg-arrow-color: var(--color-blue-400);
  color: var(--color-black-800);
}
.c-cta-btn.--rotate {
  --arrow-deg: -45deg;
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn {
    min-width: 15rem;
    padding-inline: 1rem 0.25rem;
    padding-block: 0.25rem;
    gap: 1rem;
  }
  .c-cta-btn.--sp-8 {
    padding-inline: 1rem 0.5rem;
    padding-block: 0.5rem;
  }
}
.c-cta-btn:focus-visible, .c-cta-btn:focus {
  outline: 2px double var(--color-text);
}
.c-cta-btn.--reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  padding-inline: max(0.5rem, 6.4px) max(1.25rem, 16px);
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn.--reverse {
    padding-inline: 0.25rem 1rem;
  }
}
.c-cta-btn.--reverse .c-cta-btn__arrow {
  rotate: calc(var(--arrow-deg) + 180deg);
}

.c-cta-btn__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.c-cta-btn__icon-wrap {
  position: relative;
  overflow: hidden;
  width: max(4.375rem, 56px);
  height: auto;
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn__icon-wrap {
    width: 4rem;
  }
}

.c-cta-btn__icon-block {
  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;
}
.c-cta-btn__icon-block:has(.--icon2) {
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}

.c-cta-btn__icon-container {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  position: relative;
}
.c-cta-btn__icon-container svg,
.c-cta-btn__icon-container img {
  width: auto;
  height: auto;
}
.c-cta-btn__icon-container svg.--x,
.c-cta-btn__icon-container img.--x {
  width: max(1.5rem, 19.2px);
}
.c-cta-btn__icon-container svg.--youtube,
.c-cta-btn__icon-container img.--youtube {
  width: max(2.1875rem, 28px);
}
.c-cta-btn__icon-container svg.--facebook,
.c-cta-btn__icon-container img.--facebook {
  width: max(1.75rem, 22.4px);
}
.c-cta-btn__icon-container svg.--inst,
.c-cta-btn__icon-container img.--inst {
  width: max(1.75rem, 22.4px);
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn__icon-container svg.--x,
  .c-cta-btn__icon-container img.--x {
    width: 1.25rem;
  }
  .c-cta-btn__icon-container svg.--youtube,
  .c-cta-btn__icon-container img.--youtube {
    width: 1.875rem;
  }
  .c-cta-btn__icon-container svg.--facebook,
  .c-cta-btn__icon-container img.--facebook {
    width: 1.5625rem;
  }
  .c-cta-btn__icon-container svg.--inst,
  .c-cta-btn__icon-container img.--inst {
    width: 1.5625rem;
  }
}

.c-cta-btn__text-wrap {
  position: relative;
  overflow: hidden;
}

.c-cta-btn__text-block:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
}

.c-cta-btn__text {
  font-size: max(1rem, 12.8px);
  font-weight: 500;
  line-height: 1.1875;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn__text {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn__text {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.2666666667;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .c-cta-btn__text {
    font-size: 0.9375rem;
  }
}
.c-cta-btn__text.--small {
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.2666666667;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .c-cta-btn__text.--small {
    font-size: 0.9375rem;
  }
}
.c-cta-btn__text.--600 {
  font-weight: 600;
}

.c-cta-btn__arrow-wrap {
  width: max(3.375rem, 43.2px);
  height: max(3.375rem, 43.2px);
  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-color: var(--bg-arrow-color);
  position: relative;
  overflow: hidden;
  border-radius: 2px;
}

.c-cta-btn__arrow-block {
  position: relative;
  overflow: hidden;
}

.c-cta-btn__arrow {
  width: max(1.125rem, 14.4px);
  height: auto;
  rotate: var(--arrow-deg);
  position: relative;
}
.c-cta-btn__arrow:nth-child(1) {
  position: relative;
  left: 0;
  top: 0;
}
.c-cta-btn__arrow:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
}
.c-cta-btn__arrow.--small {
  width: 0.8125rem;
}
.c-cta-btn__arrow.--small:nth-child(1) {
  top: 1px;
}
.c-cta-btn__arrow.--small:nth-child(2) {
  top: 2px;
}

.c-header-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.c-header-group.--center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-header-group.--blue {
  color: var(--color-blue-400);
}

.c-header-group__sub-ttl {
  font-size: max(1rem, 12.8px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-blue-400);
}
@media screen and (max-width: 767.9px) {
  .c-header-group__sub-ttl {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .c-header-group__sub-ttl {
    font-size: max(0.875rem, 11.2px);
    font-weight: 600;
    line-height: 1.5;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .c-header-group__sub-ttl {
    font-size: 0.875rem;
  }
}
.c-header-group__sub-ttl.--red {
  color: var(--color-red-400);
}

.c-header-group__ttl {
  --font-size: 48;
  --font-weight: 500;
  --line-height: calc(var(--font-size) * 1.6);
  --letter-spacing: 0.96;
  font-family: "Noto Sans JP";
  font-size: max(var(--font-size) / 16 * 1rem, var(--font-size) * 0.8px);
  font-weight: var(--font-weight);
  line-height: calc(var(--line-height) / var(--font-size));
  letter-spacing: calc(var(--letter-spacing) / var(--font-size) * 1em);
}
@media screen and (max-width: 767.9px) {
  .c-header-group__ttl {
    --font-size: 28;
    --letter-spacing: 0.56;
  }
}
@media screen and (max-width: 767.9px) {
  .c-header-group__ttl {
    font-size: calc(var(--font-size) / 16 * 1rem);
  }
}
.c-header-group__ttl.--about {
  font-size: 60px;
  line-height: 72px;
  letter-spacing: 0;
}
@media screen and (max-width: 767.9px) {
  .c-header-group__ttl.--about {
    font-size: max(2.25rem, 28.8px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .c-header-group__ttl.--about {
    font-size: 2.25rem;
  }
}
.c-header-group__ttl.--pc-60 {
  --font-size: 60;
}
.c-header-group__ttl.--pc-48 {
  --font-size: 48;
}
.c-header-group__ttl.--pc-36 {
  --font-size: 36;
}
.c-header-group__ttl.--pc-28 {
  --font-size: 28;
}
.c-header-group__ttl.--pc-22 {
  --font-size: 22;
}
@media screen and (max-width: 767.9px) {
  .c-header-group__ttl.--sp-36 {
    --font-size: 36;
    --letter-spacing: 0.56;
  }
  .c-header-group__ttl.--sp-28 {
    --font-size: 28;
  }
  .c-header-group__ttl.--sp-30 {
    --font-size: 30;
    --letter-spacing: 0.56;
  }
  .c-header-group__ttl.--sp-22 {
    --font-size: 22;
    --letter-spacing: 0.44;
  }
  .c-header-group__ttl.--sp-18 {
    --font-size: 18;
    --letter-spacing: 0.36;
  }
}

.c-breadcrumb {
  font-size: max(0.875rem, 11.2px);
  font-weight: 400;
  line-height: 2.0571428571;
  letter-spacing: 0.0185714286em;
}
@media screen and (max-width: 767.9px) {
  .c-breadcrumb {
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .c-breadcrumb {
    font-size: max(0.625rem, 8px);
    font-weight: 400;
    line-height: 1.7;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .c-breadcrumb {
    font-size: 0.625rem;
  }
}

.c-breadcrumb__inner {
  padding-block: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  overflow: auto;
  gap: 0.5rem;
  width: 80%;
  margin-left: auto;
}
@media screen and (max-width: 767.9px) {
  .c-breadcrumb__inner {
    width: 50%;
    gap: 0.25rem 0.375rem;
  }
}

.c-breadcrumb__link {
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .c-breadcrumb__link:hover {
    opacity: 0.5;
  }
}

.c-breadcrumb__item {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  gap: 0.5rem;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
.c-breadcrumb__item::after {
  color: var(--color-black-500);
  content: "／";
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0em;
  font-family: var(--font-en);
  pointer-events: none;
  margin-inline: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .c-breadcrumb__item::after {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .c-breadcrumb__item::after {
    font-size: max(0.625rem, 8px);
    font-weight: 400;
    line-height: 1.7;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .c-breadcrumb__item::after {
    font-size: 0.625rem;
  }
}
.c-breadcrumb__item.--home {
  color: var(--color-black-800);
}

.c-breadcrumb__text {
  color: var(--color-black-500);
}

.c-breadcrumb__current {
  color: var(--color-black-500);
  text-align: right;
}

.c-archive-filter {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.75rem 2rem;
}

.c-archive-filter__link {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: var(--color-black-500);
  -webkit-transition: color 0.3s var(--ease-out-quint);
  transition: color 0.3s var(--ease-out-quint);
}
@media screen and (max-width: 767.9px) {
  .c-archive-filter__link {
    font-size: 0.8125rem;
  }
}
.c-archive-filter__link:hover {
  color: var(--color-red-400);
}
.c-archive-filter__link.is-active {
  color: var(--color-red-400);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  pointer-events: none;
}
.c-archive-filter__link.is-active::before {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  background-color: var(--color-red-400);
  border-radius: calc(infinity * 1px);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .c-archive-filter__link.is-active::before {
    width: 0.375rem;
    height: 0.375rem;
  }
}

.c-pagination {
  margin-top: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: max(0.25rem, 3.2px);
}
@media screen and (max-width: 767.9px) {
  .c-pagination {
    margin-top: 3rem;
  }
}

.page-numbers {
  width: max(2.25rem, 28.8px);
  height: max(2.25rem, 28.8px);
  background-color: var(--color-black-400);
  border-radius: 2px;
  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;
  font-size: max(0.8125rem, 10.4px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0em;
  color: var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .page-numbers {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .page-numbers {
    width: 2.25rem;
    height: 2.25rem;
  }
}
.page-numbers.current {
  background-color: var(--color-black-800);
  color: var(--color-white);
}
.page-numbers.dots {
  pointer-events: none;
  background-color: transparent;
  height: auto;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  translate: 0 max(0.5625rem, 7.2px);
}
@media screen and (max-width: 767.9px) {
  .page-numbers.dots {
    translate: 0 0.5625rem;
  }
}

.p-drawer__icon-line {
  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;
  gap: 4px;
  width: 44px;
  height: 44px;
  background-color: var(--color-black-800);
  border-radius: 2px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .p-drawer__icon-line {
    width: 2.75rem;
    height: 2.75rem;
    gap: 0.25rem;
  }
}

.p-drawer__icon-line-bar {
  width: 14px;
  height: 1px;
  background: var(--color-white);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition: translate 0.3s cubic-bezier(0.86, 0, 0.07, 1), rotate 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: translate 0.3s cubic-bezier(0.86, 0, 0.07, 1), rotate 0.3s cubic-bezier(0.86, 0, 0.07, 1);
}
@media screen and (max-width: 767.9px) {
  .p-drawer__icon-line-bar {
    width: 0.875rem;
  }
}

.p-drawer__bg {
  background-color: rgb(255, 255, 255);
  opacity: 0;
  visibility: hidden;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  -webkit-transition: opacity 0.3s cubic-bezier(0.86, 0, 0.07, 1), visibility 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: opacity 0.3s cubic-bezier(0.86, 0, 0.07, 1), visibility 0.3s cubic-bezier(0.86, 0, 0.07, 1);
}

.p-drawer__icon-line.js-show .p-drawer__icon-line-bar:nth-of-type(1) {
  rotate: 45deg;
  translate: 0 2.5px;
}
@media screen and (max-width: 767.9px) {
  .p-drawer__icon-line.js-show .p-drawer__icon-line-bar:nth-of-type(1) {
    translate: 0 0.15625rem;
  }
}
.p-drawer__icon-line.js-show .p-drawer__icon-line-bar:nth-of-type(2) {
  rotate: -45deg;
  translate: 0 -2.5px;
}
@media screen and (max-width: 767.9px) {
  .p-drawer__icon-line.js-show .p-drawer__icon-line-bar:nth-of-type(2) {
    translate: 0 -0.15625rem;
  }
}

.p-drawer {
  position: fixed;
  z-index: 101;
  overflow-y: auto;
  top: max(8.25rem, 105.6px);
  right: max(2.5rem, 32px);
  bottom: 1.25rem;
  max-width: max(20.9375rem, 268px);
  width: 100%;
  color: var(--color-white);
  -webkit-transform: scaleY(0);
          transform: scaleY(0);
  -webkit-transform-origin: top;
          transform-origin: top;
  -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: -webkit-transform 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: transform 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: transform 0.3s cubic-bezier(0.86, 0, 0.07, 1), -webkit-transform 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  max-height: calc(100dvh - max(6.75rem, 86.4px));
}
@media screen and (max-width: 767.9px) {
  .p-drawer {
    right: 1.25rem;
    top: 5.25rem;
    max-width: 20.9375rem;
    max-height: calc(100dvh - 5.25rem);
  }
}
@media screen and (max-width: 767.9px) and (width < 450px) {
  .p-drawer {
    right: initial;
    left: 50%;
    translate: -50%;
    max-width: calc(100% - 2.5rem);
  }
}

.p-drawer__icon--bar {
  -webkit-transition: all 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.3s cubic-bezier(0.86, 0, 0.07, 1);
}

.p-drawer {
  -webkit-transition: all 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: all 0.3s cubic-bezier(0.86, 0, 0.07, 1);
}
.p-drawer.js-show {
  opacity: 1;
  visibility: visible;
  -webkit-transform: scaleY(1);
          transform: scaleY(1);
}
.p-drawer.js-show + .p-drawer__bg {
  opacity: 1;
  visibility: visible;
}

.p-drawer__inner {
  margin-left: auto;
  background: var(--color-black-800);
  padding-block: 2.125rem 3rem;
  padding-inline: 1.25rem;
  border-radius: 0.25rem;
  overflow-y: auto;
}

.p-drawer__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-bottom: 40px;
}

.p-drawer__list-item-details.is-opened .p-drawer__list-plus::after {
  rotate: 90deg;
}

.p-drawer__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-block: max(0.875rem, 11.2px);
  cursor: pointer;
  -webkit-transition: opacity 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: opacity 0.3s cubic-bezier(0.86, 0, 0.07, 1);
}
@media screen and (max-width: 767.9px) {
  .p-drawer__link {
    padding-block: 0.875rem;
  }
}
.p-drawer__link:has(.p-drawer__link-arrow-wrap) {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
  gap: 0.5rem;
}
@media (any-hover: hover) {
  .p-drawer__link:hover {
    opacity: 0.5;
  }
}

.p-drawer__link-text {
  font-size: 15px;
  font-weight: 500;
  line-height: 24px;
}
@media screen and (max-width: 767.9px) {
  .p-drawer__link-text {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-drawer__link-text {
    font-size: 0.9375rem;
  }
}

.p-drawer__list-arrow {
  width: 0.5rem;
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-drawer__list-plus {
  width: 0.75rem;
  height: 0.75rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: relative;
}
.p-drawer__list-plus::before, .p-drawer__list-plus::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  background-color: #fff;
  -webkit-transition: rotate 0.2s cubic-bezier(0.86, 0, 0.07, 1);
  transition: rotate 0.2s cubic-bezier(0.86, 0, 0.07, 1);
}
.p-drawer__list-plus::before {
  width: 12px;
  height: 2px;
}
.p-drawer__list-plus::after {
  width: 2px;
  height: 12px;
}

.p-drawer__content {
  margin-top: 4rem;
}

.p-drawer__sub-menu-wrap {
  overflow: hidden;
}

.p-drawer__sub-menu-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.p-drawer__sub-menu-list-item:first-child {
  margin-top: max(0rem, 0px);
}
@media screen and (max-width: 767.9px) {
  .p-drawer__sub-menu-list-item:first-child {
    margin-top: 0rem;
  }
}

.p-drawer__sub-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  -webkit-transition: opacity 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  transition: opacity 0.3s cubic-bezier(0.86, 0, 0.07, 1);
  padding-block: 4px;
}
@media screen and (max-width: 767.9px) {
  .p-drawer__sub-link {
    padding-block: 0.5rem;
  }
}
@media (any-hover: hover) {
  .p-drawer__sub-link:hover {
    opacity: 0.5;
  }
}
.p-drawer__sub-link .p-drawer__link-arrow path {
  fill: var(--color-black-400);
}

.p-drawer__sub-list-text {
  -ms-flex-preferred-size: 18.75rem;
      flex-basis: 18.75rem;
  font-size: 13px;
  font-weight: 500;
  line-height: 20.8px;
  color: var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-drawer__sub-list-text {
    font-size: max(0.8125rem, 10.4px);
    font-weight: 400;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-drawer__sub-list-text {
    font-size: 0.8125rem;
  }
}

.p-drawer__sub-list-arrow {
  width: 6px;
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-drawer__link-wrap,
.p-drawer__link-arrow-wrap {
  overflow: hidden;
  position: relative;
}
.p-drawer__link-wrap > *:nth-child(2),
.p-drawer__link-arrow-wrap > *:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
}

.p-drawer__link-arrow {
  width: 14px;
  height: 14px;
}
.p-drawer__link-arrow path {
  fill: var(--color-white);
}
@media screen and (max-width: 767.9px) {
  .p-drawer__link-arrow {
    width: 0.875rem;
    height: 0.875rem;
  }
}

.p-drawer__btn {
  background-color: var(--color-white);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-inline: 1.25rem;
  padding-block: 1rem;
  gap: 0.5rem;
}

.p-drawer__btn-tel-wrap {
  color: var(--color-black-800);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.25rem;
}

.p-drawer__btn-tel-icon {
  width: 1rem;
  height: 1rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.p-drawer__btn-tel-number {
  font-size: max(1rem, 12.8px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .p-drawer__btn-tel-number {
    font-size: 1rem;
  }
}

.p-drawer__btn-tel-hours {
  font-size: max(0.625rem, 8px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: 0em;
  color: var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .p-drawer__btn-tel-hours {
    font-size: 0.625rem;
  }
}

.p-fix-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
}

.p-fix-bg__movie-clip {
  height: 100svh;
  overflow-x: clip;
  position: relative;
  border: 0;
}
.p-fix-bg__movie-clip iframe {
  aspect-ratio: 16/9;
  min-height: 100%;
  min-width: 100%;
  border: 0;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .p-fix-bg__movie-clip iframe {
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

.p-fix-bg__img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.p-fv {
  height: 100svh;
  max-height: 950px;
  min-height: 600px;
}
@media screen and (max-width: 767.9px) {
  .p-fv {
    min-height: initial;
  }
}

.p-fv__inner {
  max-width: 1440px;
  height: 100%;
  margin: 0 auto;
  width: 100%;
  padding-inline: max(3.625rem, 46.4px);
  padding-bottom: max(5rem, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
@media screen and (max-width: 767.9px) {
  .p-fv__inner {
    padding-inline: 1.125rem;
    padding-bottom: 3rem;
  }
}

.p-fv__top-title {
  font-size: max(5rem, 64px);
  font-weight: 500;
  line-height: 1.2875;
  letter-spacing: 0.096em;
}
@media screen and (max-width: 767.9px) {
  .p-fv__top-title {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-fv__top-title {
    font-size: max(2.625rem, 33.6px);
    font-weight: 500;
    line-height: 1.5952380952;
    letter-spacing: 0.0476190476em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-fv__top-title {
    font-size: 2.625rem;
  }
}
.p-fv__top-title .--red {
  color: var(--color-red-400);
}
.p-fv__top-title .--big {
  font-size: max(5rem, 64px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0em;
  font-family: "Noto Sans JP";
}
@media screen and (max-width: 767.9px) {
  .p-fv__top-title .--big {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-fv__top-title .--big {
    font-size: max(2.625rem, 33.6px);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-fv__top-title .--big {
    font-size: 2.625rem;
  }
}
.p-fv__top-title .--big2 {
  font-size: max(5rem, 64px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.096em;
}
@media screen and (max-width: 767.9px) {
  .p-fv__top-title .--big2 {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-fv__top-title .--big2 {
    font-size: max(2.625rem, 33.6px);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.0476190476em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-fv__top-title .--big2 {
    font-size: 2.625rem;
  }
}

.p-fv__logo {
  width: max(19.125rem, 244.8px);
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  margin-top: 2.0625rem;
  margin-left: max(0.625rem, 8px);
}
@media screen and (max-width: 767.9px) {
  .p-fv__logo {
    width: 11.75rem;
    margin-top: 1.375rem;
    margin-left: 0.125rem;
  }
}

.p-fv__bottom {
  margin-top: max(2rem, 25.6px);
  margin-left: max(2.5625rem, 32.8px);
}
@media screen and (max-width: 767.9px) {
  .p-fv__bottom {
    margin-top: 1.5rem;
    margin-left: 0rem;
  }
}

.p-fv__bottom-sentence {
  font-size: max(0.875rem, 11.2px);
  font-weight: 500;
  line-height: 1.2142857143;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .p-fv__bottom-sentence {
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-fv__bottom-sentence {
    font-size: max(0.875rem, 11.2px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-fv__bottom-sentence {
    font-size: 0.875rem;
  }
}

.p-fv__btn-wrap {
  margin-top: max(1rem, 12.8px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: max(1rem, 12.8px);
}
@media screen and (max-width: 767.9px) {
  .p-fv__btn-wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 0.5rem;
    gap: 0.75rem;
  }
}

.p-about {
  padding-top: 8.5rem;
  padding-bottom: 12.75rem;
}
@media screen and (max-width: 767.9px) {
  .p-about {
    padding-top: 7.1875rem;
    padding-bottom: 7rem;
  }
}

.p-about__container {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
}

.p-about__header-group {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}

.p-about__content {
  margin-top: 48px;
}
@media screen and (max-width: 767.9px) {
  .p-about__content {
    margin-top: 2rem;
  }
}

.p-about__sentence-wrap {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}

.p-about__sentence {
  font-size: 16px;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 500;
  line-height: 200%; /* 32px */
  letter-spacing: 0.64px;
}
@media screen and (max-width: 767.9px) {
  .p-about__sentence {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0.04em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-about__sentence {
    font-size: 0.9375rem;
  }
}
.p-about__sentence:not(:first-child) {
  margin-top: 1lh;
}

.p-about__graph-wrap {
  margin-top: 64px;
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 767.9px) {
  .p-about__graph-wrap {
    margin-top: 5rem;
  }
}

.p-about__graph > * {
  transform-box: fill-box;
  -webkit-transform-origin: center;
          transform-origin: center;
  scale: 0;
  -webkit-transition: scale 0.3s cubic-bezier(0.19, 1, 0.22, 1.22);
  transition: scale 0.3s cubic-bezier(0.19, 1, 0.22, 1.22);
}
.p-about__graph > *.js-active {
  scale: 1;
}

.p-about__graph-circle1 {
  -webkit-transition: scale 0.35s cubic-bezier(0.1, 0.7, 0.22, 1.8);
  transition: scale 0.35s cubic-bezier(0.1, 0.7, 0.22, 1.8);
}

.p-about__graph-circle2 {
  -webkit-transition: scale 1.4s cubic-bezier(0.19, 1, 0.22, 1);
  transition: scale 1.4s cubic-bezier(0.19, 1, 0.22, 1);
}

.p-about__graph-circle3 {
  -webkit-transition: scale 1.8s cubic-bezier(0.19, 1, 0.22, 1);
  transition: scale 1.8s cubic-bezier(0.19, 1, 0.22, 1);
}

.p-about__graph-circle4 {
  -webkit-transition: scale 2.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: scale 2.5s cubic-bezier(0.19, 1, 0.22, 1);
}

.p-about__graph-circle5 {
  -webkit-transition: scale 3s cubic-bezier(0.19, 1, 0.22, 1);
  transition: scale 3s cubic-bezier(0.19, 1, 0.22, 1);
}

.p-about__graph-circle6 {
  -webkit-transition: scale 3s cubic-bezier(0.19, 1, 0.22, 1);
  transition: scale 3s cubic-bezier(0.19, 1, 0.22, 1);
}

.p-about__graph-circle1--text2 {
  position: absolute;
  width: min(16.25vw, 91px);
  top: 52%;
  left: 50%;
  translate: -50% -50%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  transform-box: fill-box;
  -webkit-transform-origin: center;
          transform-origin: center;
  scale: 0;
  -webkit-transition: scale 0.3s cubic-bezier(0.19, 1, 0.22, 1.22);
  transition: scale 0.3s cubic-bezier(0.19, 1, 0.22, 1.22);
}
.p-about__graph-circle1--text2 path {
  transform-box: fill-box;
  -webkit-transform-origin: center;
          transform-origin: center;
  scale: 0;
  -webkit-transition: scale 0.3s cubic-bezier(0.19, 1, 0.22, 1);
  transition: scale 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}
.p-about__graph-circle1--text2.js-active {
  scale: 1;
}

.p-about__graph-text-circle {
  -webkit-transition: scale 0.35s cubic-bezier(0.1, 0.7, 0.22, 1.8);
  transition: scale 0.35s cubic-bezier(0.1, 0.7, 0.22, 1.8);
}

.p-about__graph-circle1--text2.js-active path {
  scale: 1;
}

.p-about__btn {
  margin-top: 48px;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .p-about__btn {
    margin-top: 3.5rem;
  }
}

.p-service {
  padding-top: 9rem;
  padding-bottom: 9rem;
  background-color: var(--color-white);
  background-image: linear-gradient(to right, #eeeeee 1px, transparent 1px), linear-gradient(to bottom, #eeeeee 1px, transparent 1px);
  background-size: 28px 28px;
  background-position: 0 -14px;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .p-service {
    padding-top: 4rem;
    padding-bottom: 5rem;
  }
}

@media (min-width: 768px) {
  .p-service__inner {
    position: relative;
    max-width: 1420px;
    padding-inline: 0;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service__inner {
    display: block;
  }
}

.p-service__header-group.--top {
  opacity: 0;
  visibility: hidden;
}
@media screen and (max-width: 767.9px) {
  .p-service__header-group.--top {
    opacity: 1;
    visibility: visible;
  }
}

.p-service__content {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  margin-left: auto;
  max-width: 1360px;
}
@media screen and (max-width: 767.9px) {
  .p-service__content {
    margin-top: 2.5rem;
  }
}

.p-service__item-wrap {
  -webkit-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
  position: absolute;
  inset: 0; /* = top/right/bottom/left:0; 画面いっぱいに広げる */
  display: block; /* ← flexをやめる */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; /* 縦中央 */
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center; /* 横中央 */
  /* アニメの品質UP */
  will-change: opacity;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
@media screen and (max-width: 767.9px) {
  .p-service__item-wrap {
    position: initial;
  }
  .p-service__item-wrap:not(:first-child) {
    margin-top: 5rem;
  }
}

.p-service__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-right: calc(50% - 50vw);
  gap: 2.5rem;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%); /* ここを基準に固定 */
  width: 100%;
  max-width: 1360px;
  padding-left: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-service__item {
    -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;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    margin-right: initial;
    padding-left: 0;
    position: relative;
    left: initial;
    top: initial;
    -webkit-transform: initial;
            transform: initial;
    gap: 2rem;
  }
}

.p-service__item-body {
  padding-bottom: 4rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: max(35.625rem, 456px);
  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) {
  .p-service__item-body {
    padding-bottom: 0;
    width: 100%;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service__item-body .p-service__header-group {
    display: none;
  }
}

.p-service__item-body,
.p-service__item-img-wrap {
  max-width: 680px;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
}

.p-service__item-box {
  margin-top: auto;
}
@media screen and (max-width: 767.9px) {
  .p-service__item-box {
    margin-top: initial;
  }
}

.p-service__item-title {
  font-size: max(1.875rem, 24px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  margin-top: auto;
}
@media screen and (max-width: 767.9px) {
  .p-service__item-title {
    font-size: 1.875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service__item-title {
    font-size: max(1.375rem, 17.6px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
    margin-top: initial;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-service__item-title {
    font-size: 1.375rem;
  }
}

.p-service__item-description {
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0em;
  margin-top: 2rem;
}
@media screen and (max-width: 767.9px) {
  .p-service__item-description {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service__item-description {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0em;
    margin-top: 1rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-service__item-description {
    font-size: 0.9375rem;
  }
}

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

.p-service__item-img-wrap {
  border-radius: 0.375rem;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .p-service__item-img-wrap {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    width: 100%;
    padding-right: 0;
  }
}

.p-service__item-img {
  width: 100%;
  height: 90svh;
  max-height: 760px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
  -webkit-transform-origin: center center;
          transform-origin: center center;
}
@media screen and (max-width: 767.9px) {
  .p-service__item-img {
    max-height: initial;
    height: auto;
    max-height: 400px;
  }
}

.p-promise {
  background-color: var(--color-black-200);
  padding-top: 9rem;
  padding-bottom: 6rem;
}
@media screen and (max-width: 767.9px) {
  .p-promise {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
}

.p-promise__content {
  margin-top: 2.3125rem;
}
@media screen and (max-width: 767.9px) {
  .p-promise__content {
    margin-top: 2rem;
  }
}

.p-promise__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-promise__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-promise__text {
  font-size: max(1.5rem, 19.2px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.04em;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  min-width: max(29.6875rem, 380px);
}
@media screen and (max-width: 767.9px) {
  .p-promise__text {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-promise__text {
    min-width: 100%;
    font-size: max(1.25rem, 16px);
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.04em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-promise__text {
    font-size: 1.25rem;
  }
}

.p-promise__sentence {
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
}
@media screen and (max-width: 767.9px) {
  .p-promise__sentence {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-promise__sentence {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-promise__sentence {
    font-size: 0.9375rem;
  }
}

.p-promise__btn {
  margin-top: 2.5rem;
  margin-left: auto;
}
@media screen and (max-width: 767.9px) {
  .p-promise__btn {
    margin-top: 2rem;
    margin-left: initial;
  }
}

.p-feature {
  background-color: var(--color-black-200);
  min-height: 100vh;
  overflow: hidden;
}

.p-feature__wrap {
  position: relative;
}

.p-feature__box {
  will-change: transform;
  padding-top: 6.5rem;
  padding-bottom: 7rem;
  min-height: 100vh;
  background-color: #eeeeee;
  background-image: linear-gradient(to right, #eaeaea 2px, transparent 2px), linear-gradient(to bottom, #eaeaea 2px, transparent 2px);
  background-size: 50px 50px;
  background-position: 0 -40px;
  display: grid;
  place-content: center;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .p-feature__box {
    padding-top: 0rem;
    padding-bottom: 0rem;
  }
}

.p-feature__img {
  width: 67.375rem;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
@media screen and (max-width: 767.9px) {
  .p-feature__img {
    width: 100%;
    max-width: 390px;
    padding-inline: 1.25rem;
    translate: 0 -1.125rem;
  }
}

.p-member {
  margin-top: 20rem;
  padding-top: 7.5rem;
  padding-bottom: 6.5rem;
  background-color: var(--color-white);
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .p-member {
    margin-top: 15rem;
    padding-top: 5rem;
    padding-bottom: 4rem;
  }
}

.p-member__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 2rem;
}
@media screen and (max-width: 767.9px) {
  .p-member__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-member__sentence {
  width: max(38.75rem, 496px);
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
}
@media screen and (max-width: 767.9px) {
  .p-member__sentence {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member__sentence {
    width: 100%;
  }
}

.p-member__content {
  margin-top: 4rem;
}
@media screen and (max-width: 767.9px) {
  .p-member__content {
    margin-top: 3rem;
  }
}

.p-member__gallery {
  margin-inline: calc(50% - 50vw);
  width: 100vw;
  position: relative;
}

.p-member__splide {
  position: relative;
}

.p-member__slide:nth-child(3n-2) {
  padding-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .p-member__slide:nth-child(3n-2) {
    padding-top: 1.625rem;
  }
}
.p-member__slide:nth-child(3n-1) {
  padding-top: 5.375rem;
}
@media screen and (max-width: 767.9px) {
  .p-member__slide:nth-child(3n-1) {
    padding-top: 3.9375rem;
  }
}

.p-member__splide-slide-img {
  width: 17.5rem;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 0.375rem;
}
@media screen and (max-width: 767.9px) {
  .p-member__splide-slide-img {
    width: 10.5rem;
  }
}

.p-member__fix-text {
  font-size: max(12.5rem, 160px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0em;
  color: var(--color-blue-100);
  white-space: nowrap;
  position: absolute;
  left: 50%;
  translate: -50%;
  bottom: min(-1.625rem, -20.8px);
  mix-blend-mode: multiply;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .p-member__fix-text {
    font-size: 12.5rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member__fix-text {
    font-size: max(9rem, 115.2px);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0em;
    bottom: -1.25rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-member__fix-text {
    font-size: 9rem;
  }
}

.p-member__btn {
  margin-inline: auto;
  margin-top: 7.125rem;
}
@media screen and (max-width: 767.9px) {
  .p-member__btn {
    margin-top: 4rem;
  }
}

.p-news {
  padding-top: 6rem;
  padding-bottom: 6rem;
  background-color: var(--color-white);
  position: relative;
}
.p-news::before {
  content: "";
  position: absolute;
  width: calc(100% - 2.5rem);
  height: 1px;
  top: 0;
  left: 50%;
  translate: -50%;
  background-color: var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-news::before {
    width: calc(100% - 2.5rem);
  }
}
@media screen and (max-width: 767.9px) {
  .p-news {
    padding-top: 4rem;
    padding-bottom: 6.5rem;
  }
}

.p-news__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 2rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .p-news__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 2rem;
  }
}

.p-news__header-group {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: sticky;
  top: calc(5rem + var(--header-height) / 16 * 1rem);
  will-change: top;
  -webkit-transition: top 0.28s var(--ease-out-quint);
  transition: top 0.28s var(--ease-out-quint);
  height: 100%;
}
@media screen and (max-width: 767.9px) {
  .p-news__header-group {
    position: initial;
    top: initial;
  }
}

.p-news__body {
  max-width: max(50rem, 640px);
  width: 100%;
}

.p-news__articles {
  display: grid;
  grid-template-columns: max(6.25rem, 80px) auto 1fr;
}
@media screen and (max-width: 767.9px) {
  .p-news__articles {
    display: block;
    grid-template-columns: initial;
    grid-template-rows: initial;
  }
}

.p-news__article {
  display: block grid;
  grid-template-columns: subgrid;
  grid-column: 1/-1;
  -webkit-transition: background-color 0.3s var(--ease-out-quint);
  transition: background-color 0.3s var(--ease-out-quint);
  border-top: 1px solid var(--color-black-300);
}
.p-news__article:last-child {
  border-bottom: 1px solid var(--color-black-300);
}
@media (any-hover: hover) {
  .p-news__article:hover {
    background-color: var(--color-black-200);
  }
}
@media screen and (max-width: 767.9px) {
  .p-news__article {
    display: block;
  }
}

.p-news__article-link {
  display: inherit;
  grid-template-columns: inherit;
  grid-column: inherit;
  -webkit-column-gap: inherit;
     -moz-column-gap: inherit;
          column-gap: inherit;
  row-gap: inherit;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  padding-block: max(2rem, 25.6px);
  padding-inline: max(1.25rem, 16px);
}
@media screen and (max-width: 767.9px) {
  .p-news__article-link {
    padding-inline: 1.25rem;
    -webkit-column-gap: 0.5rem;
       -moz-column-gap: 0.5rem;
            column-gap: 0.5rem;
    row-gap: 0rem;
    padding-block: 2rem;
    display: grid;
    grid-template-columns: -webkit-max-content 1fr;
    grid-template-columns: max-content 1fr;
    grid-template-rows: initial;
  }
}

.p-news__article-date {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 2.2692307692;
  letter-spacing: 0em;
  color: var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .p-news__article-date {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-news__article-date {
    font-size: max(0.8125rem, 10.4px);
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news__article-date {
    font-size: 0.8125rem;
  }
}

.p-news__article-info {
  display: contents;
}
@media screen and (max-width: 767.9px) {
  .p-news__article-info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0.5rem;
  }
}

.p-news__article-label-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  margin-right: 1.5rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.p-news__article-label {
  font-size: max(0.6875rem, 8.8px);
  font-weight: 500;
  line-height: 1.1818181818;
  letter-spacing: 0em;
  padding-inline: max(0.625rem, 8px);
  padding-block: 0.3125rem;
  color: var(--color-blue-400);
  background-color: var(--color-blue-100);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  border-radius: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-news__article-label {
    font-size: 0.6875rem;
  }
}

.p-news__article-title {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  color: var(--color-black-800);
}
@media screen and (max-width: 767.9px) {
  .p-news__article-title {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-news__article-title {
    grid-column: 1/-1;
    margin-top: 1.5rem;
  }
}

.p-news__btn {
  margin-top: 4rem;
  margin-left: auto;
}
@media screen and (max-width: 767.9px) {
  .p-news__btn {
    margin-left: initial;
    margin-top: 2.5rem;
  }
}

.p-cta-contact {
  padding-top: 4rem;
  padding-bottom: 4rem;
  background-color: #f4f4f4;
  background-image: linear-gradient(to right, #ededed 1px, transparent 1px), linear-gradient(to bottom, #ededed 1px, transparent 1px);
  background-size: 28px 28px;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact {
    padding-bottom: 5rem;
  }
}

.p-cta-contact__content {
  display: grid;
  grid-template-columns: auto auto;
  grid-template-rows: auto auto;
  gap: 0.625rem;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__content {
    grid-template-columns: auto;
    grid-template-rows: repeat(auto);
  }
}

.p-cta-contact__btn {
  --bg-color: var(--color-white);
  --bg-btn-color: var(--color-black-800);
  --btn-size-block: 80;
  --btn-arrow: 23;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: var(--bg-color);
  padding-inline: 5rem;
  padding-block: 4rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn {
    padding-block: 1.75rem;
    padding-inline: 1.25rem;
    --btn-arrow: 16;
  }
}
.p-cta-contact__btn.--2col {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto auto;
}
.p-cta-contact__btn.--2col .p-cta-contact__btn-arrow-wrap {
  grid-row: 1/-1;
  grid-column: 2;
  align-self: center;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn.--2col .p-cta-contact__btn-arrow-wrap {
    grid-row: 1;
    grid-column: 2;
  }
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn.--2col {
    padding-block: 3rem;
    --btn-size-block: 54;
  }
  .p-cta-contact__btn.--2col .p-cta-contact__btn-sentence,
  .p-cta-contact__btn.--2col .p-cta-contact__btn-catch {
    grid-column: 1/-1;
  }
}
.p-cta-contact__btn.--blue {
  --bg-color: var(--color-blue-100);
  --bg-btn-color: var(--color-blue-400);
  --btn-size-block: 68;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn.--blue {
    --btn-size-block: 54;
  }
}
.p-cta-contact__btn.--red {
  --bg-color: var(--color-red-100);
  --bg-btn-color: var(--color-red-400);
  --btn-size-block: 68;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn.--red {
    --btn-size-block: 54;
  }
}

.p-cta-contact__btn-catch {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  color: var(--color-black-800);
  margin-top: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn-catch {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn-catch {
    font-size: max(1.25rem, 16px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-cta-contact__btn-catch {
    font-size: 1.25rem;
  }
}

.p-cta-contact__btn-sentence {
  margin-top: 1rem;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn-sentence {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn-sentence {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-cta-contact__btn-sentence {
    font-size: 0.9375rem;
  }
}

.p-cta-contact__btn-arrow-wrap {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: relative;
  overflow: hidden;
  width: calc(var(--btn-size-block) / 16 * 1rem);
  height: calc(var(--btn-size-block) / 16 * 1rem);
  background-color: var(--bg-btn-color);
  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;
  border-radius: 2px;
}

.p-cta-contact__arrow-block {
  position: relative;
  overflow: hidden;
}

.p-cta-contact__btn-arrow {
  overflow: hidden;
  position: relative;
}
.p-cta-contact__btn-arrow:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
}

.p-cta-contact__arrow {
  width: calc(var(--btn-arrow) / 16 * 1rem);
  height: auto;
}

.p-cta-contact__btn-ttl {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn-ttl {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__btn-ttl {
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-cta-contact__btn-ttl {
    font-size: 1.125rem;
  }
}

.p-cta-contact__cursor-text {
  width: max(9.375rem, 120px);
  height: max(9.375rem, 120px);
  background-color: rgba(255, 255, 255, 0.7);
  border-radius: 100%;
  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: fixed;
  left: 0;
  top: 0;
  z-index: 1;
  font-size: 18px;
  font-weight: bold;
  text-decoration: none;
  pointer-events: auto;
  opacity: 0;
  letter-spacing: 2px;
  color: var(--color-black-800);
  visibility: hidden; /* 最初は非表示 */
  -webkit-transition: opacity 0.2s ease-out, visibility 0.2s ease-out;
  transition: opacity 0.2s ease-out, visibility 0.2s ease-out;
  pointer-events: none;
  border: max(1.25rem, 16px) solid #e60013;
}
.p-cta-contact__cursor-text::before {
  content: ""; /* 擬似要素には content が必要 */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.329); /* 好きな背景色を設定 */
  -webkit-filter: blur(20px);
          filter: blur(20px); /* ここでぼかしを適用 */
  z-index: -1; /* 背景が要素の下に来るようにする */
  border-radius: calc(infinity * 1px);
}
@media screen and (max-width: 767.9px) {
  .p-cta-contact__cursor-text {
    width: 6.25rem;
    height: 6.25rem;
    border: 1.25rem solid #e60013;
    font-size: max(1rem, 12.8px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.0975em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-cta-contact__cursor-text {
    font-size: 1rem;
  }
}

.p-common-recruit {
  min-height: 100vh;
  overflow: hidden;
}

.p-common-recruit.is-front {
  background-color: #fff;
}

.p-common-recruit__wrap {
  position: relative;
}

.p-common-recruit__box {
  will-change: transform;
  padding-top: 6.5rem;
  padding-bottom: 7rem;
  height: 100vh;
  background-color: var(--color-blue-100);
  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;
  overflow: hidden;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__box {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

.p-common-recruit__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  z-index: -1;
}

.p-common-recruit__img {
  --width-size: 200;
  width: calc(var(--width-size) / 16 * 1rem);
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  position: absolute;
  border-radius: 0.25rem;
  z-index: -1;
}
.p-common-recruit__img.--1 {
  top: calc(50% - 21.3125rem);
  left: 10rem;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__img.--1 {
    --width-size: 108;
    top: -9rem;
    left: 0rem;
  }
}
.p-common-recruit__img.--2 {
  top: calc(50% - 0rem);
  left: 2.5rem;
}
.p-common-recruit__img.--3 {
  --width-size: 160;
  top: calc(50% + 13.53rem);
  left: 15rem;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__img.--3 {
    --width-size: 111;
    top: initial;
    bottom: -9.1875rem;
    left: 0rem;
  }
}
.p-common-recruit__img.--4 {
  top: 4.375rem;
  right: 7.6875rem;
  top: calc(50% - 16.9375rem);
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__img.--4 {
    --width-size: 130;
    top: -5.5rem;
    right: -0.875rem;
  }
}
.p-common-recruit__img.--5 {
  top: calc(50% - 4.3rem);
  right: 2.5rem;
}
.p-common-recruit__img.--6 {
  top: calc(50% + 14rem);
  right: 12.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__img.--6 {
    --width-size: 150;
    top: initial;
    bottom: -6.125rem;
    right: -0.875rem;
  }
}

.p-common-recruit__content {
  position: relative;
  max-width: 1440px;
  margin: 0 auto;
  width: 100%;
  max-height: max(42.125rem, 539.2px);
  height: 100%;
  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) {
  .p-common-recruit__content {
    max-height: 50.25rem;
    max-width: 400px;
    padding-inline: 1.25rem;
  }
}

.p-common-recruit__body {
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__body {
    position: relative;
    max-width: 281px;
  }
}

.p-common-recruit__catch {
  margin-top: 2.5rem;
  font-size: max(1.875rem, 24px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.05em;
  text-align: center;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__catch {
    font-size: 1.875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__catch {
    font-size: max(1.375rem, 17.6px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-common-recruit__catch {
    font-size: 1.375rem;
  }
}

.p-common-recruit__sentence {
  margin-top: 1rem;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__sentence {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__sentence {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
    text-align: center;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-common-recruit__sentence {
    font-size: 0.9375rem;
  }
}

.p-common-recruit__btn {
  margin-top: 3.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .p-common-recruit__btn {
    margin-top: 2.5rem;
  }
}

.p-side-index {
  position: absolute;
  top: 0px;
  left: 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin-top: 0;
  padding-inline: 2.5rem;
  padding-block: 2rem;
  z-index: 3;
  background-color: var(--color-black-200);
  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.75rem;
  border-radius: 4px;
  -webkit-transition: opacity 0.3s ease-in-out, translate 0.3s ease-in-out !important;
  transition: opacity 0.3s ease-in-out, translate 0.3s ease-in-out !important;
}
.p-side-index.is-pin {
  translate: 0 calc(var(--header-height) / 16 * 1rem) !important;
}
@media (768px <= width < 830px) {
  .p-side-index {
    left: calc(-30px + (100vw - 768px) * 0.484);
    padding-inline: 2rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-side-index {
    position: initial;
    top: initial;
    left: initial;
    width: 100%;
    max-width: 295px;
    margin-inline: auto;
    padding: 1.25rem;
    gap: 1rem;
  }
}

.p-side-index__item {
  --label-color: var(--color-black-500);
  font-size: max(0.8125rem, 10.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  color: var(--label-color);
  -webkit-transition: color 0.3s var(--ease-out-quint);
  transition: color 0.3s var(--ease-out-quint);
  max-width: max(7.5rem, 96px);
}
@media screen and (max-width: 767.9px) {
  .p-side-index__item {
    font-size: 0.8125rem;
  }
}
@media (any-hover: hover) {
  .p-side-index__item:hover {
    --label-color: var(--color-black-800);
  }
}
@media (min-width: 768px) {
  .p-side-index__item::before {
    content: "";
    background-color: transparent;
    width: max(0.375rem, 4.8px);
    height: max(0.375rem, 4.8px);
    border-radius: calc(infinity * 1px);
    display: block;
    -webkit-transition: background-color 0.3s var(--ease-out-quint);
    transition: background-color 0.3s var(--ease-out-quint);
    -ms-flex-negative: 0;
        flex-shrink: 0;
    translate: 0 max(0.46875rem, 6px);
  }
}
@media screen and (max-width: 767.9px) {
  .p-side-index__item {
    --label-color: var(--color-black-800);
    max-width: initial;
    -webkit-transition: opacity 0.3s var(--ease-out-quint);
    transition: opacity 0.3s var(--ease-out-quint);
  }
}
@media screen and (max-width: 767.9px) and (any-hover: hover) {
  .p-side-index__item:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767.9px) {
  .p-side-index__item::after {
    content: "";
    width: 0.75rem;
    height: 1.0625rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background-image: url("../img/icon_arrow-black.svg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    margin-left: auto;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    translate: 0 0.125rem;
  }
}

@media (min-width: 768px) {
  .p-side-index__item.is-current {
    --label-color: var(--color-black-800);
  }
  .p-side-index__item.is-current::before {
    background-color: var(--color-red-400);
  }
}
.p-under-company-outline__content {
  margin-top: 2rem;
}

.p-under-company-outline__dl-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  padding-block: 2rem;
  border-top: 1px solid var(--color-black-400);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0.5rem;
}
.p-under-company-outline__dl-item:last-child {
  border-bottom: 1px solid var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-item {
    padding-block: 1.25rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.5rem;
  }
}

.p-under-company-outline__dl-ttl {
  -ms-flex-preferred-size: max(12.5rem, 160px);
      flex-basis: max(12.5rem, 160px);
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: max(1rem, 12.8px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  min-height: 2rem;
  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) {
  .p-under-company-outline__dl-ttl {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-ttl {
    -ms-flex-preferred-size: initial;
        flex-basis: initial;
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
    min-height: initial;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-company-outline__dl-ttl {
    font-size: 0.9375rem;
  }
}

.p-under-company-outline__dl-content {
  max-width: 696px;
  width: 100%;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  -ms-flex-item-align: center;
      align-self: center;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content {
    -ms-flex-preferred-size: initial;
        flex-basis: initial;
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-company-outline__dl-content {
    font-size: 0.9375rem;
  }
}
.p-under-company-outline__dl-content .--line-150 {
  line-height: 150% !important;
}
.p-under-company-outline__dl-content div:has(.--2column) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content div:has(.--2column) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-under-company-outline__dl-content div:has(.--item) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content div:has(.--item) {
    gap: 1.75rem;
  }
}
.p-under-company-outline__dl-content .--2column {
  -ms-flex-preferred-size: 21rem;
      flex-basis: 21rem;
  -ms-flex-negative: 1;
      flex-shrink: 1;
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content .--2column {
    -ms-flex-preferred-size: initial;
        flex-basis: initial;
  }
}
.p-under-company-outline__dl-content .--item {
  font-size: max(0.875rem, 11.2px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  color: var(--color-black-600);
  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) {
  .p-under-company-outline__dl-content .--item {
    font-size: 0.875rem;
  }
}
.p-under-company-outline__dl-content .--item b {
  font-size: max(1rem, 12.8px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: var(--color-black-800);
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content .--item b {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-company-outline__dl-content .--item b {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-company-outline__dl-content .--item b {
    font-size: 0.9375rem;
  }
}

.p-under-company-access {
  margin-top: 6.0625rem;
  margin-bottom: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access {
    margin-top: 4rem;
    margin-bottom: 5rem;
  }
}

.p-under-company-access__content {
  margin-top: 2rem;
}

.p-under-company-access__item-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.5rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-wrap {
    gap: 2.5rem 1rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.p-under-company-access__item {
  max-width: calc(50% - 1.25rem);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  height: auto;
  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) {
  .p-under-company-access__item {
    min-width: 17.5rem;
    max-width: 400px;
  }
}

.p-under-company-access__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 18.125rem;
  border-radius: 4px;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-img {
    height: 13.75rem;
  }
}

.p-under-company-access__item-center {
  margin-top: 1.5rem;
  margin-bottom: 1.625rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-center {
    margin-top: 1rem;
    margin-bottom: 1.125rem;
  }
}

.p-under-company-access__item-ttl {
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-ttl {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-ttl {
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-company-access__item-ttl {
    font-size: 1.125rem;
  }
}

.p-under-company-access__item-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  margin-top: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-text {
    font-size: 0.875rem;
  }
}
.p-under-company-access__item-map {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: var(--color-red-400);
  gap: 0.25rem;
  margin-top: 0.3125rem;
}

.p-under-company-access__item-map-text-box {
  position: relative;
  overflow: hidden;
}

.p-under-company-access__item-map-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-map-text {
    font-size: 0.875rem;
  }
}

.p-under-company-access__item-map-icon {
  width: 0.875rem;
  height: auto;
}

.p-under-company-access__item-bottom {
  margin-top: auto;
  border-radius: 4px;
  background-color: var(--color-black-200);
  padding-block: 1.25rem;
  padding-inline: 1.5rem;
  color: var(--color-black-600);
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-bottom {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-company-access__item-bottom {
    padding: 1.25rem;
  }
}

.p-under-company-header-gallery {
  height: 31.25rem;
  position: relative;
  margin-top: -2.4375rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-header-gallery {
    height: auto;
    margin-top: 2rem;
  }
}

.p-under-company-header-gallery__item {
  position: absolute;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint), -webkit-transform 0.3s var(--ease-out-quint);
}
.p-under-company-header-gallery__item.--1 {
  top: 6.0625rem;
  left: -5.125rem;
}
.p-under-company-header-gallery__item.--2 {
  right: 20rem;
  top: 0;
}
.p-under-company-header-gallery__item.--3 {
  bottom: 0;
  right: -5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-header-gallery__item {
    position: static;
  }
  .p-under-company-header-gallery__item.--3 {
    margin-top: 1rem;
    margin-left: auto;
  }
}

.p-under-company-header-gallery__img {
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 0.25rem;
}
.p-under-company-header-gallery__img.--1 {
  width: 37.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-header-gallery__img.--1 {
    width: 17.25rem;
  }
}
.p-under-company-header-gallery__img.--2 {
  width: 12.5rem;
}
.p-under-company-header-gallery__img.--3 {
  width: 20rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-company-header-gallery__img.--3 {
    width: 9.1875rem;
  }
}

.p-under-fv__header-group {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-fv__header-group {
    margin-top: 1rem;
  }
}

.p-card-items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(max(17.5rem, 224px), 1fr));
  gap: 4rem 2.5rem;
  padding-bottom: 9rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-items {
    gap: 2rem 1rem;
    grid-template-columns: repeat(auto-fit, minmax(9.9375rem, 1fr));
    padding-bottom: 5rem;
  }
}

@media (any-hover: hover) {
  .p-card-item:hover .p-card-item__img-item:nth-child(2) {
    opacity: 1;
  }
  .p-card-item:hover .p-card-item__img-item:nth-child(1) {
    opacity: 0;
  }
}

.p-card-item__img-wrap {
  position: relative;
}

.p-card-item__img-item {
  -webkit-transition: opacity 0.4s ease-out;
  transition: opacity 0.4s ease-out;
}
.p-card-item__img-item:nth-child(2) {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.p-card-item__img-item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
  aspect-ratio: 280/320;
  border-radius: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-item__img-item-img {
    aspect-ratio: 76/87;
  }
}

.p-card-item__info-wrap {
  margin-top: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-item__info-wrap {
    margin-top: 0.5rem;
  }
}

.p-card-item__info {
  color: var(--color-black-600);
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-card-item__info {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-card-item__info {
    font-size: max(0.625rem, 8px);
    font-weight: 400;
    line-height: 1.7;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-card-item__info {
    font-size: 0.625rem;
  }
}

.p-card-item__ttl {
  font-size: max(1.25rem, 16px);
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.02em;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-item__ttl {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-card-item__ttl {
    font-size: max(1rem, 12.8px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
    margin-top: 0.3125rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-card-item__ttl {
    font-size: 1rem;
  }
}

.p-member-content {
  background-color: var(--color-black-200);
  border-radius: 4px;
  padding: 5rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content {
    padding-top: 2rem;
    padding-bottom: 3rem;
    padding-inline: 1.25rem;
  }
}

.p-member-content__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: initial;
        -ms-flex-pack: initial;
            justify-content: initial;
    margin-bottom: 2.5rem;
  }
}

.p-member-content__img-wrap {
  max-width: 30rem;
  width: 100%;
  height: 34.25rem;
  aspect-ratio: 480/548;
  position: sticky;
  top: calc(5rem + var(--header-height) / 16 * 1rem);
  will-change: top;
  -webkit-transition: top 0.28s var(--ease-out-quint);
  transition: top 0.28s var(--ease-out-quint);
}
@media screen and (max-width: 767.9px) {
  .p-member-content__img-wrap {
    position: relative;
    height: auto;
    aspect-ratio: 36/41;
    width: auto;
    top: 0;
    max-width: initial;
  }
}

.p-member-content__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 4px;
}
.p-member-content__img:nth-child(2) {
  position: absolute;
  inset: 0;
  opacity: 0;
  -webkit-transition: opacity 0.5s var(--ease-out-quint);
  transition: opacity 0.5s var(--ease-out-quint);
}
.p-member-content__img:nth-child(2).is-active {
  opacity: 1;
}

.p-member-content__body {
  width: 32.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__body {
    width: 100%;
    margin-top: 1rem;
  }
}

.p-member-content__info-wrap {
  color: var(--color-black-600);
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__info-wrap {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member-content__info-wrap {
    font-size: max(0.625rem, 8px);
    font-weight: 400;
    line-height: 1.7;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-member-content__info-wrap {
    font-size: 0.625rem;
  }
}

.p-member-content__name-wrap {
  margin-top: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
}

.p-member-content__name-ja {
  font-size: max(1.75rem, 22.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__name-ja {
    font-size: 1.75rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member-content__name-ja {
    font-size: max(1.375rem, 17.6px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-member-content__name-ja {
    font-size: 1.375rem;
  }
}

.p-member-content__name-en {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .p-member-content__name-en {
    font-size: 0.8125rem;
  }
}

.p-member-content__profile-sentence {
  margin-top: 2rem;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__profile-sentence {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member-content__profile-sentence {
    margin-top: 1.5rem;
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-member-content__profile-sentence {
    font-size: 0.9375rem;
  }
}

.p-member-content__faq {
  margin-top: 2rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__faq {
    margin-top: 2.5rem;
  }
}

.p-member-content__faq-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  padding-block: 1.5rem;
  border-top: 1px solid var(--color-black-400);
  gap: 1rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  color: var(--color-black-600);
}
.p-member-content__faq-item:last-child {
  border-bottom: 1px solid var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-member-content__faq-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-block: 1.25rem;
    gap: 0.75rem;
  }
}

.p-member-content__faq-ttl {
  -ms-flex-preferred-size: max(7.5rem, 96px);
      flex-basis: max(7.5rem, 96px);
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: max(0.8125rem, 10.4px);
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.02em;
  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) {
  .p-member-content__faq-ttl {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member-content__faq-ttl {
    -ms-flex-preferred-size: initial;
        flex-basis: initial;
    line-height: 160%;
  }
}

.p-member-content__faq-answer {
  max-width: 380px;
  width: 100%;
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  -ms-flex-item-align: center;
      align-self: center;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__faq-answer {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-member-content__faq-answer {
    -ms-flex-preferred-size: initial;
        flex-basis: initial;
    max-width: initial;
  }
}

.p-member-content__introducing-others {
  margin-top: 1.25rem;
}

.p-member-content__avatar-block {
  margin-top: 3.4375rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__avatar-block {
    margin-top: 1.25rem;
  }
}

.p-member-content__interview {
  border-top: 1px solid var(--color-black-600);
  padding-top: 4rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__interview {
    padding-top: 2.5rem;
  }
}

.p-member-content__interview-items {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
}
@media screen and (max-width: 767.9px) {
  .p-member-content__interview-items {
    gap: 2rem;
    margin-top: 1.5rem;
  }
}

.p-card-slider {
  position: relative;
  margin-top: 7.5rem;
  margin-bottom: 9rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-slider {
    margin-top: 4rem;
    margin-bottom: 5rem;
  }
}

.p-card-slider__content {
  margin-top: 2.5rem;
  margin-inline: calc(50% - 50vw);
  width: 100vw;
}
@media screen and (max-width: 767.9px) {
  .p-card-slider__content {
    margin-top: 2rem;
  }
}

.p-card-slider__splide {
  position: initial;
}

.p-card-slider__slide {
  max-width: 280px;
}
@media screen and (max-width: 767.9px) {
  .p-card-slider__slide {
    max-width: 160px;
  }
}

.p-card-slider__arrows {
  position: absolute;
  pointer-events: none;
  top: 1.0625rem;
  right: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-slider__arrows {
    position: initial;
    top: initial;
    gap: 0.5rem;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 2rem;
  }
}

.p-card-slider__arrow {
  opacity: 1;
  pointer-events: auto;
  background-color: transparent;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  -webkit-transform: translateY(0%);
          transform: translateY(0%);
  -webkit-transition: background-color 0.3s var(--ease-out-quint);
  transition: background-color 0.3s var(--ease-out-quint);
  position: initial;
  width: 3.5rem;
  height: 3.5rem;
  background-color: var(--color-black-800);
  border-radius: 0;
}
@media screen and (max-width: 767.9px) {
  .p-card-slider__arrow {
    width: 3rem;
    height: 3rem;
  }
}
@media (any-hover: hover) {
  .p-card-slider__arrow:hover {
    background-color: var(--color-black-600);
  }
}
.p-card-slider__arrow svg {
  width: 1rem;
  height: 1.375rem;
}
@media screen and (max-width: 767.9px) {
  .p-card-slider__arrow svg {
    width: 0.875rem;
    height: 1.25rem;
  }
}

.p-avatar-block {
  border-radius: 4px;
  background-color: var(--color-red-100);
  padding-top: 1.5rem;
  padding-inline: 2rem;
  padding-bottom: 1.8125rem;
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block {
    padding-inline: 1.25rem;
    padding-bottom: 1.5rem;
  }
}

.p-avatar-block__title {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: var(--color-red-400);
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__title {
    font-size: 0.8125rem;
  }
}

.p-avatar-block__body {
  margin-top: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__body {
    gap: 1.25rem;
  }
}

.p-avatar-block__figure {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  max-width: max(5rem, 64px);
  width: 100%;
  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;
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__figure {
    width: 5rem;
  }
}

.p-avatar-block__avatar {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  aspect-ratio: 1/1;
  border-radius: calc(infinity * 1px);
  background-color: #D9D9D9;
}

.p-avatar-block__caption {
  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;
  margin-top: 0.5rem;
  text-align: center;
}

.p-avatar-block__caption-label {
  font-size: max(0.625rem, 8px);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__caption-label {
    font-size: 0.625rem;
  }
}

.p-avatar-block__caption-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  margin-top: -0.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__caption-text {
    font-size: 0.9375rem;
  }
}

.p-avatar-block__sentence {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.02em;
  color: var(--color-black-600);
  max-width: 348px;
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__sentence {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-avatar-block__sentence {
    max-width: initial;
  }
}

.p-article-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767.9px) {
  .p-article-card {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
  }
}

.p-article-card__img-wrap {
  width: 30rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .p-article-card__img-wrap {
    width: 100%;
  }
}

.p-article-card__img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.p-article-card__body {
  max-width: 520px;
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .p-article-card__body {
    max-width: initial;
  }
}

.p-article-card__title {
  font-size: max(1.125rem, 14.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-article-card__title {
    font-size: 1.125rem;
  }
}

.p-article-card__excerpt {
  margin-top: 1rem;
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}
@media screen and (max-width: 767.9px) {
  .p-article-card__excerpt {
    font-size: 0.8125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-article-card__excerpt {
    -webkit-line-clamp: 8;
  }
}

.p-article-card__btn {
  margin-top: 2.6875rem;
  margin-left: auto;
  padding-block: max(0.375rem, 4.8px);
  padding-inline: max(1.25rem, 16px) max(0.375rem, 4.8px);
  min-width: max(12.9375rem, 165.6px);
}
@media screen and (max-width: 767.9px) {
  .p-article-card__btn {
    padding-block: 0.375rem;
    padding-inline: 1.25rem 0.375rem;
    min-width: 12.9375rem;
    margin-left: initial;
    margin-top: 1.5rem;
  }
}

.p-article-card__btn-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 500;
  line-height: 1.4285714286;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .p-article-card__btn-text {
    font-size: 0.875rem;
  }
}

.p-article-card__btn-arrow-wrap {
  width: max(2.1875rem, 28px);
  height: max(2.1875rem, 28px);
}
@media screen and (max-width: 767.9px) {
  .p-article-card__btn-arrow-wrap {
    width: 2.1875rem;
    height: 2.1875rem;
  }
}

.p-article-card__btn-arrow {
  width: max(0.8125rem, 10.4px);
  height: max(1.0625rem, 13.6px);
}
@media screen and (max-width: 767.9px) {
  .p-article-card__btn-arrow {
    width: 0.8125rem;
    height: 1.0625rem;
  }
}

.p-news-card {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 0;
}

.p-news-card__link {
  display: inherit;
  grid-template-rows: inherit;
  grid-row: inherit;
  gap: inherit;
}
@media (any-hover: hover) {
  .p-news-card__link:hover .p-news-card__thumbnail {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}

.p-news-card__thumbnail-wrap {
  overflow: hidden;
  aspect-ratio: 386/203;
}

.p-news-card__thumbnail {
  width: 100%;
  height: 100%;
  -webkit-transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint), -webkit-transform 0.3s var(--ease-out-quint);
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 767.9px) {
  .p-news-card__thumbnail {
    height: auto;
  }
}

.p-news-card__title {
  font-size: max(1.125rem, 14.4px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0em;
  margin-top: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-news-card__title {
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-news-card__title {
    font-size: max(1rem, 12.8px);
    font-weight: 400;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-card__title {
    font-size: 1rem;
  }
}

.p-news-card__info-wrap {
  margin-top: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}

.p-news-card__date {
  font-size: max(0.75rem, 9.6px);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .p-news-card__date {
    font-size: 0.75rem;
  }
}

.p-news-card__cat {
  padding-inline: max(0.625rem, 8px);
  padding-block: max(0.125rem, 1.6px);
  border-radius: max(0.125rem, 1.6px);
  min-height: max(1.5rem, 19.2px);
  background-color: var(--color-blue-100);
}
@media screen and (max-width: 767.9px) {
  .p-news-card__cat {
    padding-inline: 0.625rem;
    padding-block: 0.125rem;
    border-radius: 0.125rem;
    min-height: 1.5rem;
  }
}

.p-news-card__cat-text {
  font-size: max(0.75rem, 9.6px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--color-blue-400);
}
@media screen and (max-width: 767.9px) {
  .p-news-card__cat-text {
    font-size: 0.75rem;
  }
}

.p-news-cards {
  margin-top: 3rem;
}

.p-news-cards__content {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(max(21.875rem, 280px), 1fr));
  gap: 4rem 2.5625rem;
}
@media screen and (max-width: 767.9px) {
  .p-news-cards__content {
    grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
    gap: 2rem 1.5rem;
  }
}
@media (width < 450px) {
  .p-news-cards__content {
    grid-template-columns: auto;
  }
}

#yotpo-modal {
  font-family: var(--font-figtree) !important;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  max-height: 90% !important;
}
@media screen and (max-width: 740px) {
  #yotpo-modal {
    max-width: 500px !important;
  }
}
@media screen and (max-width: 740px) {
  #yotpo-modal .yotpo-modal-body {
    padding-inline: 10px !important;
  }
}
#yotpo-modal .yotpo-modal-header-heading,
#yotpo-modal .yotpo-form-label,
#yotpo-modal textarea,
#yotpo-modal input,
#yotpo-modal .yotpo-new-input-message,
#yotpo-modal .yotpo-new-review-submit,
#yotpo-modal .yotpo-new-input-message,
#yotpo-modal p,
#yotpo-modal span,
#yotpo-modal .yotpo-upload-label {
  font-family: var(--font-figtree) !important;
}
#yotpo-modal .yotpo-star-rating-text {
  font-weight: 600 !important;
}
#yotpo-modal .yotpo-sr-star-empty path {
  stroke: rgba(0, 0, 0, 0);
  fill: rgba(0, 0, 0, 0.2);
}
#yotpo-modal .yotpo-sr-star-full path {
  stroke: rgb(0, 0, 0);
  fill: rgb(0, 0, 0);
}
#yotpo-modal .yotpo-input-wrapper,
#yotpo-modal .yotpo-star-rating-wrapper {
  min-height: initial !important;
  height: initial !important;
}
#yotpo-modal .yotpo-input-wrapper {
  margin-top: 20px;
  min-width: initial !important;
  width: 100% !important;
}
#yotpo-modal textarea,
#yotpo-modal input {
  padding: 8px 12px !important;
}
#yotpo-modal textarea {
  width: 100% !important;
}
#yotpo-modal .yotpo-new-input-message {
  margin-top: 6px !important;
}
#yotpo-modal .yotpo-name-email-wrapper {
  gap: 12px !important;
  width: 100% !important;
}
@media screen and (max-width: 740px) {
  #yotpo-modal .yotpo-name-email-wrapper {
    -ms-flex-wrap: wrap !important;
        flex-wrap: wrap !important;
    gap: 0 !important;
    margin-bottom: 20px !important;
  }
}

.yotpo-device-mobile {
  max-width: 650px !important;
}
.yotpo-device-mobile .yotpo-review-form {
  max-width: 400px !important;
  width: 100% !important;
}
.yotpo-device-mobile #yotpo-modal {
  max-width: 500px !important;
}
.yotpo-device-mobile .yotpo-name-email-wrapper {
  width: 100% !important;
  gap: 0px !important;
}
.yotpo-device-mobile .yotpo-input-wrapper {
  margin-top: 16px;
}
.yotpo-device-mobile .yotpo-file-upload {
  margin-top: 16px;
}

.yotpo-review-form {
  width: 100% !important;
}

.p-news-single__top {
  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: end;
  gap: 1.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-news-single__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2.5rem;
  }
}

.p-news-single__header {
  max-width: 560px;
  width: 100%;
}

.p-news-single__title {
  font-size: max(1.75rem, 22.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-news-single__title {
    font-size: 1.75rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-news-single__title {
    font-size: max(1.25rem, 16px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single__title {
    font-size: 1.25rem;
  }
}

.p-news-single__meta {
  margin-top: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}

.p-news-single__date {
  font-size: max(0.75rem, 9.6px);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-black-600);
}
@media screen and (max-width: 767.9px) {
  .p-news-single__date {
    font-size: 0.75rem;
  }
}

.p-news-single__category-link {
  padding-inline: max(0.625rem, 8px);
  padding-block: max(0.125rem, 1.6px);
  border-radius: max(0.125rem, 1.6px);
  min-height: max(1.5rem, 19.2px);
  background-color: var(--color-blue-100);
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media screen and (max-width: 767.9px) {
  .p-news-single__category-link {
    padding-inline: 0.625rem;
    padding-block: 0.125rem;
    border-radius: 0.125rem;
    min-height: 1.5rem;
  }
}
@media (any-hover: hover) {
  .p-news-single__category-link:hover {
    opacity: 0.7;
  }
}

.p-news-single__category-text {
  font-size: max(0.75rem, 9.6px);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--color-blue-400);
}
@media screen and (max-width: 767.9px) {
  .p-news-single__category-text {
    font-size: 0.75rem;
  }
}

.p-news-single__thumbnail-wrap {
  max-width: 560px;
  width: 100%;
  aspect-ratio: 560/294;
}

.p-news-single__thumbnail {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.p-news-single__body {
  margin-top: 6.4375rem;
  padding-block: 80px;
  background-color: var(--color-white);
  max-width: 1080px;
  width: 100%;
  margin-inline: auto;
  padding-inline: 40px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single__body {
    margin-top: 3.5rem;
    padding-block: 3.5rem;
    padding-inline: 2.5rem;
  }
}

.p-news-single__content {
  max-width: 760px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-news-single__content {
    padding-bottom: 2rem;
  }
}

.p-news-single__back-link {
  margin-top: 32px;
  color: var(--color-red-400);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 16px;
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .p-news-single__back-link:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767.9px) {
  .p-news-single__back-link {
    margin-top: 2.5rem;
    gap: 1rem;
  }
}

.p-news-single__back-link-icon {
  width: 13px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single__back-link-icon {
    width: 0.8125rem;
  }
}

.p-news-single__back-link-text {
  font-size: 15px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single__back-link-text {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single__back-link-text {
    font-size: 0.9375rem;
  }
}

.p-news-single-content > *:nth-child(1) {
  margin-top: 0 !important;
}
.p-news-single-content > * {
  margin-top: 56px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content > * {
    margin-top: 3rem;
  }
}
.p-news-single-content > p {
  margin-top: 16px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content > p {
    margin-top: 1rem;
  }
}
.p-news-single-content > * figure {
  margin-top: 56px;
}
.p-news-single-content > * figure img,
.p-news-single-content > * figure video,
.p-news-single-content > * figure picture {
  margin-top: 0 !important;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content > * figure {
    margin-top: 3rem;
  }
}
.p-news-single-content > .is-layout-flex > * {
  margin-top: 0 !important;
}
.p-news-single-content > blockquote {
  margin-top: 40px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content > blockquote {
    margin-top: 2.5rem;
  }
}
.p-news-single-content > .addtoany_content {
  margin-top: 56px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content > .addtoany_content {
    margin-top: 3rem;
  }
}
.p-news-single-content h2 {
  font-weight: 500;
  font-size: 28px;
  line-height: 44.8px;
  letter-spacing: 0.56px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content h2 {
    font-size: max(1.25rem, 16px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content h2 {
    font-size: 1.25rem;
  }
}
.p-news-single-content h3 {
  font-size: 20px;
  font-weight: 500;
  line-height: 32px;
  letter-spacing: 0.4px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content h3 {
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content h3 {
    font-size: 1.125rem;
  }
}
.p-news-single-content h4,
.p-news-single-content h5,
.p-news-single-content h6 {
  font-size: 16px;
  font-weight: 500;
  line-height: 25.6px;
  letter-spacing: 0.32px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content h4,
  .p-news-single-content h5,
  .p-news-single-content h6 {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content h4,
  .p-news-single-content h5,
  .p-news-single-content h6 {
    font-size: 0.9375rem;
  }
}
.p-news-single-content p {
  font-size: 15px;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content p {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content p {
    font-size: 0.9375rem;
  }
}
.p-news-single-content a {
  color: var(--color-blue-400);
  text-decoration: underline;
}
.p-news-single-content blockquote {
  border-left: var(--color-blue-400) 0.25em solid;
  margin-inline: 0;
  padding-left: 1em;
}
.p-news-single-content .p-news-single__btn {
  color: var(--color-white) !important;
  text-decoration: none;
}
.p-news-single-content figcaption {
  font-size: 13px;
  font-weight: 400;
  line-height: 26px;
  letter-spacing: 0.26px;
  color: var(--color-black-600);
  margin-top: 16px;
  margin-bottom: 0;
  text-align: center;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content figcaption {
    font-size: max(0.8125rem, 10.4px);
    font-weight: 400;
    line-height: 1.8461538462;
    letter-spacing: 0.02em;
    margin-top: 1rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content figcaption {
    font-size: 0.8125rem;
  }
}
.p-news-single-content .wp-block-file {
  margin-top: 40px;
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content .wp-block-file {
    margin-top: 3rem;
  }
}
@media (any-hover: hover) {
  .p-news-single-content .wp-block-file:hover {
    opacity: 0.7;
  }
}
.p-news-single-content .wp-block-file a {
  color: var(--color-black-800);
  font-size: 15px;
  font-weight: 500;
  line-height: 22.5px;
  letter-spacing: 0.3px;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content .wp-block-file a {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.02em;
    gap: 0.5rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content .wp-block-file a {
    font-size: 0.9375rem;
  }
}
.p-news-single-content .wp-block-file a::before {
  content: "";
  width: 15px;
  height: 20px;
  display: block;
  background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="15" height="20" viewBox="0 0 15 20" fill="none"><g clip-path="url(%23clip0_771_2065)"><path d="M1.6668 20C0.747656 20 0 19.2523 0 18.3332V1.6668C0 0.747656 0.747656 0 1.6668 0H10.4168C10.5281 0 10.6328 0.0433594 10.7113 0.121875L14.8781 4.28867C14.957 4.36758 15 4.47188 15 4.5832V18.3332C15 19.2523 14.2523 20 13.3332 20H1.6668ZM1.6668 0.833203C1.20742 0.833203 0.833594 1.20703 0.833594 1.66641V18.3332C0.833594 18.7926 1.20742 19.1664 1.6668 19.1664H13.3336C13.793 19.1664 14.1668 18.7926 14.1668 18.3332V5H11.6668C10.7477 5 10 4.25234 10 3.3332V0.833203H1.6668ZM10.8332 3.3332C10.8332 3.79258 11.207 4.16641 11.6664 4.16641H13.5773L10.8332 1.42227V3.3332ZM3.75 16.6668C3.14883 16.6668 2.5 16.2969 2.5 15.6996C2.5 14.8762 3.37891 14.4602 4.70937 13.8305L4.73477 13.8184C5.02578 13.6805 5.325 13.5387 5.64727 13.3773C5.73281 13.3344 5.82617 13.2906 5.93242 13.2434C6.05586 12.9672 6.16992 12.6727 6.27187 12.368L6.38359 12.0316C6.55195 11.5258 6.71094 11.0484 6.84922 10.627C6.17539 9.75117 5.83359 8.99297 5.83359 8.37305C5.83359 6.9625 6.51328 6.66641 7.08359 6.66641C7.68828 6.66641 8.33359 6.79531 8.33359 8.3332C8.33359 8.68047 8.12266 9.40234 7.78203 10.4539C8.03047 10.7504 8.31523 11.059 8.62813 11.3719C8.85703 11.6008 9.21094 11.9062 9.62461 12.2316C10.2336 12.1297 10.6781 12.0832 10.8336 12.0832C11.3746 12.0832 12.5004 12.0832 12.5004 13.0684C12.5004 13.5695 12.2836 14.1668 11.2504 14.1668C10.9391 14.1668 10.3023 13.8039 9.40977 13.1176C8.76914 13.2371 7.54531 13.4965 6.54961 13.8891C6.13828 14.7281 5.63906 15.4395 5.10508 15.9465C4.61562 16.4113 4.13477 16.6672 3.75039 16.6672L3.75 16.6668ZM3.3332 15.6996C3.34727 15.7164 3.50312 15.8336 3.75 15.8336C3.97773 15.8336 4.60625 15.4113 5.23125 14.5055L5.06641 14.5832C4.175 15.0055 3.33359 15.4039 3.33359 15.6996H3.3332ZM10.5805 12.9363C11.0457 13.2531 11.2188 13.3227 11.2805 13.3359C11.6672 13.3336 11.6672 13.2559 11.6672 13.0688C11.6164 12.9609 11.375 12.9172 10.834 12.9172C10.784 12.9172 10.6965 12.9238 10.5809 12.9367L10.5805 12.9363ZM7.47969 11.3762C7.38008 11.677 7.27109 12.0043 7.15195 12.3617L7.06172 12.632C7.03711 12.7063 7.01172 12.7801 6.98594 12.8516C7.46406 12.7 7.99648 12.5598 8.56836 12.4352C8.30625 12.2117 8.11328 12.0359 8.03867 11.9613C7.83867 11.7613 7.65039 11.5645 7.47969 11.3762ZM7.0832 7.5C6.66641 7.5 6.66641 8.06797 6.66641 8.37305C6.66641 8.69766 6.83516 9.12187 7.16797 9.63437C7.39727 8.90078 7.49961 8.49922 7.49961 8.3332C7.49961 7.5 7.37773 7.5 7.08281 7.5H7.0832Z" fill="%23B22A00"/></g><defs><clipPath id="clip0_771_2065"><rect width="15" height="20" fill="white"/></clipPath></defs></svg>') !important;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content .wp-block-file a::before {
    width: 0.9375rem;
    height: 1.25rem;
  }
}
.p-news-single-content .wp-block-file .wp-block-file__button {
  display: none;
}
.p-news-single-content ul,
.p-news-single-content ol {
  padding-left: 1.5em;
  margin-left: 0;
  list-style: initial;
}
.p-news-single-content ul li,
.p-news-single-content ol li {
  list-style: initial;
  font-size: 15px;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 0.3px;
  margin-bottom: 8px;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content ul li,
  .p-news-single-content ol li {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-news-single-content ul li,
  .p-news-single-content ol li {
    font-size: 0.9375rem;
  }
}
.p-news-single-content ul {
  list-style-type: disc;
}
.p-news-single-content ul ul {
  list-style-type: circle;
  margin-top: 8px;
}
.p-news-single-content ul ul ul {
  list-style-type: square;
}
.p-news-single-content ol {
  list-style-type: decimal;
}
.p-news-single-content ol ol {
  list-style-type: lower-alpha;
  margin-top: 8px;
}
.p-news-single-content ol ol ol {
  list-style-type: lower-roman;
}
.p-news-single-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 15px;
  line-height: 24px;
}
.p-news-single-content table th,
.p-news-single-content table td {
  padding: 12px 16px;
  text-align: left;
  border: 1px solid var(--color-blue-400);
  vertical-align: top;
}
.p-news-single-content table th {
  background-color: var(--color-blue-100);
  font-weight: 500;
}
@media screen and (max-width: 767.9px) {
  .p-news-single-content table {
    font-size: 14px;
    line-height: 22px;
  }
  .p-news-single-content table th,
  .p-news-single-content table td {
    padding: 8px 12px;
  }
}
.p-news-single-content code {
  background-color: var(--color-black-200);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 14px;
  color: var(--color-red-600);
}
.p-news-single-content pre {
  background-color: var(--color-black-50);
  padding: 16px;
  border-radius: 8px;
  overflow-x: auto;
}
.p-news-single-content pre code {
  background-color: transparent;
  padding: 0;
  color: inherit;
}

.p-service-btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-service-btns {
    gap: 3rem;
  }
}

.p-service-btns__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.5rem;
}

.p-service-btns__title {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-service-btns__title {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service-btns__title {
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.5888888889;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-service-btns__title {
    font-size: 1.125rem;
  }
}

.p-service-btns__wrap {
  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.75rem;
}

.p-service-recruits {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits {
    gap: 2.5rem;
  }
}

.p-service-recruits__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
}

.p-service-recruits__item-img-wrap {
  width: 100%;
  height: auto;
  aspect-ratio: 540/303;
}

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

.p-service-recruits__item-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.p-service-recruits__item-title {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits__item-title {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits__item-title {
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.5888888889;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-service-recruits__item-title {
    font-size: 1.125rem;
  }
}

.p-service-recruits__item-text {
  margin-top: 0.5rem;
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits__item-text {
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits__item-text {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-service-recruits__item-text {
    font-size: 0.9375rem;
  }
}

.p-service-recruits__item-link {
  margin-top: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: auto;
  gap: 0.375rem;
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-bottom: 0.1875rem solid;
  padding-bottom: 0.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits__item-link {
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-service-recruits__item-link {
    margin-top: 0.75rem;
  }
}
.p-service-recruits__item-link .u-textUp--block:has(.p-service-recruits__item-link-icon) {
  translate: 0 -0.125rem;
}

.p-sns-btns {
  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.75rem;
}

.p-list-sitemap li {
  list-style-type: disc;
  margin-left: 1.5rem;
}
.p-list-sitemap a {
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .p-list-sitemap a:hover {
    opacity: 0.7;
  }
}

.p-list-sitemap__item {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-list-sitemap__item {
    font-size: 0.9375rem;
  }
}

a .p-list-sitemap__item-text,
a .p-list-sitemap__sub-item-text,
a .p-list-sitemap__sub-sub-item-text {
  text-decoration: underline;
}

.p-privacy-policy {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 2.5rem;
  width: 100%;
}

.p-privacy-policy__content > *:nth-child(1) {
  margin-top: 0 !important;
}
.p-privacy-policy__content > * {
  margin-top: 16px;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content > * {
    margin-top: 1rem;
  }
}
.p-privacy-policy__content > h2 {
  margin-top: 48px;
  font-size: 22px;
  font-style: normal;
  font-weight: 500;
  line-height: 150%; /* 33px */
  scroll-margin-top: 180px;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content > h2 {
    margin-top: 3rem;
    font-size: max(1.375rem, 17.6px);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.02em;
    scroll-margin-top: 7.5rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-privacy-policy__content > h2 {
    font-size: 1.375rem;
  }
}
.p-privacy-policy__content h3,
.p-privacy-policy__content h4 {
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 150%;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content h3,
  .p-privacy-policy__content h4 {
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-privacy-policy__content h3,
  .p-privacy-policy__content h4 {
    font-size: 1.125rem;
  }
}
.p-privacy-policy__content p {
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 200%; /* 30px */
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content p {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-privacy-policy__content p {
    font-size: 0.9375rem;
  }
}
.p-privacy-policy__content sup {
  line-height: 100%;
  translate: 0px 3px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content sup {
    translate: 0rem 0.1875rem;
  }
}
.p-privacy-policy__content a {
  color: var(--color-blue-400);
  text-decoration: underline;
  -webkit-transition: opacity 0.3s var(--ease-out-quint);
  transition: opacity 0.3s var(--ease-out-quint);
}
@media (any-hover: hover) {
  .p-privacy-policy__content a:hover {
    opacity: 0.7;
  }
}
.p-privacy-policy__content ul,
.p-privacy-policy__content ol {
  padding-left: 1.5em;
  margin-left: 0;
  list-style: initial;
}
.p-privacy-policy__content ul li,
.p-privacy-policy__content ol li {
  list-style: initial;
  font-size: 15px;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content ul li,
  .p-privacy-policy__content ol li {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-privacy-policy__content ul li,
  .p-privacy-policy__content ol li {
    font-size: 0.9375rem;
  }
}
.p-privacy-policy__content ul {
  list-style-type: disc;
}
.p-privacy-policy__content ul ul {
  list-style-type: circle;
  margin-top: 8px;
}
.p-privacy-policy__content ul ul ul {
  list-style-type: square;
}
.p-privacy-policy__content ol {
  list-style-type: decimal;
}
.p-privacy-policy__content ol ol {
  list-style-type: lower-alpha;
  margin-top: 8px;
}
.p-privacy-policy__content ol ol ol {
  list-style-type: lower-roman;
}
.p-privacy-policy__content .wp-block-group .wp-block-group__inner-container {
  background: var(--color-black-200);
  color: var(--color-black-600);
  padding-block: 32px;
  padding-inline: 40px;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content .wp-block-group .wp-block-group__inner-container {
    padding-block: 2rem;
    padding-inline: 0.625rem;
  }
}
.p-privacy-policy__content .wp-block-group .wp-block-group__inner-container > *:nth-child(1) {
  margin-top: 0 !important;
}
.p-privacy-policy__content .wp-block-group .wp-block-group__inner-container > * {
  margin-top: 16px;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content .wp-block-group .wp-block-group__inner-container > * {
    margin-top: 1rem;
  }
}
.p-privacy-policy__content .wp-block-group .wp-block-group__inner-container p {
  font-size: 13px;
  font-style: normal;
  font-weight: 400;
  line-height: 200%;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content .wp-block-group .wp-block-group__inner-container p {
    font-size: max(0.8125rem, 10.4px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-privacy-policy__content .wp-block-group .wp-block-group__inner-container p {
    font-size: 0.8125rem;
  }
}
.p-privacy-policy__content .wp-block-group .wp-block-group__inner-container sup {
  line-height: 100%;
  font-size: 10px !important;
  translate: 0px 3px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}
@media screen and (max-width: 767.9px) {
  .p-privacy-policy__content .wp-block-group .wp-block-group__inner-container sup {
    font-size: max(0.625rem, 8px);
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-privacy-policy__content .wp-block-group .wp-block-group__inner-container sup {
    font-size: 0.625rem;
  }
}

.p-under-service-header-gallery {
  height: 31.25rem;
  position: relative;
  margin-top: -2.4375rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-header-gallery {
    height: auto;
    margin-top: 2rem;
  }
}

.p-under-service-header-gallery__item {
  position: absolute;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: -webkit-transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint);
  transition: transform 0.3s var(--ease-out-quint), -webkit-transform 0.3s var(--ease-out-quint);
}
.p-under-service-header-gallery__item.--1 {
  bottom: 0rem;
  left: -5rem;
}
.p-under-service-header-gallery__item.--2 {
  left: 25rem;
  top: 0;
}
.p-under-service-header-gallery__item.--3 {
  bottom: 2.6875rem;
  right: -5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-header-gallery__item {
    position: static;
  }
  .p-under-service-header-gallery__item.--3 {
    margin-top: 1rem;
    margin-left: auto;
  }
}

.p-under-service-header-gallery__img {
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 0.25rem;
}
.p-under-service-header-gallery__img.--1 {
  width: 20rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-header-gallery__img.--1 {
    width: 9.1875rem;
  }
}
.p-under-service-header-gallery__img.--2 {
  width: 12.5rem;
}
.p-under-service-header-gallery__img.--3 {
  width: 37.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-header-gallery__img.--3 {
    width: 17.25rem;
  }
}

.p-under-service-details {
  padding-bottom: 5.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details {
    padding-bottom: 4rem;
  }
}

.p-under-service-details__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4rem;
}

.p-under-service-details__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5rem;
  width: 100%;
  max-width: 1360px;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item {
    -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;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    margin-right: initial;
    padding-left: 0;
    position: relative;
    left: initial;
    top: initial;
    -webkit-transform: initial;
            transform: initial;
    gap: 2rem;
  }
}

.p-under-service-details__item-body {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: max(26.25rem, 336px);
  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) {
  .p-under-service-details__item-body {
    padding-bottom: 0;
    width: 100%;
  }
}

.p-under-service-details__item-title {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  margin-top: auto;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-title {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-title {
    margin-top: initial;
  }
}

.p-under-service-details__item-description {
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0em;
  margin-top: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-description {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-description {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-service-details__item-description {
    font-size: 0.9375rem;
  }
}

.p-under-service-details__item-btn-wrap {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
}

.p-under-service-details__item-btn {
  padding-block: max(0.375rem, 4.8px);
  padding-inline: max(1.25rem, 16px) max(0.375rem, 4.8px);
  min-width: max(12.9375rem, 165.6px);
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-btn {
    padding-block: 0.375rem;
    padding-inline: 1.25rem 0.375rem;
    min-width: 12.9375rem;
  }
}

.p-under-service-details__item-btn-text {
  font-size: max(0.875rem, 11.2px);
  font-weight: 500;
  line-height: 1.4285714286;
  letter-spacing: 0em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-btn-text {
    font-size: 0.875rem;
  }
}

.p-under-service-details__item-btn-arrow-wrap {
  width: max(2.1875rem, 28px);
  height: max(2.1875rem, 28px);
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-btn-arrow-wrap {
    width: 2.1875rem;
    height: 2.1875rem;
  }
}

.p-under-service-details__item-btn-arrow {
  width: max(0.8125rem, 10.4px);
  height: max(1.0625rem, 13.6px);
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-btn-arrow {
    width: 0.8125rem;
    height: 1.0625rem;
  }
}

.p-under-service-details__item-img-wrap {
  border-radius: 0.25rem;
  overflow: hidden;
  width: 100%;
  height: 29.375rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-details__item-img-wrap {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    width: 100%;
    padding-right: 0;
  }
}

.p-under-service-details__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.p-under-philosophy__content {
  margin-top: 2rem;
}

.p-under-philosophy__content-text-wrap {
  padding-bottom: 3rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__content-text-wrap {
    padding-bottom: 2.5rem;
  }
}

.p-under-philosophy__text {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__text {
    font-size: 0.9375rem;
  }
}
.p-under-philosophy__text:not(:first-child) {
  margin-top: 1lh;
}
.p-under-philosophy__text .marker {
  position: relative;
  font-weight: 700;
}
.p-under-philosophy__text .marker .marker-txt {
  position: relative;
  z-index: 2;
}
.p-under-philosophy__text .marker:before {
  height: 48%;
  width: 100%;
  left: 0;
  bottom: 11%;
  content: "";
  position: absolute;
  background-color: #f7eae6;
}

.p-under-philosophy__catch {
  padding-block: 1.9375rem;
  border-top: var(--color-black-400) 1px solid;
}
.p-under-philosophy__catch:has(.p-under-philosophy__catch-ttl-wrap + *) {
  padding-block: 1.9375rem 0rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch:has(.p-under-philosophy__catch-ttl-wrap + *) {
    padding-block: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch {
    padding-block: 1.25rem;
  }
}

.p-under-philosophy__catch-icon-cards {
  --card-items: 3;
  --card-gap: 20;
  gap: calc(var(--card-gap) / 16 * 1rem);
  margin-top: 1.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-bottom: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch-icon-cards {
    -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;
  }
}

.p-under-philosophy__catch-icon-card {
  height: inherit;
  -ms-flex-preferred-size: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
      flex-basis: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
  border-radius: 4px;
  border: 1px solid var(--color-red-400);
  padding-block: 1.9375rem;
  padding-inline: 1.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-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) {
  .p-under-philosophy__catch-icon-card {
    padding-block: 1.4375rem 1.9375rem;
    padding-inline: 1.1875rem;
    -ms-flex-preferred-size: 10%;
        flex-basis: 10%;
    max-width: 400px;
    width: 100%;
  }
}
@media (min-width: 768px) {
  .p-under-philosophy__catch-icon-card:first-child {
    margin-left: auto;
  }
  .p-under-philosophy__catch-icon-card:last-child {
    margin-right: auto;
  }
}

.p-under-philosophy__catch-icon-card-ttl {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 500;
  line-height: 1.5846153846;
  letter-spacing: 0.02em;
  color: var(--color-red-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch-icon-card-ttl {
    font-size: 0.8125rem;
  }
}

.p-under-philosophy__catch-icon-card-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 6.25rem;
  height: 6.25rem;
  margin-top: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch-icon-card-img {
    margin-top: 0.75rem;
  }
}

.p-under-philosophy__catch-icon-card-text {
  margin-top: 1.5rem;
  text-align: center;
  font-size: max(1.125rem, 14.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch-icon-card-text {
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy__catch-icon-card-text {
    font-size: max(0.9375rem, 12px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
    margin-top: 0.75rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-philosophy__catch-icon-card-text {
    font-size: 0.9375rem;
  }
}

.p-under-philosophy-future {
  margin-top: 6.125rem;
  margin-bottom: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future {
    margin-top: 3.75rem;
    margin-bottom: 5rem;
  }
}

.p-under-philosophy-future__content {
  margin-top: 2rem;
}

.p-under-philosophy-future__top {
  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) {
  .p-under-philosophy-future__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-under-philosophy-future__top-ttl {
  font-size: max(2.75rem, 35.2px);
  font-weight: 500;
  line-height: 1.2045454545;
  letter-spacing: 0em;
  font-family: "Noto Sans JP";
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__top-ttl {
    font-size: 2.75rem;
  }
}
.p-under-philosophy-future__top-ttl .--red {
  color: var(--color-red-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__top-ttl {
    font-size: max(2.25rem, 28.8px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-philosophy-future__top-ttl {
    font-size: 2.25rem;
  }
}

.p-under-philosophy-future__top-text-wrap {
  margin-top: 2rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__top-text-wrap {
    margin-top: 1.5rem;
  }
}

.p-under-philosophy-future__top-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__top-text {
    font-size: 0.9375rem;
  }
}
.p-under-philosophy-future__top-text:not(:first-child) {
  margin-top: 1lh;
}

.p-under-philosophy-future__graph-wrap {
  width: 32.5rem;
  height: 32.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__graph-wrap {
    margin-top: 2.5rem;
    max-width: 25rem;
    width: 100%;
    height: 100%;
  }
}

.p-under-philosophy-future__graph-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
}

.p-under-philosophy-future__items {
  margin-top: 4.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__items {
    margin-top: 3.5rem;
  }
}

.p-under-philosophy-future__item {
  padding-block: 1.9375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.875rem;
  border-bottom: 1px solid var(--color-black-400);
}
.p-under-philosophy-future__item:first-child {
  border-top: 1px solid var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__item {
    padding-block: 1.4375rem;
    gap: 0.5rem;
  }
}

.p-under-philosophy-future__item-no {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: max(1.5rem, 19.2px);
  font-size: max(1rem, 12.8px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-red-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__item-no {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__item-no {
    gap: 0.5rem;
    -ms-flex-item-align: start;
        align-self: start;
    translate: 0 0.0625rem;
  }
}

.p-under-philosophy-future__item-ttl {
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__item-ttl {
    font-size: 1.25rem;
  }
}

.p-under-philosophy-future__item-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__item-text {
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-philosophy-future__item-text {
    margin-top: 0.75rem;
  }
}

.p-partner-message__content {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-message__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.5rem;
  }
}

.p-partner-message__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.p-partner-message__text {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-message__text {
    font-size: 0.9375rem;
  }
}

.p-partner-message__info {
  margin-top: auto;
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.75rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-message__info {
    margin-top: 1.5rem;
  }
}

.p-partner-message__job {
  font-size: max(0.8125rem, 10.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-message__job {
    font-size: 0.8125rem;
  }
}

.p-partner-message__name {
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-message__name {
    font-size: 1.25rem;
  }
}

.p-partner-message__img-wrap {
  width: 27.4375rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .p-partner-message__img-wrap {
    max-width: 27.4375rem;
    width: 100%;
    margin-inline: auto;
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
}

.p-partner-message__img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.p-partner-service {
  margin-top: 6rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-service {
    margin-top: 4rem;
  }
}

.p-partner-service__content {
  margin-top: 2rem;
}

.p-partner-service__items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-service__items {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: 400px;
    width: 100%;
    margin-inline: auto;
  }
}

.p-partner-service__item {
  width: 100%;
}

@media (any-hover: hover) {
  a.p-partner-service__item:hover .p-partner-service__item-img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}

.p-partner-service__item-img-wrap {
  overflow: hidden;
}

.p-partner-service__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  -webkit-transition: all 0.5s var(--ease-out-quint);
  transition: all 0.5s var(--ease-out-quint);
}

.p-partner-service__item-ttl {
  font-size: max(1.125rem, 14.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
  margin-top: 1rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-service__item-ttl {
    font-size: 1.125rem;
  }
}

.p-partner-look-for {
  margin-top: 6rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for {
    margin-top: 5rem;
    margin-bottom: 3rem;
  }
}

.p-partner-look-for__content {
  margin-top: 2rem;
}

.p-partner-look-for__items {
  margin-top: 4.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__items {
    margin-top: 3.5rem;
  }
}

.p-partner-look-for__item {
  padding-block: 1.9375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px solid var(--color-black-400);
}
.p-partner-look-for__item:first-child {
  border-top: 1px solid var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item {
    padding-block: 1.4375rem;
    gap: 0.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-partner-look-for__item-no {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: max(1.5rem, 19.2px);
  font-size: max(1rem, 12.8px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-red-400);
  margin-right: 1.25rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item-no {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item-no {
    gap: 0.5rem;
    margin-right: initial;
    margin-bottom: 0.5rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.p-partner-look-for__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 5.625rem;
  height: 5.625rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-right: 1.875rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item-img {
    margin-right: initial;
    margin-bottom: 1rem;
  }
}

.p-partner-look-for__item-ttl {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item-ttl {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item-ttl {
    text-align: center;
    font-size: max(1.25rem, 16px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-partner-look-for__item-ttl {
    font-size: 1.25rem;
  }
}

.p-partner-look-for__item-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-look-for__item-text {
    font-size: 0.9375rem;
  }
}

.p-partner-requirement {
  padding-block: 4rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-requirement {
    padding-block: 3rem;
    width: 100%;
    max-width: 640px;
  }
}

.p-partner-requirement__content {
  margin-top: 2rem;
}

.p-partner-requirement__dl-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-block: 2rem;
  border-bottom: 1px solid var(--color-black-400);
  display: flex;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-requirement__dl-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.5rem;
  }
}
.p-partner-requirement__dl-item:first-child {
  border-top: 1px solid var(--color-black-400);
}

.p-partner-requirement__dl-ttl {
  -ms-flex-preferred-size: 12.5rem;
      flex-basis: 12.5rem;
  font-size: max(0.9375rem, 12px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-requirement__dl-ttl {
    font-size: 0.9375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-partner-requirement__dl-ttl {
    -ms-flex-preferred-size: auto;
        flex-basis: auto;
  }
}

.p-partner-requirement__dl-content {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media screen and (max-width: 767.9px) {
  .p-partner-requirement__dl-content {
    font-size: 0.9375rem;
  }
}

.p-partner-requirement__dl-text ~ * {
  margin-top: 1lh;
}

.p-partner-requirement__dl-2column-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-partner-requirement__dl-2column-ttl {
  -ms-flex-preferred-size: max(8.625rem, 110.4px);
      flex-basis: max(8.625rem, 110.4px);
}

.p-partner-voice {
  margin-top: 4rem;
  padding-bottom: 4rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-voice {
    margin-top: 3rem;
    padding-bottom: 5rem;
  }
}

.p-partner-voice__content {
  margin-top: 2rem;
}

.p-partner-voice__items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  --card-items: 2;
  --card-gap: 40;
  gap: calc(var(--card-gap) / 16 * 1rem);
}
@media screen and (max-width: 767.9px) {
  .p-partner-voice__items {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-partner-voice__item {
  -ms-flex-preferred-size: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
      flex-basis: calc((100% - var(--card-gap) / 16 * 1rem * (var(--card-items) - 1)) / var(--card-items));
  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) {
  .p-partner-voice__item {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
  }
}

.p-partner-voice__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  height: 100%;
  width: 100%;
  aspect-ratio: 440/230;
}
.p-partner-voice__item-body {
  margin-top: 1.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-partner-voice__item-body {
    margin-top: 1rem;
  }
}

.p-partner-voice__item-ttl {
  font-size: max(1.125rem, 14.4px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-voice__item-ttl {
    font-size: 1.125rem;
  }
}

.p-partner-voice__item-text {
  margin-top: 1rem;
  font-size: max(0.8125rem, 10.4px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-partner-voice__item-text {
    font-size: 0.8125rem;
  }
}

.p-contact-cta {
  position: relative;
  width: 100%;
  padding-block: 12.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-contact-cta {
    padding-block: 5rem 0;
    height: 22.75rem;
  }
}

.p-contact-cta__bg-picture::after {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  background: rgba(16, 14, 15, 0.5);
}

.p-contact-cta__bg-img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  inset: 0;
}

.p-contact-cta__content {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 77.5rem;
  width: 100%;
  margin-inline: auto;
}
@media screen and (max-width: 767.9px) {
  .p-contact-cta__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: initial;
        -ms-flex-pack: initial;
            justify-content: initial;
  }
}

.p-contact-cta__text {
  font-size: max(1.375rem, 17.6px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
  color: #fff;
}
@media screen and (max-width: 767.9px) {
  .p-contact-cta__text {
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-contact-cta__text {
    font-size: max(1.25rem, 16px);
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-contact-cta__text {
    font-size: 1.25rem;
  }
}

.p-contact-cta__btn {
  background-color: #fff;
  border: initial !important;
}
@media screen and (max-width: 767.9px) {
  .p-contact-cta__btn {
    margin-top: 2.5rem;
  }
}

.p-404 {
  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.75rem;
}

.p-under-service-promise {
  padding-block: 5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise {
    padding-block: 4rem;
  }
}

.p-under-service-promise__content {
  margin-top: 2rem;
}

.p-under-service-promise__block {
  margin-top: 2rem;
}

.p-under-service-promise__img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 0.25rem;
}

.p-under-service-promise__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1.5rem;
  margin-top: 2rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-under-service-promise__ttl {
  max-width: max(27.5rem, 352px);
  width: 100%;
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise__ttl {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise__ttl {
    max-width: 100%;
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-service-promise__ttl {
    font-size: 1.125rem;
  }
}

.p-under-service-promise__sentence {
  max-width: max(27.5rem, 352px);
  width: 100%;
  font-size: max(1rem, 12.8px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise__sentence {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise__sentence {
    font-size: max(0.9375rem, 12px);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.02em;
    max-width: 100%;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-service-promise__sentence {
    font-size: 0.9375rem;
  }
}

.p-under-service-promise__picture {
  margin-top: 2.5rem;
}

.p-under-service-promise__graph__img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-promise__graph__img {
    max-width: 400px;
    width: 100%;
    margin-inline: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.p-under-service-gallery__gallery {
  margin-inline: calc(50% - 50vw);
  width: 100vw;
  position: relative;
  margin-top: 7.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__gallery {
    margin-top: 4rem;
  }
}

.p-under-service-gallery__splide {
  position: relative;
}

.p-under-service-gallery__slide {
  --img-width: 200;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide {
    --img-width: 114;
  }
}
.p-under-service-gallery__slide.--01 {
  margin-top: 1rem;
  --img-width: 400;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--01 {
    margin-top: 0.5625rem;
    --img-width: 229;
  }
}
.p-under-service-gallery__slide.--02 {
  margin-top: 10rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--02 {
    margin-top: 5.75rem;
  }
}
.p-under-service-gallery__slide.--04 {
  margin-top: 5.5625rem;
  --img-width: 360;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--04 {
    margin-top: 3.1875rem;
    --img-width: 206;
  }
}
.p-under-service-gallery__slide.--06 {
  margin-top: 5.5625rem;
  --img-width: 360;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--06 {
    margin-top: 3.1875rem;
    --img-width: 206;
  }
}
.p-under-service-gallery__slide.--07 {
  margin-top: 1rem;
  --img-width: 400;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--07 {
    margin-top: 0.5625rem;
    --img-width: 229;
  }
}
.p-under-service-gallery__slide.--08 {
  margin-top: 10rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--08 {
    margin-top: 5.75rem;
  }
}
.p-under-service-gallery__slide.--10 {
  margin-top: 10rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__slide.--10 {
    margin-top: 5.75rem;
  }
}

.p-under-service-gallery__splide-slide-img {
  width: calc(var(--img-width) / 16 * 1rem);
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  border-radius: 0.25rem;
}

.p-under-service-gallery__fix-text {
  font-size: max(12.5rem, 160px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0em;
  color: var(--color-blue-100);
  white-space: nowrap;
  position: absolute;
  left: 50%;
  translate: -50%;
  bottom: min(-1.625rem, -20.8px);
  mix-blend-mode: multiply;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__fix-text {
    font-size: 12.5rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__fix-text {
    font-size: max(9rem, 115.2px);
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0em;
    bottom: -1.25rem;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-service-gallery__fix-text {
    font-size: 9rem;
  }
}

.p-under-service-gallery__btn {
  margin-inline: auto;
  margin-top: 7.125rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-gallery__btn {
    margin-top: 4rem;
  }
}

.p-under-service-strength {
  padding-top: 7.5rem;
  padding-bottom: 5.5625rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

.p-under-service-strength__content {
  margin-top: 2rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__content {
    margin-top: 1.5rem;
  }
}

.p-under-service-strength__text {
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__text {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__text {
    font-size: max(1.125rem, 14.4px);
    font-weight: 600;
    line-height: 1.6;
    letter-spacing: 0.0166666667em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-service-strength__text {
    font-size: 1.125rem;
  }
}
.p-under-service-strength__text .--marker {
  display: inline;
  background: -webkit-gradient(linear, left top, right top, from(var(--color-red-100)), to(var(--color-red-100))) no-repeat, transparent;
  background: linear-gradient(to right, var(--color-red-100), var(--color-red-100)) no-repeat, transparent;
  background-size: 100% 50%; /* 背景色の高さ50% */
  background-position: 0 100%; /* 背景色の位置を下部に設定 */
}

.p-under-service-strength__img {
  margin-top: 3rem;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__img {
    margin-top: 2.5625rem;
    max-width: 400px;
    width: 100%;
    margin-inline: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.p-under-service-strength__items {
  margin-top: 4.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__items {
    margin-top: 3.5rem;
  }
}

.p-under-service-strength__item {
  padding-block: 1.9375rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.5rem;
  border-bottom: 1px solid var(--color-black-400);
}
.p-under-service-strength__item:first-child {
  border-top: 1px solid var(--color-black-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item {
    padding-block: 1.4375rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.5rem;
  }
}

.p-under-service-strength__item-ttl-wrap {
  width: max(15rem, 192px);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-ttl-wrap {
    width: auto;
    min-width: initial;
  }
}

.p-under-service-strength__item-no {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: max(1.5rem, 19.2px);
  font-size: max(0.875rem, 11.2px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0em;
  color: var(--color-red-400);
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-no {
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-no {
    gap: 1rem;
    -ms-flex-item-align: start;
        align-self: start;
    translate: 0 0.0625rem;
  }
}

.p-under-service-strength__item-sub-ttl {
  margin-top: 0.5rem;
  font-size: max(0.875rem, 11.2px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-sub-ttl {
    font-size: 0.875rem;
  }
}

.p-under-service-strength__item-ttl {
  margin-top: 0.125rem;
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-ttl {
    font-size: 1.25rem;
  }
}

.p-under-service-strength__item-body {
  max-width: 640px;
}

.p-under-service-strength__item-ttl {
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-ttl {
    font-size: 1.25rem;
  }
}

.p-under-service-strength__item-text {
  font-size: max(0.9375rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-strength__item-text {
    font-size: 0.9375rem;
  }
}
.p-under-service-organization {
  padding-block: 5rem 10rem;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization {
    position: relative;
    padding-block: 4rem;
    height: auto;
  }
}

.p-under-service-organization__sentence {
  margin-top: 2rem;
  font-size: max(1.25rem, 16px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization__sentence {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization__sentence {
    margin-top: 1.5rem;
    font-size: max(1.125rem, 14.4px);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767.9px) and (max-width: 767.9px) {
  .p-under-service-organization__sentence {
    font-size: 1.125rem;
  }
}

@media screen and (max-width: 767.9px) {
  .p-under-service-organization__content {
    margin-top: 2rem;
  }
}

.p-under-service-organization__content-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  will-change: transform;
  gap: 2.5rem;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization__content-items {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
  }
}

.p-under-service-organization__content-item {
  max-width: 70rem;
  height: calc(100vh - 12.5rem);
  width: auto !important;
  aspect-ratio: 920/661;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: relative;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization__content-item {
    height: auto;
    max-width: initial;
    width: 100% !important;
    aspect-ratio: initial;
  }
}

.p-under-service-organization__item-img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: auto;
}

.org-wrap {
  position: relative;
}

.p-under-service-organization {
  width: 100%;
}

.p-under-service-organization-inner .org-content {
  max-width: 77.5rem;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization-inner .org-content {
    max-width: 40rem;
    padding-inline: 1.25rem;
    width: 100%;
    margin: 0 auto;
  }
}
.p-under-service-organization-inner .org-content #sidemenu-sticky-end {
  /* position: absolute;
  bottom: 300px;
  left: 0; */
}
.p-under-service-organization-inner .org-content-inner {
  width: 57.5rem;
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization-inner .org-content-inner {
    width: 100%;
  }
}
.p-under-service-organization-inner .p-under-service-organization__content {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization-inner .p-under-service-organization__content {
    -ms-flex-negative: initial;
        flex-shrink: initial;
  }
}
.p-under-service-organization-inner .org-content-wrap {
  overflow: hidden;
  height: 100vh; /* 最小高さを確保 */
  position: sticky;
  left: 0;
  top: 0;
  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) {
  .p-under-service-organization-inner .org-content-wrap {
    position: relative;
    height: auto;
    top: initial;
    -webkit-box-align: initial;
        -ms-flex-align: initial;
            align-items: initial;
    display: block;
  }
}

.p-under-service-organization__item-click-wrap {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  max-width: 77.5rem;
  width: 100%;
  height: auto;
  aspect-ratio: 920/594;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization__item-click-wrap {
    aspect-ratio: 335/442;
  }
}

.p-under-service-organization__item-click-button {
  cursor: pointer;
}
.p-under-service-organization__item-click-button.js-after .p-under-service-organization__item-click-img.--before {
  opacity: 0;
}
.p-under-service-organization__item-click-button.js-after .p-under-service-organization__item-click-img.--after {
  opacity: 1;
}

.p-under-service-organization__item-click-img {
  width: auto;
  height: 83%;
  right: 0;
  bottom: 0;
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  aspect-ratio: 440/493;
  border-radius: 0.5rem;
  -webkit-transition: opacity 0.6s var(--ease-out-quint);
  transition: opacity 0.6s var(--ease-out-quint);
}
.p-under-service-organization__item-click-img.--after {
  opacity: 0;
}
@media screen and (max-width: 767.9px) {
  .p-under-service-organization__item-click-img {
    height: 72%;
  }
}

@media (min-width: 768px) {
  .u-sp {
    display: none !important;
  }
}
@media screen and (max-width: 767.9px) {
  .u-pc {
    display: none !important;
  }
}
@media (width < 1400px) {
  .u-header-pc {
    display: none !important;
  }
}
@media (1400px < width) {
  .u-header-sp {
    display: none !important;
  }
}
.u-font {
  font-family: "Instrument Sans", "Noto Sans JP", sans-serif;
}
.u-font__jp {
  font-family: "Noto Sans JP", sans-serif;
}
.u-font__en {
  font-family: "Instrument Sans", sans-serif;
}

.u-text__center {
  text-align: center !important;
}
@media screen and (max-width: 767.9px) {
  .u-text__center--sp {
    text-align: center !important;
  }
}
@media (min-width: 768px) {
  .u-text__center--pc {
    text-align: center !important;
  }
}

.u-text__left {
  text-align: left !important;
}
@media screen and (max-width: 767.9px) {
  .u-text__left--sp {
    text-align: left !important;
  }
}
@media (min-width: 768px) {
  .u-text__left--pc {
    text-align: left !important;
  }
}

.u-text__right {
  text-align: right !important;
}
@media screen and (max-width: 767.9px) {
  .u-text__right--sp {
    text-align: right !important;
  }
}
@media (min-width: 768px) {
  .u-text__right--pc {
    text-align: right !important;
  }
}

.u-text__nowrap {
  white-space: nowrap;
}
@media screen and (max-width: 767.9px) {
  .u-text__nowrap--sp {
    white-space: nowrap;
  }
}
@media (min-width: 768px) {
  .u-text__nowrap--pc {
    white-space: nowrap;
  }
}

.u-text__capitalize {
  text-transform: capitalize !important;
}
@media screen and (max-width: 767.9px) {
  .u-text__capitalize--sp {
    text-transform: capitalize !important;
  }
}
@media (min-width: 768px) {
  .u-text__capitalize--pc {
    text-transform: capitalize !important;
  }
}

.u-textUp.--rotate .js-arrow1,
.u-textUp.--rotate .js-arrow2 {
  rotate: -45deg;
}

.u-textUp--block {
  overflow: hidden;
  position: relative;
}
.u-textUp--block > *:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
}

.u-animated__fadeIn {
  opacity: 0;
  translate: 0 10px;
  -webkit-transition: opacity 0.6s ease-in-out, translate 1.2s var(--ease-out-quint), -webkit-filter 0.3s ease-in-out;
  transition: opacity 0.6s ease-in-out, translate 1.2s var(--ease-out-quint), -webkit-filter 0.3s ease-in-out;
  transition: opacity 0.6s ease-in-out, filter 0.3s ease-in-out, translate 1.2s var(--ease-out-quint);
  transition: opacity 0.6s ease-in-out, filter 0.3s ease-in-out, translate 1.2s var(--ease-out-quint), -webkit-filter 0.3s ease-in-out;
  -webkit-transition-delay: var(--delay, 0s);
          transition-delay: var(--delay, 0s);
}
@media screen and (max-width: 767.9px) {
  .u-animated__fadeIn {
    -webkit-transition-delay: var(--delay-sp, 0s);
            transition-delay: var(--delay-sp, 0s);
  }
}
.u-animated__fadeIn.js-fadeIn {
  opacity: 1;
  translate: 0;
}