@charset "UTF-8";
/*pagemv-wrap
-------------------------------*/
.pagemv-wrap {
  overflow: hidden;
}
.pagemv-wrap_inner {
  position: relative;
  width: 100%;
  height: 100vh;
  max-height: 720px;
}
.pagemv-backimg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.pagemv-backimg_item {
  position: absolute;
  overflow: hidden;
}
.pagemv-backimg_item img {
  opacity: 0;
  filter: blur(6px) grayscale(1000%);
  transform: scale(1.04);
  animation: pagemvAnime 1s ease-in-out forwards;
}
/* whoweare */
.pagemv-backimg_item.-pagemv001 {
  top: 0;
  left: 0;
  width: 70%;
  height: 480px;
  border-radius: 0 0 8px 0;
}
.pagemv-backimg_item.-pagemv002 {
  top: 0;
  right: 0;
  width: calc(30% - 14px);
  height: 227px;
  border-radius: 0 0 0 8px;
}
.pagemv-backimg_item.-pagemv003 {
  top: 239px;
  left: calc(70% + 14px);
  width: 249px;
  height: 166px;
  border-radius: 8px;
}
.pagemv-backimg_item.-pagemv004 {
  top: 492px;
  left: calc(19% + 12px);
  width: 13%;
  height: 125px;
  border-radius: 8px;
}
.pagemv-backimg_item.-pagemv005 {
  top: 492px;
  left: 0;
  width: 19%;
  height: 228px;
  border-radius: 0 8px 8px 0;
}
.pagemv-backimg_item.-pagemv001 img {
  animation: pagemvAnime 1.4s 0.4s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv002 img {
  animation: pagemvAnime 1.2s 1.25s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv003 img {
  animation: pagemvAnime 1.4s 0.8s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv004 img {
  animation: pagemvAnime 1.2s 1s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv005 img {
  animation: pagemvAnime 1.2s 1.2s ease-in-out forwards;
}
/* business --------------------- */
.pagemv-backimg_item.-pagemv_business001 {
  top: 0;
  left: 0;
  width: 14%;
  height: 202px;
  border-radius: 0 0 8px 0;
}
.pagemv-backimg_item.-pagemv_business002 {
  top: 0;
  left: calc(14% + 12px);
  width: 63%;
  height: 480px;
  border-radius: 0 0 8px 8px;
}
.pagemv-backimg_item.-pagemv_business003 {
  top: 0;
  left: calc(77% + 24px);
  width: calc(23% - 24px);
  height: 138px;
  border-radius: 0 0 0 8px;
}
.pagemv-backimg_item.-pagemv_business004 {
  top: 214px;
  left: 0;
  width: 14%;
  height: 469px;
  border-radius: 0 8px 8px 0;
}
.pagemv-backimg_item.-pagemv_business005 {
  top: 489px;
  left: 0;
  width: 14%;
  height: 194px;
  border-radius: 0 8px 8px 0;
}
.pagemv-backimg_item.-pagemv_business006 {
  top: 489px;
  left: calc(14% + 12px);
  width: 11.5%;
  height: 110px;
  border-radius: 8px;
}
.pagemv-backimg_item.-pagemv_business001 img {
  animation: pagemvAnime 1.4s 0.4s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv_business002 img {
  animation: pagemvAnime 1.8s 0.8s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv_business003 img {
  animation: pagemvAnime 1s 1.25s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv_business004 img {
  animation: pagemvAnime 1.2s 1.4s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv_business005 img {
  animation: pagemvAnime 1.4s 1s ease-in-out forwards;
}
.pagemv-backimg_item.-pagemv_business006 img {
  animation: pagemvAnime 1.15s 1.45s ease-in-out forwards;
}
.pagemv-backimg_item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pagemv_inner {
  position: relative;
  padding-top: clamp(6.75rem, (1vw * 164 / 1440 * 100), 10.25rem);
  padding-left: 8%;
}
.pagemv-title {
  display: inline-block;
  opacity: 0;
  clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
}
@keyframes textareaAnime {
  0% {
    opacity: 0;
    clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
  }
  1% {
    opacity: 1;
    clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}
.pagemv-title.on {
  opacity: 0;
  clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
  animation: textareaAnime 0.9s 1.8s linear forwards;
}
.pagemv-title.-business.on {
  opacity: 0;
  clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
  animation: textareaAnime 1s 2s linear forwards;
}
.pagemv-title.-news.on {
  opacity: 0;
  clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
  animation: textareaAnime 0.4s 0.3s linear forwards;
}
.pagemv-title .en {
  font-size: clamp(
    calc(56 / 16 * 1rem),
    calc(112 / 1440 * 100vw),
    calc(112 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 1;
}
.pagemv-title .en span {
  margin-left: -0.125em;
}
.pagemv-title .ja {
  margin-top: 6px;
  padding-left: 3px;
  display: flex;
  align-items: center;
  font-size: clamp(
    calc(13 / 16 * 1rem),
    calc(18 / 1440 * 100vw),
    calc(18 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  letter-spacing: 0.05em;
  white-space: pre;
}
.pagemv-title .ja::before {
  content: "";
  margin-bottom: -4px;
  display: inline-block;
  margin-right: 0.875rem;
  width: clamp(2.5rem, (1vw * 48 / 1440 * 100), 3rem);
  height: 1px;
  background-color: #fff;
}
/* ----------------------- */
@media (max-width: 576px) {
  .pagemv-wrap_inner {
    width: 126vw;
    height: 60vh;
  }
  .pagemv-backimg_item.-pagemv001 {
    width: 70%;
    height: 265px;
  }
  .pagemv-backimg_item.-pagemv002 {
    top: 0;
    right: 0;
    width: calc(30% - 8px);
    height: 92px;
  }
  .pagemv-backimg_item.-pagemv003 {
    top: 100px;
    left: calc(70% + 8px);
    width: 121px;
    height: 82px;
  }
  .pagemv-backimg_item.-pagemv004 {
    top: 273px;
    left: calc(24.5% + 8px);
    width: 17.5%;
    height: 54px;
  }
  .pagemv-backimg_item.-pagemv005 {
    top: 273px;
    width: 24.5%;
    height: 100px;
  }
  /* business --------------------- */
  .pagemv-wrap_inner.-pagemv_business {
    margin: 0 -2.5vw;
    width: 103vw;
    height: 60vh;
  }
  .pagemv-backimg_item.-pagemv_business001 {
    width: 14%;
    height: 112px;
  }
  .pagemv-backimg_item.-pagemv_business002 {
    left: calc(14% + 12px);
    width: 72%;
    height: 265px;
  }
  .pagemv-backimg_item.-pagemv_business003 {
    top: -10px;
    left: calc(86% + 24px);
    width: calc(14% - 24px);
    height: 112px;
  }
  .pagemv-backimg_item.-pagemv_business004 {
    top: 120px;
    width: 14%;
    height: 285px;
  }
  .pagemv-backimg_item.-pagemv_business005 {
    top: 273px;
    width: 14%;
    height: 132px;
  }
  .pagemv-backimg_item.-pagemv_business006 {
    top: 273px;
    left: calc(14% + 8px);
    width: 29.8%;
    height: 75px;
  }
  .pagemv-title .ja {
    margin-top: 0;
  }
}

/*******************************
pagesection
*******************************/
.pagesection-name {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 1;
  text-transform: uppercase;
}
.pagesection-name span {
  text-transform: lowercase;
}
/*zwhy
-------------------------------*/
section.page-why {
  padding-top: 1rem;
  padding-bottom: clamp(1.5rem, (1vw * 76 / 1440 * 100), 4.75rem);
  overflow: hidden;
}
.zwhy-wrap {
  margin-left: 8.5%;
  display: grid;
  grid-template-columns: 40% 60%;
  grid-template-rows: auto 1fr;
  grid-template-areas:
    "concept1 concept2"
    "concept3 concept2";
}
.zwhy-hading {
  padding-top: clamp(1rem, (1vw * 112 / 1440 * 100), 7rem);
  grid-area: concept1;
}
.zwhy-title {
  padding-left: 10px;
  padding-top: clamp(1rem, (1vw * 24 / 1440 * 100), 1.5rem);
  display: flex;
  align-items: center;
}
.zwhy-title .en {
  width: clamp(4.25rem, (1vw * 100 / 1440 * 100), 6.25rem);
}
.zwhy-title .en img {
  width: 100%;
  height: auto;
}
.zwhy-title .ja {
  padding-left: clamp(1rem, (1vw * 24 / 1440 * 100), 1.5rem);
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(40 / 1440 * 100vw),
    calc(48 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  letter-spacing: 0.05em;
}
.zwhy-copy {
  margin-top: clamp(1.5rem, (1vw * 40 / 1440 * 100), 2.5rem);
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
  font-feature-settings: "palt";
}
.zwhy-zicon {
  margin-left: 12%;
  grid-area: concept2;
  max-width: 460px;
  aspect-ratio: 1;
}
.zwhy-contents {
  grid-area: concept3;
}
/* ----------------------- */
@media (max-width: 768px) {
  section.page-why {
    padding-top: 0;
  }
  .zwhy-wrap {
    margin-left: 0;
    display: block;
  }
  .zwhy-contents {
    margin-top: 4.75rem;
  }
  .zwhy-title {
    padding-left: 0;
  }
  .zwhy-title .en {
    width: 68px;
  }
  .zwhy-title .ja {
    padding-left: 1.25rem;
  }
  .zwhy-zicon {
    margin-top: 2rem;
    margin-right: 9%;
    margin-left: 2%;
  }
}
/*identity
-------------------------------*/
section.page-identity {
  padding-top: clamp(4.5rem, (1vw * 128 / 1440 * 100), 8rem);
  margin-right: 1rem;
  margin-left: 1rem;
}
.identity-wrap {
  position: relative;
  display: flex;
  aspect-ratio: 3.06;
  border-radius: 8px;
  overflow: hidden;
}
.identity-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.identity-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.identity-logo {
  margin: auto;
  position: relative;
  width: 56%;
}
.identity-textarea {
  margin-top: clamp(2.125rem, (1vw * 56 / 1440 * 100), 3.5rem);
  margin-right: auto;
  margin-left: auto;
  padding-bottom: clamp(2.5rem, (1vw * 124 / 1440 * 100), 7.75rem);
  width: 90%;
  max-width: 1010px;
  text-align: center;
  border-bottom: 1px solid var(--gray06);
}
.identity-title {
  font-size: clamp(
    calc(32 / 16 * 1rem),
    calc(42 / 1440 * 100vw),
    calc(42 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 1;
}
.identity-copy {
  margin-top: 1rem;
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
  font-feature-settings: "palt";
}

/* ----------------------- */
@media (max-width: 768px) {
  .identity-wrap {
    aspect-ratio: 0.735;
  }
  .identity-logo {
    width: 86%;
  }
  .identity-textarea {
    display: flex;
    text-align: left;
    border-bottom: none;
  }
  .identity-title {
    padding-right: 8.5%;
  }
  .identity-copy {
    margin-top: -3px;
    line-height: 1.8;
    text-align: justify;
  }
  .identity-copy br {
    display: none;
  }
}
/*philosophy
-------------------------------*/
section.page-philosophy {
  padding-top: clamp(2.75rem, (1vw * 128 / 1440 * 100), 8rem);
  margin-right: 1rem;
  padding-bottom: clamp(3rem, (1vw * 78 / 1440 * 100), 4.875rem);
  margin-left: 1rem;
}
/* philosophy-heading */
.philosophy-heading {
  padding-left: 7%;
  padding-bottom: clamp(2rem, (1vw * 56 / 1440 * 100), 3.5rem);
  display: flex;
}
.philosophy-title {
  margin-right: clamp(1rem, (1vw * 130 / 1440 * 100), 8.12rem);
  font-size: clamp(
    calc(48 / 16 * 1rem),
    calc(74 / 1440 * 100vw),
    calc(74 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 0.9;
}
.philosophy-copy {
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
  font-feature-settings: "palt";
}
/* philosophybnr-list */
.philosophybnr-list {
  display: flex;
  gap: 0 12px;
}
.philosophybnr-list + .philosophybnr-list {
  margin-top: 12px;
}
.philosophybnr-list_item {
  display: flex;
  position: relative;
  height: 320px;
  border-radius: 8px;
  overflow: hidden;
}
.philosophybnr-list_item.-column {
  padding: 2.5rem 0 2rem 36%;
  flex: 0 1 100%;
  height: 400px;
}
.philosophybnr-list_item.-column2 {
  padding: 2.5rem 6% 2rem;
  flex: 0 1 50%;
}
.philosophybnr-list_item.-column3 {
  padding: 2.5rem 2.5rem 1.75rem;
  flex: 1 1 31%;
}
.philosophybnr-list_item picture {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.philosophybnr-list_item picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.philosophybnr-contents {
  margin: auto 0;
  position: relative;
}
.philosophybnr-contents.-value {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.philosophybnr-title {
  padding-left: 3px;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1;
  font-family: var(--googlefont-Instrument);
  text-transform: uppercase;
}
.philosophybnr-copy {
  margin-top: clamp(0.5rem, (1vw * 16 / 1440 * 100), 1rem);
  padding-bottom: 22px;
  font-size: clamp(
    calc(24 / 16 * 1rem),
    calc(32 / 1440 * 100vw),
    calc(32 / 16 * 1rem)
  );
  line-height: 1.4;
  letter-spacing: 0.02em;
}
.slogan-copy {
  margin-top: 0.75rem;
  padding-left: 3px;
  padding-bottom: 36px;
  font-size: clamp(
    calc(48 / 16 * 1rem),
    calc(80 / 1440 * 100vw),
    calc(80 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1;
  letter-spacing: 0.02em;
}
.slogan-copy span {
  display: inline-block;
}
.value-title {
  margin-top: auto;
  font-size: clamp(
    calc(24 / 16 * 1rem),
    calc(32 / 1440 * 100vw),
    calc(32 / 16 * 1rem)
  );
  line-height: 1.4;
  letter-spacing: 0.02em;
}
.philosophybnr-subcopy {
  margin-top: clamp(0.5rem, (1vw * 16 / 1440 * 100), 1rem);
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1.7;
  letter-spacing: 0.03em;
}
/* ----------------------- */
@media (max-width: 768px) {
  section.page-philosophy {
    margin-right: 2%;
    margin-left: 2%;
  }
  /* philosophy-heading */
  .philosophy-heading {
    padding-left: 6.4%;
    display: block;
  }
  .philosophy-copy {
    margin-top: 1.125rem;
  }
  /* philosophybnr-list */
  .philosophybnr-list {
    display: block;
    gap: 0 12px;
  }
  .philosophybnr-list + .philosophybnr-list {
    margin-top: 8px;
  }

  .philosophybnr-list_item + .philosophybnr-list_item {
    margin-top: 8px;
  }
  .philosophybnr-list_item.-column {
    padding: 2.5rem 0 2rem 1.5rem;
    height: 420px;
  }
  .philosophybnr-list_item.-column .philosophybnr-contents {
    margin: 0 0;
  }
  .philosophybnr-list_item.-column2 {
    padding: 2.5rem 0.5rem 2rem 1.5rem;
  }
  .philosophybnr-list_item.-column3 {
    padding: 2.25rem 1.5rem 1.625rem;
  }
  /* ----------- */
  .slogan-copy {
    line-height: 1.1;
  }
}
@media (max-width: 576px) {
  .philosophybnr-list_item {
    height: 180px;
  }
}
/*message
-------------------------------*/
section.page-message {
  padding-top: clamp(4rem, (1vw * 78 / 1440 * 100), 4.875rem);
  padding-bottom: clamp(2rem, (1vw * 78 / 1440 * 100), 4.875rem);
}
.topmessage-wrap {
  display: flex;
  flex-wrap: wrap;
}
.topmessage-mv {
  flex: 0 1 63.5%;
  order: 2;
  aspect-ratio: 1.04096;
  border-radius: 8px 0 0 8px;
  overflow: hidden;
}
.topmessage-mv img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.topmessage-textarea {
  padding-top: clamp(2.5rem, (1vw * 72 / 1440 * 100), 4.5rem);
  flex: 0 1 36.5%;
  order: 1;
}
.topmessage-textarea_inner {
  position: relative;
  margin-left: 41%;
  margin-right: -58%;
  z-index: 10;
}
.topmessage-subimg {
  margin-top: -3rem;
  flex: 0 1 42%;
  order: 3;
}
.topmessage-subimg picture {
  border-radius: 0 8px 8px 0;
  aspect-ratio: 1.502488;
  overflow: hidden;
}
.topmessage-subimg picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.topmessage-subcopyarea {
  padding-top: 100px;
  padding-left: 8.75%;
  flex: 0 1 58%;
  order: 4;
}
/* ----- */
.topmessage-title {
  display: flex;
  align-items: center;
  gap: 0 10px;
}
.topmessage-title .en {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 1;
  text-transform: uppercase;
}
.topmessage-title .ja {
  color: var(--text-gray2);
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(14 / 1440 * 100vw),
    calc(14 / 16 * 1rem)
  );
  letter-spacing: 0.04em;
}
.topmessage-subtitle {
  margin-top: clamp(1.375rem, (1vw * 56 / 1440 * 100), 3.5rem);
  padding-bottom: clamp(1.75rem, (1vw * 44 / 1440 * 100), 2.75rem);
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(36 / 1440 * 100vw),
    calc(36 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  letter-spacing: 0.03em;
}
.topmessage-copy {
  max-width: 596px;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
  text-align: justify;
}
.topmessage-copy + .topmessage-copy {
  margin-top: clamp(1rem, (1vw * 40 / 1440 * 100), 2.5rem);
}
.topmessage-copy.-last {
  max-width: 494px;
}
/* ----------------------- */
@media (max-width: 1200px) {
  .topmessage-textarea_inner {
    margin-left: 30%;
  }
  .topmessage-subimg {
    margin-top: 3rem;
  }
  .topmessage-subcopyarea {
    padding-right: 5%;
    padding-left: 5%;
  }
}
@media (max-width: 768px) {
  .topmessage-wrap {
    display: block;
  }
  .topmessage-mv {
    margin-right: 6.4%;
    aspect-ratio: 0.777;
    border-radius: 0 8px 8px 0;
  }
  .topmessage-textarea {
    padding-top: 0;
  }
  .topmessage-textarea_inner {
    margin-top: -4rem;
    padding: 0 6.4%;
    margin-left: 0;
    margin-right: 0;
  }
  .topmessage-subimg {
    margin: 2.5rem 2.2% 0;
  }
  .topmessage-subimg picture {
    aspect-ratio: 1.50209;
    border-radius: 8px 8px 8px 8px;
  }
  .topmessage-subcopyarea {
    padding-top: 2rem;
    padding-right: 6.4%;
    padding-left: 6.4%;
  }
}
/*profile
-------------------------------*/
section.page-profile {
  padding-top: clamp(1.75rem, (1vw * 64 / 1440 * 100), 4rem);
  padding-bottom: clamp(2.5rem, (1vw * 64 / 1440 * 100), 4rem);
}
.profile-box {
  margin: 0 auto;
  display: flex;
  max-width: 1004px;
}
.profile-box + .profile-box {
  margin-top: clamp(4rem, (1vw * 80 / 1440 * 100), 5rem);
}
.profile-title {
  flex: 0 1 10%;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 1;
  text-transform: uppercase;
}
.profile-contents {
  margin-top: -5px;
  flex: 0 1 90%;
}
.profile-name {
  margin-top: -3px;
  display: flex;
  align-items: center;
  gap: 0 20px;
  font-size: clamp(
    calc(18 / 16 * 1rem),
    calc(20 / 1440 * 100vw),
    calc(20 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  letter-spacing: 0.03em;
}
.profile-name .en {
  padding-top: 5px;
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  text-transform: uppercase;
}
.profile-copy {
  margin-top: clamp(0.75rem, (1vw * 20 / 1440 * 100), 1.25rem);
  padding-bottom: clamp(1rem, (1vw * 28 / 1440 * 100), 1.75rem);
  max-width: 610px;
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(14 / 1440 * 100vw),
    calc(14 / 16 * 1rem)
  );
  line-height: 1.7;
  letter-spacing: 0.03em;
}
.profile-copy span {
  display: inline-block;
}
.profile-dl {
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(14 / 1440 * 100vw),
    calc(14 / 16 * 1rem)
  );
  line-height: 1.7;
  letter-spacing: 0.03em;
}
.profile-dl dt {
  padding-bottom: 0.125rem;
}
/* booklink-list_item */
.booklink-list_item + .booklink-list_item {
  margin-top: 12px;
}
.booklink-list_item a {
  padding: 8px;
  max-width: 802px;
  display: flex;
  align-items: center;
  gap: 0 24px;
  text-decoration: none;
  border-radius: 8px;
  background-color: var(--gray07);
  transition: 0.25s ease-in-out;
}
.booklink-list_item a picture {
  flex-shrink: 0;
  width: 64px;
}
.booklink-title {
  flex-grow: 1;
  flex-shrink: 1;
  font-size: clamp(
    calc(13 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1.7;
  letter-spacing: 0.01em;
}
.booklink-title span {
  display: block;
  font-size: clamp(
    calc(10 / 16 * 1rem),
    calc(14 / 1440 * 100vw),
    calc(14 / 16 * 1rem)
  );
}
/* booklink-arrow  */
.booklink-list_item a .booklink-arrow {
  flex-shrink: 0;
  margin: auto 1rem;
  display: inline-block;
  position: relative;
  width: 28px;
  height: 28px;
  border-radius: 100%;
  border: 1px solid var(--gray04);
  overflow: hidden;
}
.booklink-list_item a .booklink-arrow::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url(../images/icon-arrow-w.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 40% 40%;
  transform: rotate(-45deg);
  transition: 0.25s ease-in-out;
}
.booklink-list_item a .booklink-arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -50%;
  width: 100%;
  height: 100%;
  background-image: url(../images/icon-arrow-w.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 40% 40%;
  transform: rotate(-45deg);
  opacity: 0;
  transition: 0.25s 0.1s ease-in-out;
}
@media (hover: hover) {
  .booklink-list_item a:hover {
    background-color: var(--gray08);
  }
  .booklink-list_item a:hover .booklink-arrow::before {
    top: -50%;
    left: 50%;
  }
  .booklink-list_item a:hover .booklink-arrow::after {
    top: 0;
    left: 0;
    opacity: 1;
  }
}
/* ----------------------- */
@media (max-width: 768px) {
  .profile-box {
    display: block;
  }
  .profile-contents {
    margin-top: 1.75rem;
  }
  .profile-dl dt {
    padding-bottom: 0;
  }
  .booklink-list_item a .booklink-arrow {
    margin: auto 8px auto 0;
  }
  .booklink-title {
    line-height: 1.6;
    letter-spacing: 0em;
  }
  .booklink-title span {
    margin-top: 4px;
  }
}
/* -------------------------------*/
/* PAGE / our business
-------------------------------*/
section.page-flow {
  padding-bottom: clamp(5rem, (1vw * 160 / 1440 * 100), 10rem);
  padding-right: 2.8%;
  padding-left: 2.8%;
}
.l-business-list {
  margin-top: 10rem;
  display: grid;
  grid-template-columns: 11fr 87fr;
  grid-template-rows: auto 1fr;
  grid-column-gap: 24px;
  grid-row-gap: 9.5rem;
  grid-template-areas:
    "business2 business1"
    "business2 business3";
}
.l-business_intro {
  grid-area: business1;
}
.l-business_linkarea {
  grid-area: business2;
}
.l-business_linkarea_inner {
  position: -webkit-sticky;
  position: sticky;
  top: 8rem;
}
/* page-anchorlink-list */
.page-anchorlink-list_item a {
  margin-left: -3px;
  margin-bottom: 0.625rem;
  padding-left: 11px;
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  font-size: calc(14 / 16 * 1rem);
  letter-spacing: 0.03em;
  text-decoration: none;
}
.page-anchorlink-list_item a::before {
  content: "";
  position: absolute;
  display: inline-block;
  top: 9px;
  left: 0;
  width: 4px;
  height: 4px;
  border-radius: 100%;
  background-color: #fff;
  opacity: 0;
  transition: 0.25s ease-in-out;
}
.page-anchorlink-list_item a.active::before {
  opacity: 1;
}
.anchorlink-arrow {
  margin-left: 8px;
  display: inline-block;
  position: relative;
  width: 10px;
  height: 14px;
  background-image: url(../images/page/icon-anchorlink.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
@media (hover: hover) {
  .page-anchorlink-list_item a:hover::before {
    opacity: 0.4;
  }
}
.l-business_details {
  margin-top: -15rem;
  grid-area: business3;
}
.bl_section {
  margin-top: -5.5rem;
  padding-top: 5.5rem;
}
/* business contents */
.topbusiness-wrap {
  display: flex;
  gap: 0 1rem;
}
.topbusiness-textarea {
  flex: 0 1 28.5%;
}
.topbusiness-imgarea {
  position: relative;
  flex: 0 1 66%;
  max-width: 790px;
  transform: translateY(-30%);
}
.topbusiness-imgarea .topbusiness-imgarea_item {
  opacity: 0;
  transition: 0.6s ease-in-out;
}
.topbusiness-imgarea .topbusiness-imgarea_item.field {
  position: relative;
  width: 100%;
  height: auto;
}
.topbusiness-imgarea .topbusiness-imgarea_item.field2,
.topbusiness-imgarea .topbusiness-imgarea_item.field3,
.topbusiness-imgarea .topbusiness-imgarea_item.field4,
.topbusiness-imgarea .topbusiness-imgarea_item.field5 {
  position: absolute;
  top: 0;
  left: -10px;
  width: 100%;
  opacity: 0;
  filter: blur(3px);
}
.topbusiness-imgarea .topbusiness-imgarea_item.field2 {
  transition-delay: 0.2s;
}
.topbusiness-imgarea .topbusiness-imgarea_item.field3 {
  transition-delay: 0.35s;
}
.topbusiness-imgarea .topbusiness-imgarea_item.field4 {
  transition-delay: 0.5s;
}
.topbusiness-imgarea .topbusiness-imgarea_item.field5 {
  transition-delay: 0.5s;
}
.topbusiness-imgarea.on .topbusiness-imgarea_item {
  top: 0;
  left: 0;
  opacity: 1;
  filter: blur(0);
}
.topbusiness-imgarea picture img {
  width: 100%;
  height: auto;
}
.topbusiness-semititle {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 1;
  text-transform: uppercase;
}
.topbusiness-title {
  margin-top: 2rem;
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(48 / 1440 * 100vw),
    calc(48 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1;
  letter-spacing: 0.05em;
}
.topbusiness-copy {
  margin-top: 3rem;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
}
.topbusiness-copy span {
  display: block;
}
/* business contents */
.step-wrap {
  margin-top: clamp(4.75rem, (1vw * 104 / 1440 * 100), 6.5rem);
  display: flex;
  align-items: flex-start;
}
.step-wrap.-first {
  margin-top: 0;
}
.step-heading {
  padding-top: 12px;
  margin-left: -100px;
  flex: 0 1 35%;
  display: flex;
  align-items: center;
}
.step-num {
  margin-right: 20px;
  display: inline-block;
  width: 80px;
  height: 80px;
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(32 / 1440 * 100vw),
    calc(32 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  line-height: 80px;
  letter-spacing: 0.05em;
  text-align: center;
  border-radius: 100%;
  border: 1px solid #fff;
}
.step-semititle {
  display: block;
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(14 / 1440 * 100vw),
    calc(14 / 16 * 1rem)
  );
  font-family: var(--googlefont-Instrument);
  text-transform: uppercase;
}
.step-title {
  margin-top: 0.25rem;
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(40 / 1440 * 100vw),
    calc(40 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1;
  letter-spacing: 0.05em;
}
/* step-details */
.step-details {
  flex: 0 1 67%;
  max-width: 700px;
}
.stepdetails-title {
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(36 / 1440 * 100vw),
    calc(36 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  letter-spacing: 0.05em;
}
.stepdetails-title span {
  display: inline-block;
}
.stepdetails-copy {
  margin-top: clamp(0.875rem, (1vw * 24 / 1440 * 100), 1.5rem);
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
}
.step-box {
  margin-top: clamp(1.625rem, (1vw * 40 / 1440 * 100), 2.5rem);
  padding: 2rem 4.6% 2.25rem;
  color: #000;
  background-color: #fff;
  border-radius: 8px;
}
.stepbox-title {
  font-size: clamp(
    calc(16 / 16 * 1rem),
    calc(18 / 1440 * 100vw),
    calc(18 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  letter-spacing: 0.03em;
}
.step-list + .stepbox-title {
  padding-top: 1.5rem;
  margin-top: 1.5rem;
  border-top: 1px solid #b5bcc0;
}
.step-list {
  margin-top: 0.5rem;
  padding-left: 6px;
}
.step-list_item {
  padding-left: 1em;
  position: relative;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
}
.step-list_item::before {
  content: "・";
  position: absolute;
  top: 0px;
  left: 2px;
}
.method-list {
  margin-top: 0.5rem;
  display: flex;
  gap: 0 1rem;
}
.method-list_item {
  width: 190px;
  display: flex;
  align-items: center;
}
.method-list_item .icon {
  margin-right: 8px;
  flex-shrink: 0;
}
.method-list_item .icon img {
  width: 56px;
  height: auto;
}
.method-list_item p {
  font-size: clamp(
    calc(12 / 16 * 1rem),
    calc(14 / 1440 * 100vw),
    calc(14 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.3;
  letter-spacing: 0.03em;
}
.method-list_item p span {
  display: inline-block;
}
/* ----------------------- */
@media (max-width: 768px) {
  section.page-flow {
    padding-right: 0;
    padding-left: 0;
  }
  .topbusiness-textarea {
    padding-left: 6.4%;
    padding-bottom: 2rem;
  }
  .topbusiness-wrap {
    display: block;
  }
  .topbusiness-copy {
    margin-top: 3.25rem;
  }
  .topbusiness-imgarea {
    transform: translateY(0);
  }
  .topbusiness-imgarea .topbusiness-imgarea_item.field2,
  .topbusiness-imgarea .topbusiness-imgarea_item.field3,
  .topbusiness-imgarea .topbusiness-imgarea_item.field4,
  .topbusiness-imgarea .topbusiness-imgarea_item.field5 {
    position: absolute;
    top: -10px;
    left: 0;
  }
  .topbusiness-imgarea.on .topbusiness-imgarea_item {
    top: 0;
    left: 0;
    opacity: 1;
    filter: blur(0);
  }
  .l-business-list {
    margin-top: 5.125rem;
    display: block;
  }
  .l-business_linkarea {
    margin-top: 2rem;
    padding-left: 6.4%;
    width: 100%;
  }
  .l-business_linkarea_inner {
    top: 5rem;
  }
  .l-business_details {
    margin-top: 0;
    padding-top: 4rem;
    padding-right: 6.4%;
    padding-left: 6.4%;
    /* padding-bottom: 14rem; */
    /* margin-left: -100%; */
    width: 100%;
  }

  .step-heading {
    margin-left: 0;
    justify-content: center;
  }
  .step-num {
    margin-right: 14px;
    width: 64px;
    height: 64px;
    line-height: 64px;
  }
  .stepdetails-title {
    margin-top: 1.75rem;
    text-align: center;
    white-space: pre;
  }
  .stepdetails-title span {
    display: block;
  }
  .stepdetails-copy {
    line-height: 1.8;
  }
  .step-box {
    padding: 1.125rem 4.6% 1.5rem;
  }
  .step-list {
    margin-top: 0.375rem;
  }
  .step-list + .stepbox-title {
    padding-top: 1rem;
    margin-top: 1rem;
  }
  .step-list_item {
    line-height: 1.5;
  }
  .step-list_item:not(:first-child) {
    margin-top: 6px;
  }
  .step-wrap {
    display: block;
  }
  .method-list {
    margin-top: 0.25rem;
    display: block;
  }
  .method-list_item {
    width: auto;
    align-items: center;
  }
  .method-list_item .icon img {
    width: 40px;
  }
}
/* -------------------------------*/
/* PAGE / people
-------------------------------*/
.peoplemv-wrap {
  overflow: hidden;
}
.peoplemv_inner {
  margin: 0 -5vw;
  width: 107vw;
}
.peoplemv-backimg {
  display: flex;
}
.peoplemv-backimg_item {
  aspect-ratio: 0.69;
  overflow: hidden;
}
.peoplemv-backimg_item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  filter: blur(6px);
  transform: scale(1.01);
}
@keyframes peoplemvAnime {
  0% {
    opacity: 0;
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    filter: blur(0);
  }
}
.peoplemv01 img {
  animation: peoplemvAnime 1.4s 0.15s ease-in-out forwards;
}
.peoplemv02 img {
  animation: peoplemvAnime 1.25s 0.5s ease-in-out forwards;
}
.peoplemv03 img {
  animation: peoplemvAnime 1.25s 0.25s ease-in-out forwards;
}
.peoplemv04 img {
  animation: peoplemvAnime 1.25s 0.4s ease-in-out forwards;
}
.peoplemv-textarea {
  margin-top: -20px;
  margin-left: 7.8%;
  position: relative;
  display: inline-block;
  opacity: 0;
  clip-path: polygon(0 0, 1% 0, 1% 100%, 0% 100%);
}
.peoplemv-textarea.on {
  animation: textareaAnime 0.8s 1.2s ease-in-out forwards;
}
.peoplemv-maincopy {
  margin-top: -11px;
  display: inline-block;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(48 / 1440 * 100vw),
    calc(48 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  letter-spacing: 0.05em;
}
.peoplemv-maincopy span {
  background-color: #000;
}
.peoplemv-maincopy span br {
  display: none;
}
.peoplemv-title {
  margin-top: clamp(1rem, (1vw * 24 / 1440 * 100), 1.5rem);
  display: flex;
  align-items: flex-end;
}
.peoplemv-title .ja {
  margin-right: 1rem;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(18 / 1440 * 100vw),
    calc(18 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
}
.peoplemv-title .career {
  color: var(--text-gray2);
  font-size: clamp(
    calc(11 / 16 * 1rem),
    calc(13 / 1440 * 100vw),
    calc(13 / 16 * 1rem)
  );
}
/* section.page-interview --------------------- */
section.page-interview {
  padding-top: clamp(4.25rem, (1vw * 144 / 1440 * 100), 9rem);
  overflow: hidden;
}
.interview-box {
  margin: 0 7.8%;
  display: grid;
  grid-template-columns: 4fr 1fr 7fr;
  grid-column-gap: 10px;
  grid-template-areas: "interview1 . interview2";
}
.interview-box.-last {
  padding-bottom: clamp(4rem, (1vw * 156 / 1440 * 100), 9.75rem);
  border-bottom: 1px solid var(--gray06);
}
.interview-box + .interview-box {
  margin-top: clamp(4.75rem, (1vw * 100 / 1440 * 100), 6.25rem);
}
.interview-title {
  grid-area: interview1;
  font-size: clamp(
    calc(26 / 16 * 1rem),
    calc(38 / 1440 * 100vw),
    calc(38 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  letter-spacing: 0.03em;
}
.interview-details {
  padding-top: 8px;
  grid-area: interview2;
}
.interview-img {
  margin-top: clamp(1.25rem, (1vw * 36 / 1440 * 100), 2.25rem);
}
.interview-img picture {
  aspect-ratio: 1.77863;
  border-radius: 8px;
  overflow: hidden;
}
.interview-img picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.interview-copy {
  grid-area: interview1;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.05em;
  text-align: justify;
}
.interview-insertimg {
  margin-top: clamp(1.25rem, (1vw * 104 / 1440 * 100), 6.5rem);
  margin-right: 1rem;
  margin-left: 1rem;
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 2.2015625;
}
.interview-insertimg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.interview-insertimg + .interview-box {
  margin-top: clamp(4.25rem, (1vw * 100 / 1440 * 100), 6.25rem);
}
/* section.page-others --------------------- */
section.page-others {
  padding-top: clamp(5rem, (1vw * 112 / 1440 * 100), 7rem);
  padding-right: 7.6%;
  padding-bottom: clamp(4rem, (1vw * 78 / 1440 * 100), 4.875rem);
  padding-left: 7.6%;
}
/* otherspost-list */
.otherspost-list {
  margin-top: clamp(1.675rem, (1vw * 50 / 1440 * 100), 3.125rem);
  display: flex;
  gap: 0 1.5rem;
}
.otherspost-list_item {
  flex: 0 1 31%;
}
.otherspost-list_item a {
  display: block;
  color: #fff;
  text-decoration: none;
}
.otherspost-wrap picture {
  position: relative;
  aspect-ratio: 0.778;
  border-radius: 12px;
  overflow: hidden;
}
.otherspost-wrap picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.3s ease-in-out;
}
@media (hover: hover) {
  a:hover .otherspost-wrap picture img {
    transform: scale(1.04);
  }
}
.otherspost-textarea {
  margin-top: 1.25rem;
  padding: 0 8px;
}
.otherspost-title {
  font-size: clamp(
    calc(20 / 16 * 1rem),
    calc(28 / 1440 * 100vw),
    calc(28 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  font-feature-settings: "palt";
  white-space: pre;
}
.otherspost-profile {
  margin-top: 1rem;
  padding-bottom: 1rem;
  display: flex;
  align-items: flex-end;
  /* color: var(--text-gray); */
  font-feature-settings: "palt";
}
.otherspost-profile .name {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(18 / 1440 * 100vw),
    calc(18 / 16 * 1rem)
  );
}
.otherspost-profile .career {
  margin-left: 1rem;
  font-size: clamp(
    calc(11 / 16 * 1rem),
    calc(13 / 1440 * 100vw),
    calc(13 / 16 * 1rem)
  );
}
.otherspost-textarea .c-arrow {
  margin-top: 0.75rem;
  opacity: 0.6;
}
/* ------------------------------- */
@media (max-width: 991.98px) {
  .peoplemv_inner {
    margin: 0 -5vw;
    width: 110vw;
  }
  .peoplemv-backimg {
    aspect-ratio: 1.25;
  }
  .peoplemv-backimg_item.-spnone,
  .peoplemv-backimg_item.-spnone {
    display: none;
  }
  .peoplemv-textarea {
    margin-top: -24px;
    margin-left: 6.4%;
  }
  .peoplemv-maincopy {
    margin-top: -6px;
  }
  .peoplemv-maincopy span br {
    display: block;
  }
  /* interview-box */
  .interview-box {
    margin: 0 6.4%;
    display: block;
  }
  .interview-details {
    margin-top: 0.5rem;
  }
  .interview-img {
    width: 100vw;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
  }
  .interview-img picture {
    margin: 0 4%;
    aspect-ratio: 1.78607;
  }
  .interview-insertimg {
    margin-right: 0;
    margin-left: 0;
    border-radius: 0;
    aspect-ratio: 0.75;
  }
  /* otherspost-list */
  section.page-others {
    padding-right: 2%;
    padding-left: 2%;
  }
  .otherspost-list {
    padding: 0 8px;
    flex-direction: column;
    gap: 2rem 0;
  }
  .otherspost-wrap picture {
    aspect-ratio: 1.502;
    border-radius: 6px;
  }
  .otherspost-textarea {
    margin-top: 1.5rem;
    padding: 0 1rem;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: 1fr auto;
    grid-column-gap: 20px;
    grid-template-areas:
      "otherspost1 otherspost3"
      "otherspost2 otherspost2";
  }
  .otherspost-title {
    grid-area: otherspost1;
  }
  .otherspost-profile {
    grid-area: otherspost2;
    margin-top: 0.5rem;
    color: var(--text-gray);
    padding-bottom: 0;
  }
  .otherspost-textarea .c-arrow {
    grid-area: otherspost3;
  }
}
/*******************************
informations
*******************************/
/*infopost
-------------------------------*/
section.page-infopost {
  padding-top: clamp(6.75rem, (1vw * 208 / 1440 * 100), 13rem);
  padding-bottom: 2rem;
}
/* .l-subpage-wrap */
.l-subpage-wrap {
  display: grid;
  grid-template-columns: 3fr 8fr 1fr;
}
.l-subpage-postarea {
  padding-top: 1rem;
  padding-left: 1%;
}
/*pagenation*********************/
.pagenation-outer {
  padding-top: clamp(2.5rem, (1vw * 64 / 1440 * 100), 4rem);
}
.pagenation_single-outer {
  padding-top: clamp(1rem, (1vw * 38 / 1440 * 100), 2.375rem);
  border-top: 1px solid var(--gray06);
}
.pagenation {
  margin: auto 0;
  text-align: center;
}
.pagenation ul {
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 4px;
}
.pagenation.-single ul {
  gap: 0 108px;
}
.pagenation li {
  flex-shrink: 0;
  display: block;
  width: 48px;
  height: 48px;
}
.pagenation li a {
  flex-shrink: 0;
  display: block;
  width: 48px;
  height: 48px;
  color: #fff;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 46px;
  text-align: center;
  text-decoration: none;
}
.pagenation li.active {
  flex-shrink: 0;
  position: relative;
  display: block;
  width: 48px;
  height: 48px;
  color: #fff;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 46px;
  text-align: center;
  border-radius: 100%;
  border: 1px solid #fff;
  overflow: hidden;
  cursor: not-allowed;
}
.pagenation li.active::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #f3f3f4;
  opacity: 0.12;
}
.pagenation li a:hover {
  opacity: 0.4;
}

.btn_pagenation {
  display: inline-block;
  width: 48px;
  height: 48px;
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.c-prev {
  background-image: url(../images/icon-prev.svg);
}
.c-next {
  background-image: url(../images/icon-next.svg);
}
.c-first {
  background-image: url(../images/icon-first.svg);
}
.c-last {
  background-image: url(../images/icon-last.svg);
}
.c-archive {
  background-image: url(../images/icon-archive.svg);
}
@media (max-width: 768px) {
  .l-subpage-wrap {
    display: block;
  }
  .l-subpage-postarea {
    padding-top: 1.5rem;
    padding-left: 0;
  }
  /* pagenation */
  .pagenation .-pcnone {
    display: none;
  }
}
/*******************************
informations single
*******************************/
/*infopost
-------------------------------*/
section.page-infopost_single {
  padding-top: clamp(6.75rem, (1vw * 240 / 1440 * 100), 15rem);
  padding-bottom: 0.5rem;
}
.infopost-single_inner {
  width: min(84.444444%, 1010px);
  margin: 0 auto;
}
/* .infopost-heading */
.infopost-details {
  display: flex;
  align-items: center;
}
.infopost-heading .day {
  flex-shrink: 0;
  margin-right: 1rem;
  font-size: calc(14 / 16 * 1rem);
  line-height: 26px;
  letter-spacing: 0.03em;
}
.infopost-heading .category {
  flex-shrink: 0;
  margin-right: 1.75rem;
  width: 113px;
  height: 28px;
  font-size: calc(12 / 16 * 1rem);
  font-family: var(--fontplus-TsukushiB);
  line-height: 25px;
  text-align: center;
  border-radius: 2.5rem;
  border: 1px solid #fff;
}
.infopost-title {
  margin-top: clamp(2.5rem, (1vw * 56 / 1440 * 100), 3.5rem);
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(32 / 1440 * 100vw),
    calc(32 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  letter-spacing: 0.03em;
  font-feature-settings: normal;
}
/* .infopost-contents */
.infopost-contents {
  padding-top: clamp(1.5rem, (1vw * 36 / 1440 * 100), 2.25rem);
  padding-bottom: clamp(1.5rem, (1vw * 104 / 1440 * 100), 6.5rem);
  font-feature-settings: normal;
}
.infopost-contents p {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: justify;
}
.infopost-contents a {
  text-decoration: underline;
  text-underline-offset: 4px;
}
@media (max-width: 768px) {
  section.page-infopost_single {
    padding-bottom: 7rem;
  }
  .infopost-single_inner {
    width: 87.2%;
  }
  /* pagenation */
  .pagenation.-single ul {
    gap: 0 8px;
  }
}
/*******************************
contact
*******************************/
/*contact
-------------------------------*/
section.page-contact {
  padding-top: clamp(6.75rem, (1vw * 208 / 1440 * 100), 13rem);
  padding-bottom: 2.5rem;
}
/* .l-contactpage-wrap */
.l-contactpage-wrap {
  display: grid;
  grid-template-columns: 4fr 8fr;
}
.l-contactpage-postarea {
  padding-top: 5px;
  padding-left: 1%;
}
.formpage-copy {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1.8;
  letter-spacing: 0;
  font-feature-settings: normal;
}
@media (max-width: 768px) {
  .l-contactpage-wrap {
    display: block;
  }
  .l-contactpage-postarea {
    padding-top: 3.5rem;
    padding-left: 0;
  }
  .infopost-single_inner {
    width: 87.2%;
  }
  /* pagenation */
  .pagenation.-single ul {
    gap: 0 8px;
  }
}
/*confirm
-------------------------------*/
section.page-confirm {
  padding-top: clamp(6.75rem, (1vw * 208 / 1440 * 100), 13rem);
  padding-bottom: 4.5rem;
}
/*thankspage
-------------------------------*/
section.page-thanks {
  padding-top: clamp(11rem, (1vw * 272 / 1440 * 100), 17rem);
  padding-bottom: 6rem;
}
.thankspage-title {
  font-size: clamp(
    calc(28 / 16 * 1rem),
    calc(32 / 1440 * 100vw),
    calc(32 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  line-height: 1.4;
  letter-spacing: 0.03em;
  text-align: center;
  font-feature-settings: normal;
}
.thankspage-copy {
  padding-top: 2rem;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1.8;
  text-align: center;
  font-feature-settings: normal;
}
.thankspage-title span,
.thankspage-copy span {
  display: inline-block;
}
@media (max-width: 768px) {
  section.page-thanks {
    padding-bottom: 8.5rem;
  }
  .thankspage-copy span {
    display: block;
  }
}
/*policy
-------------------------------*/
section.page-policy {
  padding-top: clamp(6.75rem, (1vw * 208 / 1440 * 100), 13rem);
  padding-bottom: 4.5rem;
}
.policy-postarea_inner {
  max-width: 700px;
}
.policy-copy {
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 1.8;
  font-feature-settings: normal;
}
.policy-contents-box {
  padding-top: clamp(2.875rem, (1vw * 60 / 1440 * 100), 3.75rem);
}
.policy-dl + .policy-dl {
  margin-top: clamp(1.625rem, (1vw * 44 / 1440 * 100), 2.75rem);
}
.policy-dl dt {
  display: flex;
}
.policy-dl dt .num {
  padding: 0 0.25em 0 0.25rem;
  font-size: clamp(
    calc(18 / 16 * 1rem),
    calc(24 / 1440 * 100vw),
    calc(24 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  letter-spacing: 0.05em;
}
.policy-dl_title {
  font-size: clamp(
    calc(18 / 16 * 1rem),
    calc(24 / 1440 * 100vw),
    calc(24 / 16 * 1rem)
  );
  font-family: var(--fontplus-TsukushiB);
  letter-spacing: 0.05em;
}
.policy-dl_copy {
  margin-top: 0.875rem;
  font-size: clamp(
    calc(14 / 16 * 1rem),
    calc(16 / 1440 * 100vw),
    calc(16 / 16 * 1rem)
  );
  line-height: 2.1;
  letter-spacing: 0.03em;
}
@media (max-width: 768px) {
  .policy-copy {
    letter-spacing: 0.05em;
  }
  .policy-dl_copy {
    line-height: 1.8;
    letter-spacing: 0.05em;
  }
}
