﻿@charset "UTF-8";

/* ========================================================
                      * Variable *
========================================================= */
:root {
  --pw: 1600; /* PC幅 */
  --sw: 750; /* SP幅 */
  --artboard-pw: 500; /* PCアートボード幅 */
  --artboard-sw: 750; /* SPアートボード幅 */
  --rem: calc(var(--variable) * var(--ratio));
  --rem-pc: var(--variable);
  --transition-timing: cubic-bezier(0.51, 0.21, 0.41, 1);

  --base-font-color: #000;
  --color-accent: #7fa9d3;

  --lp-font-ja: "Roboto", hiragino-kaku-gothic-pron, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
  --lp-font-en: "century-gothic", hiragino-kaku-gothic-pron, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
  --lp-font-rn: helvetica-lt-pro, hiragino-kaku-gothic-pron, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;

  --icon-arrow-down: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2021.25%2010.06%22%3E%3Cpath%20d%3D%22m.62.78%2010%208%2010-8%22%20style%3D%22fill%3Anone%3Bstroke%3A%23000%3Bstroke-miterlimit%3A10%3Bstroke-width%3A2px%22%2F%3E%3C%2Fsvg%3E');
}

@media (768px <= width) {
  :root {
    --ratio: calc(var(--artboard-pw) / var(--artboard-sw));
    --variable: calc(100vw / var(--pw));
  }
}
@media (1600px <= width) {
  :root {
    --variable: 1px;
  }
}
@media (width < 768px) {
  :root {
    --ratio: 1;
    --variable: calc(100vw / var(--sw));
  }
}

/* ========================================================
                      * Layout style *
========================================================= */
html {
  /* scroll-behavior: smooth; */
  font-size: 62.5%
}
main {
  max-width: 100%;
}

@media (768px <= width) {
  #Wrap,
  .wrapBottom,
  .wrapTop,
  #Contents {
    width: 100%;
  }
}
#FooterWrap {
  position: relative;
}


/* ===================
  Animation
=================== */
.fade {
  opacity: 0;
  transition: opacity 2s var(--transition-timing);
  &.is-active {
    opacity: 1;
  }
}
.fade-up {
  --transition-timing: ease;
  opacity: 0;
  translate: 0 calc(50 * var(--rem));
  transition:
    opacity 2s var(--transition-timing),
    translate 2s var(--transition-timing);
  &.is-active {
    opacity: 1;
    translate: 0 0;
  }
}
.clip-anim {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.8s var(--transition-timing);
  &.is-active {
    clip-path: inset(0 0 0 0);
  }
}
.float-anim {
  --distance: 10;
  transform: translateY(calc(10 * var(--rem)));
  animation: FloatVertical 6s var(--delay, 0s) ease-in-out infinite alternate;
  /* animation-delay: var(--delay, 0s); */
}


/* keyframes */
@keyframes FloatVertical {
  0% {
    transform: translateY(calc(var(--distance) * var(--rem)));
  }
  50% {
    transform: translateY(calc((-1 * var(--distance)) * var(--rem)));
  }
  100% {
    transform: translateY(calc(var(--distance) * var(--rem)));
  }
}

@keyframes floatY {
  0% {
    transform: translateY(calc(-10 * var(--rem)));
  }
  50% {
    transform: translateY(calc(10 * var(--rem)));
  }
  100% {
    transform: translateY(calc(-10 * var(--rem)));
  }
}
@keyframes floatY2 {
  0% {
    transform: translateY(calc(10 * var(--rem)));
  }
  50% {
    transform: translateY(calc(-10 * var(--rem)));
  }
  100% {
    transform: translateY(calc(10 * var(--rem)));
  }
}


/* ===================
  LP Contents
=================== */
.lp_contents {
  --letter-spacing: 0.1em;
  position: relative;
  background: var(--lp-background-color, transparent);
  font-family: var(--lp-font-ja);
  color: var(--base-font-color, #000);
  font-size: calc(24 * var(--rem));
  font-style: normal;
  letter-spacing: var(--letter-spacing);
  & * {
    font-feature-settings: "palt";
  }
  & *,
  & *:before,
  & *:after {
    box-sizing: border-box;
  }
  & :where(h1, h2, h3, h4, h5, p, ul, ol, li, dl, dt, dd, a, button, figure, figcaption, span, sup) {
    margin: 0;
    padding: 0;
    font-family: inherit;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: var(--letter-spacing);
  }
  & ul,
  & li {
    list-style: none;
  }
  & :where(img) {
    display: block;
    max-width: 100%;
    height: auto;
  }
  & sup {
    top: 0;
    font-size: .6em;
    vertical-align: super;
  }
  & :where(a, a:before, a:after, a img, button) {
    --duration: .3s;
    --timing: ease-in-out;
    transition:
      opacity var(--duration) var(--timing),
      color var(--duration) var(--timing),
      background-color var(--duration) var(--timing),
      background-image var(--duration) var(--timing),
      border-color var(--duration) var(--timing),
      text-shadow var(--duration) var(--timing),
      text-weight var(--duration) var(--timing)
    ;
  }
  & :where(a) {
    color: inherit;
    text-decoration: none;
    text-underline-offset: calc(4 * var(--rem));
    @media (any-hover: hover) {
      &:hover {
        opacity: .7;
      }
    }
  }
  & :where(button) {
    background: none;
    border: none;
    color: inherit;
    cursor: pointer;
    outline: none;
  }
}


/* ===================
  Layout
=================== */
.layout-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  &::before {
    position: sticky;
    content: '';
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100vh;
    /* background : linear-gradient(-30deg, rgba(235, 236, 247, 1) 0%, rgba(238, 250, 254, 1) 100%); */
    background: url(../img/bg_pc.jpg) no-repeat top center / cover;
  }
}

.layout-mobile-first {
  position: relative;
  @media (768px <= width) {
    display: flex;
  }
}
.layout-mobile-first__left,
.layout-mobile-first__right {
  position: relative;
  width: calc((100% - (var(--artboard-pw) * var(--rem-pc))) / 2);
}
.layout-mobile-first__sticky {
  position: sticky;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100vh;
}
.layout-mobile-first__main {
  overflow-x: clip;
  /* padding-block: calc(80 * var(--rem)) calc(205 * var(--rem)); */
  /* background: url(../img/bg_1.jpg) no-repeat top center/cover; */
  @media (768px <= width) {
    width: calc(var(--artboard-pw) * var(--rem-pc));
  }
}


/* ===================
  Utility
=================== */


/* ===================
  Component
=================== */
/* viewmore */
.component-viewmore {
  position: relative;
  display: block;
  margin-top: calc(60 * var(--rem));
  margin-inline: auto;
  padding-right: calc(28 * var(--rem));
  padding-bottom: calc(2 * var(--rem));
  background: none;
  border: none;
  border-bottom: 1px solid currentColor;
  color: #a8a9a9;
  font-family: var(--lp-font-en);
  font-size: calc(20 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
  cursor: pointer;
  &::before,
  &::after {
    position: absolute;
    top: 50%;
    right: calc(4 * var(--rem));
    content: "";
    display: block;
    width: calc(14 * var(--rem));
    height: 1px;
    background: currentColor;
    translate: 0 -50%;
  }
  &::after {
    rotate: 90deg;
  }
  &.is-open {
    &::after {
      rotate: 0deg;
    }
  }
}

/* marker */
.component-marker {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: calc(46 * var(--rem));
  padding-inline: calc(37 * var(--rem));
  &::before {
    position: absolute;
    content: '';
    top: auto;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: var(--marker-color, #afc9e8);
  }
  & + & {
    margin-top: calc(15 * var(--rem));
  }
  .text {
    position: relative;
  }
}
.component-marker__wrap {
  .component-marker {
    --transition-timing: ease;
    clip-path: inset(0 100% 0 0);
    transition: clip-path 1.4s var(--transition-timing);
    will-change: clip-path;
    transition-delay: var(--delay);
    &:nth-child(2) {
      --delay: .6s;
    }
  }
  &.is-active {
    .component-marker {
      clip-path: inset(0 0 0 0);
    }
  }
}


/* ===================
  Accordion
=================== */
.js-accordion--body {
  max-height: var(--max-height, calc(320 * var(--rem)));
  overflow: hidden;
  transition: max-height .6s ease-in-out;
  will-change: max-height;
  &.--mask {
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 100%);
    &.is-open {
      mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 100%);
    }
  }
}


/* ===================
  Modal
=================== */
/* body.is-modal-open {
  overflow: hidden;
  scrollbar-gutter: stable;
  } */
  .project-modal {
  --backdrop-rgb: 218, 218, 218;
  --backdrop-alpha: 0.5;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  margin: auto;
  background: none;
  border: none;
  opacity: 0;
  scale: 0.95;
  /* overflow: visible; */
  transition: opacity .3s, scale .3s;
  will-change: opacity, scale;
  &.is-open {
    opacity: 1;
    scale: 1;
  }
  &.is-closing {
    animation: fade-out 0.3s ease-out forwards;
  }
  &.is-closing::backdrop {
    animation: fade-out-backdrop 0.3s ease-out forwards;
  }
}
dialog::backdrop {
  background-color: rgba(var(--backdrop-rgb), 0);
  cursor: pointer;
  transition: background-color 0.3s;
  will-change: background-color;
}
dialog.is-open::backdrop {
  background-color: rgba(var(--backdrop-rgb), var(--backdrop-alpha));
}
@keyframes fade-out {
  from {
    opacity: 1;
    scale: 1;
  }
  to {
    opacity: 0;
    scale: 0.95;
  }
}
@keyframes fade-out-backdrop {
  from { background-color: rgba(var(--backdrop-rgb), var(--backdrop-alpha)); }
  to { background-color: rgba(var(--backdrop-rgb), 0); }
}

.project-modal__container {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(600 * var(--rem));
  max-width: 100vw;
  /* max-height: 90vh; */
  max-height: calc(100dvh - (60 * var(--rem)));
  /* background-color: #fff; */
  translate: -50% -50%;
  transition: transform 0.3s ease-out;
  overflow-y: scroll;
  scrollbar-width: none;
  overscroll-behavior: contain;
}
.project-modal__close-button__wrapper {
  padding-bottom: calc(30 * var(--rem));
}
.project-modal__close-button {
  position: relative;
  display: block;
  width: calc(60 * var(--rem));
  height: calc(60 * var(--rem));
  margin-right: calc(30 * var(--rem));
  margin-left: auto;
  border: none;
  cursor: pointer;
  &::before,
  &::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: calc(84 * var(--rem));
    height: 1px;
    background-color: #fff;
  }
  &::before {
    translate: -50% -50%;
    rotate: 45deg;
  }
  &::after {
    translate: -50% -50%;
    rotate: -45deg;
  }
}

/* ===================
  .project-modal-content
=================== */
.project-modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: calc(68 * var(--rem));
  padding-bottom: calc(55 * var(--rem));
  padding-inline: calc(57 * var(--rem));
  background: #fff;
  border: calc(3 * var(--rem)) solid #7fa9d3;
  border-radius: calc(16 * var(--rem));
  #modal_1 & {
    padding-bottom: calc(60 * var(--rem));
  }
}
.project-modal-content__body {
  text-align: center;
}

.campaign-modal-content {
  max-height: calc(100dvh - ((60 + 60 + 30) * var(--rem)));
  padding-inline: 0;
  padding-bottom: calc(86 * var(--rem));
}
.campaign-modal-content__body {
  width: 100%;
  overflow-y: scroll;
  scrollbar-width: none;
  overscroll-behavior: contain;
}


.modal-box__label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(300 * var(--rem));
  height: calc(36 * var(--rem));
  margin-inline: auto;
  background: var(--color-accent);
  border-radius: calc(18 * var(--rem));
  color: #fff;
  font-size: calc(24 * var(--rem));
  font-weight: bold;
  letter-spacing: .075em;
}
.modal-box__heading {
  margin-top: calc(32 * var(--rem));
  color: var(--color-accent);
  font-size: calc(46 * var(--rem));
  font-weight: bold;
  line-height: calc(49.19 / 46);
  letter-spacing: .075em;
  text-align: center;
  &:has(.--small) {
    margin-top: calc(20 * var(--rem));
  }
  .--small {
    margin-bottom: calc(15 * var(--rem));
    font-size: calc(26 * var(--rem));
    letter-spacing: .075em;
  }
  > span {
    display: block;
    letter-spacing: inherit;
  }
  #modal_1 & {
    .--small + span {
      margin-left: calc(48 * var(--rem));
    }
  }
}
.modal-box__text {
  margin-top: calc(22 * var(--rem));
  font-size: calc(26 * var(--rem));
  line-height: calc(52 / 26);
  letter-spacing: .075em;
  text-align: justify;
  #modal_1 & {
    font-size: calc(24 * var(--rem));
    line-height: calc(48 / 24);
  }
}


.campaign-modal__heading {
  width: fit-content;
  margin-inline: auto;
  margin-bottom: calc(78 * var(--rem));
  padding-bottom: calc(28 * var(--rem));
  border-bottom: calc(4 * var(--rem)) dotted currentColor;
  color: var(--color-accent);
  font-family: var(--lp-font-en);
  font-size: calc(40 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}
.campaign-modal__box {
  position: relative;
  & + & {
    margin-top: calc(107 * var(--rem));
  }
}
.campaign-modal__box-number {
  position: absolute;
  color: var(--color-accent);
  font-family: var(--lp-font-en);
  font-size: calc(120 * var(--rem));
  line-height: 1;
  letter-spacing: -.04em;
  &.--1 {
    top: calc(-24 * var(--rem));
    left: calc(88 * var(--rem));
  }
  &.--2 {
    top: calc(-51 * var(--rem));
    left: calc(88 * var(--rem));
  }
}
.campaign-modal__box-image {
  width: calc(300 * var(--rem));
  margin-inline: auto;
  & img {
    width: 100%;
  }
}
.campaign-modal__box-text {
  margin-top: calc(30 * var(--rem));
  font-size: calc(22 * var(--rem));
  letter-spacing: .075em;
  text-align: center;
  > span {
    display: block;
  }
  .normal {
    line-height: calc(44 / 22);
  }
  .em {
    color: var(--color-accent);
    font-size: calc(26 * var(--rem));
    font-weight: bold;
    line-height: calc(45.5 / 26);
  }
}



/**
 * project-mainvisual
 */
.project-mainvisual {
  position: relative;
}
.project-mainvisual__head {
  position: absolute;
  top: calc(100 * var(--rem));
  left: 0;
  width: 100%;
}
.project-mainvisual__head-label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(610 * var(--rem));
  height: calc(70 * var(--rem));
  margin-inline: auto;
  background: rgba(127, 169, 211, .8);
  color: #fff;
  font-family: var(--lp-font-rn);
  font-weight: bold;
  font-size: calc(40 * var(--rem));
}
.project-mainvisual__head-lead {
  margin-top: calc(30 * var(--rem));
  font-family: var(--lp-font-rn);
  font-weight: bold;
  font-size: calc(30 * var(--rem));
  line-height: calc(60 / 30);
  text-align: center;
}
.project-mainvisual__body {
  & img {
    width: 100%;
  }
}
.project-mainvisual__bottom-container {
  position: absolute;
  bottom: calc(89 * var(--rem));
  left: 0;
  width: 100%;
}
.project-mainvisual__bottom {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(34 * var(--rem));
  margin-top: calc(-23 * var(--rem));
}
.project-mainvisual__bottom-item {
  width: calc(260 * var(--rem));
  & img {
    width: 100%;
  }
}
.project-mainvisual__note {
  margin-top: calc(25 * var(--rem));
}
.project-mainvisual__note-item {
  color: #a9aaaa;
  font-size: calc(20 * var(--rem));
  line-height: calc(40 / 20);
  letter-spacing: .075em;
  text-align: center;
}


/**
 * project-anchor-block
 */
.project-anchor-block {
  padding-block: calc(100 * var(--rem)) calc(98 * var(--rem));
  background: #f5ffff;
}
.project-anchor-block__heading {
  margin-bottom: calc(62 * var(--rem));
  color: #5184af;
  font-family: var(--lp-font-en);
  font-size: calc(40 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}
.project-anchor {
  width: fit-content;
  margin-inline: auto;
}
.project-anchor__item-link {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc(600 * var(--rem));
  padding-top: calc(40 * var(--rem));
  padding-bottom: calc(26 * var(--rem));
  border-bottom: calc(4 * var(--rem)) dotted #5184af;
  &::after {
    content: '';
    position: absolute;
    bottom: calc(47 * var(--rem));
    right: calc(24 * var(--rem));
    width: calc(22 * var(--rem));
    height: calc(10 * var(--rem));
    background: var(--icon-arrow-down) no-repeat center / 100%;
  }
  .project-anchor__item:first-child & {
    padding-top: 0;
  }
  .project-anchor__item--3 & {
    padding-bottom: calc(32 * var(--rem));
  }
}
.project-anchor__item-label {
  margin-bottom: calc(23 * var(--rem));
  color: #5184af;
  font-size: calc(28 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
  .project-anchor__item--3 & {
    margin-bottom: calc(29 * var(--rem));
  }
}
.project-anchor__item-text {
  display: flex;
  align-items: center;
  justify-content: center;
  .project-anchor__item--3 & {
    margin-right: calc(48 * var(--rem));
  }
  .text {
    font-size: calc(32 * var(--rem));
    line-height: 1;
    letter-spacing: .075em;
  }
  .large {
    margin-block: calc(-4 * var(--rem));
    margin-left: calc(16 * var(--rem));
    font-family: var(--lp-font-en);
    font-size: calc(52 * var(--rem));
    line-height: 1;
    letter-spacing: -.04em;
    translate: calc(-2 * var(--rem)) calc(-4 * var(--rem));
  }
}

.layout-mobile-first__right {
  .project-anchor__container {
    margin-top: calc(167 * var(--rem-pc));
    margin-right: calc(8 * var(--rem-pc));
  }
  .project-anchor-block__heading {
    margin-bottom: calc(50 * var(--rem-pc));
    margin-right: calc(20 * var(--rem-pc));
    font-size: calc(24 * var(--rem-pc));
  }
  .project-anchor {
    width: fit-content;
    margin-inline: auto;
  }
  .project-anchor__item-link {
    width: calc(300 * var(--rem-pc));
    padding-top: calc(30 * var(--rem-pc));
    padding-bottom: calc(16 * var(--rem-pc));
    padding-right: calc(21 * var(--rem-pc));
    border-bottom: calc(2 * var(--rem-pc)) dotted #5184af;
    &::after {
      bottom: calc(25 * var(--rem-pc));
      right: 0;
      width: calc(15 * var(--rem-pc));
      height: calc(6 * var(--rem-pc));
    }
  }
  .project-anchor__item-label {
    margin-bottom: calc(16 * var(--rem-pc));
    font-size: calc(16 * var(--rem-pc));
  }
  .project-anchor__item-text {
    .text {
      font-size: calc(16 * var(--rem-pc));
    }
    .large {
      margin-block: calc(-3 * var(--rem-pc));
      margin-left: calc(16 * var(--rem));
      font-size: calc(28 * var(--rem-pc));
      translate: calc(-2 * var(--rem-pc)) calc(-4 * var(--rem-pc));
    }
  }
}


/**
 * section-item
 */
.section-item {
  padding-top: calc(116 * var(--rem));
  padding-bottom: calc(280 * var(--rem));
  background: url(../img/bg_1.jpg) no-repeat top center / 100%, #f9f9f9;
}


/**
 * item-block
 */
.item-block__image {
  width: calc(703 * var(--rem));
  margin-left: calc(36 * var(--rem));
}
.item-block__name {
  margin-top: calc(29 * var(--rem));
  font-size: calc(32 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}
.item-block__button-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(20 * var(--rem));
  margin-top: calc(58 * var(--rem));
}
.item-block__button-wrap {
  width: calc(319 * var(--rem));
}
.item-block__button {
  display: block;
  & img {
    width: 100%;
  }
}
.item-block__body {
  margin-top: calc(140 * var(--rem));
}
.item-block__body-heading__item {
  --marker-color: #90AAD1;
  display: flex;
  width: fit-content;
  height: calc(60 * var(--rem));
  margin-inline: auto;
  padding-inline: calc(46 * var(--rem));
  color: #fff;
  font-family: var(--lp-font-rn);
  font-weight: bold;
  font-size: calc(36 * var(--rem));
  line-height: 1;
  &.--large {
    font-size: calc(46 * var(--rem));
  }
  & + & {
    margin-top: calc(25 * var(--rem));
  }
  .text {
    translate: calc(2 * var(--rem)) calc(2 * var(--rem));
  }
}
.item-block__body-text {
  margin-top: calc(45 * var(--rem));
  font-size: calc(26 * var(--rem));
  line-height: calc(58.5 / 26);
  text-align: center;
}


/**
 * user-voice
 */
.user-voice {
  margin-top: calc(182 * var(--rem));
}
.user-voice__head {
  position: relative;
  width: fit-content;
  margin-inline: auto;
}
.user-voice__head-icon {
  position: absolute;
  top: calc(-112 * var(--rem));
  left: calc(-144 * var(--rem));
  width: calc(160 * var(--rem));
}
.user-voice__heading {
  font-family: var(--lp-font-en);
  font-size: calc(60 * var(--rem));
  line-height: 1;
  letter-spacing: .085em;
  text-align: center;
}

.user-voice__slider {
  --swiper-pagination-bullet-horizontal-gap: calc(5 * var(--rem));
  --swiper-pagination-bullet-width: calc(120 * var(--rem));
  --swiper-pagination-bullet-height: calc(10 * var(--rem));
  --swiper-pagination-bullet-inactive-color: #d3dbe0;
  --swiper-pagination-bullet-inactive-opacity: 1;
  --swiper-pagination-color: var(--color-accent);
  margin-top: calc(80 * var(--rem));
  padding-bottom: calc(50 * var(--rem));
  .swiper-pagination {
    display: flex;
    justify-content: center;
  }
  .swiper-pagination-bullet {
    display: block;
    border-radius: 0;
  }
  .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: calc(0 * var(--rem));
  }
}
.user-voice__slider-item {
  width: calc(540 * var(--rem));
  height: auto;
  margin-inline: calc(10 * var(--rem));
  padding: calc(38 * var(--rem)) calc(45 * var(--rem));
  background: #e4edf2;
  border-radius: calc(16 * var(--rem));
  font-size: calc(26 * var(--rem));
  line-height: calc(52 / 26);
  letter-spacing: .075em;
  text-align: justify;
  & p,
  & span {
    letter-spacing: .075em;
  }
  .marker {
    /* background: linear-gradient(to bottom, #fff); */
    text-decoration: underline;
    text-decoration-skip-ink: none;
    text-underline-offset: calc(-28 * var(--rem));
    text-decoration-color: #fff;
    text-decoration-thickness: calc(34 * var(--rem));
  }
}


/**
 * section-reason
 */
.section-reason {
  position: relative;
  margin-top: calc(-130 * var(--rem));
  padding-top: calc(130 * var(--rem));
}
.section-reason--1 {
  --background-color: #e4f2f4;
  .section-reason__inner {
    padding-bottom: calc(250 * var(--rem));
  }
}
.section-reason--2 {
  --background-color: #f9f9f9;
  .section-reason__inner {
    padding-bottom: calc(240 * var(--rem));
    background: url(../img/bg_2.jpg) no-repeat top center / 100%, var(--background-color);
  }
}
.section-reason--3 {
  --background-color: #e1edf9;
  .section-reason__inner {
    padding-bottom: calc(120 * var(--rem));
  }
}
.section-reason__inner {
  position: relative;
  background: var(--background-color);
}
.section-reason__heading-wrap {
  position: relative;
  width: 100%;
  height: calc(171 * var(--rem));
  &::before {
    position: absolute;
    content: '';
    top: calc(-130 * var(--rem));
    left: 50%;
    display: block;
    width: calc(540 * var(--rem));
    height: calc(270 * var(--rem));
    background : var(--background-color);
    border-radius: calc(270 * var(--rem)) calc(270 * var(--rem)) 0 0;
    translate: -50% 0;
  }
}
.section-reason__heading {
  position: absolute;
  top: calc(-55 * var(--rem));
  left: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc(386 * var(--rem));
  margin-inline: auto;
  translate: -50% 0;
  svg {
    width: 100%;
    height: auto;
    overflow: visible;
  }
  text {
    font-family: var(--lp-font-rn);
    font-size: calc(34 * var(--rem));
    font-weight: bold;
    line-height: 1;
    letter-spacing: .075em;
  }
}
.section-reason__heading-number {
  position: absolute;
  top: calc(54 * var(--rem));
  left: auto;
  margin-right: calc(4 * var(--rem));
  color: #7fa9d3;
  font-family: var(--lp-font-en);
  font-size: calc(130 * var(--rem));
  line-height: 1;
  letter-spacing: -.04em;
}

.section-reason__lead {
  font-size: calc(30 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
  & + & {
    margin-top: calc(30 * var(--rem));
  }
}


/**
 * bacteria-block
 */
.bacteria-block {
  width: calc(650 * var(--rem));
  margin-top: calc(79 * var(--rem));
  margin-inline: auto;
  padding-top: calc(60 * var(--rem));
  padding-bottom: calc(78 * var(--rem));
  background: #fff;
  border-radius: calc(16 * var(--rem));
}
.bacteria-block__item {
  position: relative;
}
.bacteria-block__item--1 {
  --image-width: calc(165 * var(--rem));
  --color: #d8aca4;
  margin-left: calc(93 * var(--rem));
  .bacteria-block__fig-image {
    margin-left: calc(-6 * var(--rem));
  }
  .bacteria-block__fig-caption {
    margin-left: calc(2 * var(--rem));
  }
  .bacteria-block__text {
    top: calc(31 * var(--rem));
    right: calc(60 * var(--rem));
    width: calc(300 * var(--rem));
  }
}
.bacteria-block__item--2 {
  --image-width: calc(152 * var(--rem));
  --color: #8fc9a2;
  margin-top: calc(16 * var(--rem));
  margin-right: calc(12 * var(--rem));
  .bacteria-block__fig {
    margin-left: auto;
  }
  .bacteria-block__fig-image {
    margin-right: calc(24 * var(--rem));
  }
  .bacteria-block__text {
    top: calc(16 * var(--rem));
    left: calc(71 * var(--rem));
    width: calc(278 * var(--rem));
  }
}
.bacteria-block__item--3 {
  --image-width: calc(159 * var(--rem));
  --color: #b7a6c9;
  margin-top: calc(-3 * var(--rem));
  margin-left: calc(72 * var(--rem));
  .bacteria-block__fig-image {
    margin-left: calc(-26 * var(--rem));
  }
  .bacteria-block__fig-caption {
    margin-top: calc(23 * var(--rem));
  }
  .bacteria-block__text {
    top: calc(75 * var(--rem));
    right: calc(38 * var(--rem));
    width: calc(303 * var(--rem));
  }
}
.bacteria-block__fig {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: fit-content;
}
.bacteria-block__fig-image {
  width: var(--image-width);
  & img {
    width: 100%;
  }
}
.bacteria-block__fig-caption {
  margin-top: calc(26 * var(--rem));
  color: var(--color);
  font-size: calc(30 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
  .--small {
    margin-left: calc(4 * var(--rem));
    font-size: calc(22 * var(--rem));
    font-weight: normal;
  }
}
.bacteria-block__text {
  position: absolute;
}


/**
 * section-reason__body
 */
.section-reason__body {
padding-top: calc(68 * var(--rem));
padding-bottom: calc(120 * var(--rem));
}
.section-reason__body-text {
  font-size: calc(26 * var(--rem));
  line-height: calc(52 / 26);
  text-align: center;
  & + & {
    margin-top: calc(14 * var(--rem));
  }
}
.section-reason__body-image {
  width: calc(600 * var(--rem));
  margin-inline: auto;
  margin-top: calc(36 * var(--rem));
  & img {
    width: 100%;
  }
}


/**
 * accordion-box
 */
.accordion-box {
  width: calc(700 * var(--rem));
  margin-inline: auto;
}
.accordion-box__label {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: calc(134 * var(--rem));
  padding-top: calc(4 * var(--rem));
  padding-left: calc(2 * var(--rem));
  background: var(--color-accent);
  cursor: pointer;
  color: #fff;
  font-family: var(--lp-font-rn);
  font-size: calc(32 * var(--rem));
  font-weight: bold;
  line-height: calc(49 / 32);
  letter-spacing: .075em;
  text-align: center;
  &::before,
  &::after {
    position: absolute;
    content: '';
    top: 50%;
    right: calc(44 * var(--rem));
    display: block;
    width: calc(36 * var(--rem));
    height: calc(5 * var(--rem));
    margin-top: calc(4 * var(--rem));
    background: #fff;
    translate: 0 -50%;
  }
  &::after {
    rotate: 90deg;
    transition: rotate .6s;
  }
  &.is-open {
    &::after {
      rotate: 0deg;
    }
  }
  > span {
    letter-spacing: inherit;
  }
}
.accordion-box__body {
  --max-height: 0;
  background: #fff;
  border: calc(3.12 * var(--rem)) solid var(--color-accent);
  border-radius: 0 0 calc(17 * var(--rem)) calc(17 * var(--rem));
}
.accordion-box__body-inner {
  padding-top: calc(49 * var(--rem));
  padding-bottom: calc(63 * var(--rem));
}
.accordion-box__top {
  display: flex;
  justify-content: center;
  margin-left: calc(-8 * var(--rem));
}
.accordion-box__top-image {
  width: calc(240 * var(--rem));
  & img {
    width: 100%;
  }
}
.accordion-box__list {
  margin-top: calc(54 * var(--rem));
  margin-left: calc(25 * var(--rem));
}
.accordion-box__list-item {
  display: flex;
  align-items: center;
  font-size: calc(26 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
  & + & {
    margin-top: calc(40 * var(--rem));
  }
  &::before {
    content: '';
    display: block;
    width: calc(32 * var(--rem));
    height: calc(28 * var(--rem));
    margin-right: calc(11 * var(--rem));
    background: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2033.5%2029.5%22%3E%3Crect%20width%3D%2228%22%20height%3D%2228%22%20y%3D%221.5%22%20rx%3D%225%22%20ry%3D%225%22%20style%3D%22fill%3A%23e4ecf2%22%2F%3E%3Cpath%20d%3D%22M4.94%2011.56c2.97%203.08%206.04%206.07%208.78%209.35.49.59%201.63.58%202.12%200C21.27%2014.49%2027.11%208.5%2033.06%202.56c1.37-1.37-.75-3.49-2.12-2.12C25%206.38%2019.16%2012.38%2013.72%2018.79h2.12c-2.75-3.28-5.81-6.28-8.78-9.35-1.34-1.39-3.46.73-2.12%202.12%22%20style%3D%22fill%3A%23779ec6%22%2F%3E%3C%2Fsvg%3E') no-repeat center / 100%;
  }
  > span {
    letter-spacing: inherit;
  }
}
.accordion-box__arrow {
  width: calc(52 * var(--rem));
  height: calc(32 * var(--rem));
  margin-top: calc(7 * var(--rem));
  margin-inline: auto;
  background: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20id%3D%22txt%22%20viewBox%3D%220%200%2051.25%2032.06%22%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill%3Anone%3Bstroke%3A%23000%3Bstroke-miterlimit%3A10%3Bstroke-width%3A2px%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cpath%20d%3D%22m.62%2010.78%2025%2020%2025-20%22%20class%3D%22cls-1%22%2F%3E%3Cpath%20d%3D%22m.62.78%2025%2020%2025-20%22%20class%3D%22cls-1%22%2F%3E%3C%2Fsvg%3E') no-repeat center / 100%;
}
.accordion-box__lead {
  margin-top: calc(41 * var(--rem));
  color: var(--color-accent);
  font-size: calc(30 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}
.accordion-box__text-box {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(580 * var(--rem));
  height: calc(220 * var(--rem));
  margin-inline: auto;
  margin-top: calc(38 * var(--rem));
  background: #d6e1e8;
}
.accordion-box__text {
  font-size: calc(24 * var(--rem));
  line-height: calc(48 / 24);
  letter-spacing: .075em;
  text-align: center;
}
.accordion-box__image {
  width: calc(640 * var(--rem));
  margin-top: calc(40 * var(--rem));
  margin-inline: auto;
  & img {
    width: 100%;
  }
}


/**
 * product-box
 */
.product-box {
  --max-height: calc(695 * var(--rem));
  width: calc(700 * var(--rem));
  margin-top: calc(60 * var(--rem));
  margin-inline: auto;
  padding-block: calc(57 * var(--rem)) calc(56 * var(--rem));
  background: #fff;
  border: calc(3 * var(--rem)) solid var(--color-accent);
  border-radius: calc(16 * var(--rem));
}
.product-box__heading {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(540 * var(--rem));
  height: calc(70 * var(--rem));
  margin-inline: auto;
  margin-bottom: calc(60 * var(--rem));
  background: var(--color-accent);
  border-radius: calc(35 * var(--rem));
  color: #fff;
  font-size: calc(30 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}


/**
 * product-list
 */
.product-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc(40 * var(--rem)) calc(20 * var(--rem));
  padding-bottom: calc(4 * var(--rem));
}
.product-list__item {
  width: calc(320 * var(--rem));
}
.product-list__image {
  width: calc(300 * var(--rem));
  margin-inline: auto;
  & img {
    width: 100%;
  }
}
.product-list__body {
  margin-top: calc(20 * var(--rem));
  text-align: center;
}
.product-list__body-text {
  font-size: calc(22 * var(--rem));
  line-height: calc(33 / 22);
  letter-spacing: .075em;
}
.product-list__body-link {
  margin-top: calc(16 * var(--rem));
  font-size: calc(20 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
  text-decoration: underline;
}


/**
 * float-box
 */
.float-block {
  margin-top: calc(89 * var(--rem));
}
.float-block__note-container {
  margin-top: calc(50 * var(--rem));
}
.float-block__note {
  color: #a9aaaa;
  font-size: calc(20 * var(--rem));
  line-height: calc(40 / 20);
  letter-spacing: .075em;
  text-align: center;
}
.float-box__container {
  position: relative;
  height: calc(672 * var(--rem));
}
.float-box {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(350 * var(--rem));
  height: calc(350 * var(--rem));
  background: rgba(104, 161, 193, .4);
  border-radius: 50%;
  color: #fff;
  font-weight: bold;
  letter-spacing: .075em;
  text-align: center;
  cursor: pointer;
}
.float-box--1 {
  top: 0;
  left: calc(39 * var(--rem));
  padding-top: calc(18 * var(--rem));
  transform: translateY(calc(-10 * var(--rem)));
  animation: floatY 6s infinite var(--transition-timing);
  animation-delay: 2s;
  .float-box__text {
    margin-top: calc(11 * var(--rem));
    line-height: calc(45 / 30);
  }
  .float-box__icon {
    bottom: calc(-48 * var(--rem));
    right: calc(48 * var(--rem));
  }
}
.float-box--2 {
  top: calc(87 * var(--rem));
  right: calc(39 * var(--rem));
  padding-top: calc(12 * var(--rem));
  transform: translateY(calc(10 * var(--rem)));
  animation: floatY2 5s infinite var(--transition-timing);
  animation-delay: 2.3s;
  .float-box__text {
    margin-top: calc(20 * var(--rem));
  }
  .float-box__icon {
    bottom: calc(-43 * var(--rem));
    right: calc(14 * var(--rem));
  }
}
.float-box--3 {
  top: calc(322 * var(--rem));
  left: calc(124 * var(--rem));
  transform: translateY(calc(10 * var(--rem)));
  animation: floatY2 5.5s infinite var(--transition-timing);
  animation-delay: 2.6s;
  .float-box__icon {
    bottom: calc(-53 * var(--rem));
    right: calc(-21 * var(--rem));
  }
}
.float-box__inner {
  position: relative;
}
.float-box__label {
  font-size: calc(36 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
}
.float-box__text {
  margin-top: calc(13 * var(--rem));
  font-size: calc(30 * var(--rem));
  letter-spacing: .075em;
  .--small {
    font-size: calc(24 * var(--rem));
  }
}
.float-box__icon {
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(40 * var(--rem));
  height: calc(40 * var(--rem));
  background: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20id%3D%22txt%22%20viewBox%3D%220%200%2040%2040%22%3E%3Cdefs%3E%3Cstyle%3E.cls-2%7Bfill%3Anone%3Bstroke%3A%23fff%3Bstroke-miterlimit%3A10%3Bstroke-width%3A3px%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Ccircle%20cx%3D%2220%22%20cy%3D%2220%22%20r%3D%2220%22%20style%3D%22fill%3A%23779ec6%22%2F%3E%3Cpath%20d%3D%22m9%2020.11%2022-.22M20.11%2031l-.22-22%22%20class%3D%22cls-2%22%2F%3E%3C%2Fsvg%3E') no-repeat center / 100%;
}


/**
 * section-reason__movie
 */
.section-reason__movie {
  width: calc(675 * var(--rem));
  margin-top: calc(70 * var(--rem));
  margin-inline: auto;
  & img {
    width: 100%;
  }
}


/**
 * section-limitedkit
 */
.section-limitedkit {
  margin-top: calc(-120 * var(--rem));
  padding-top: calc(120 * var(--rem));
  .section-reason__heading-wrap {
    &::before {
      top: calc(-120 * var(--rem));
    }
  }
  .section-reason__heading {
    top: calc(-67 * var(--rem));
    text {
      font-size: calc(24 * var(--rem));
    }
  }
}
.limitedkit-head {
  position: relative;
  margin-top: calc(-121 * var(--rem));
}
.limitedkit-head__label {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(210 * var(--rem));
  height: calc(50 * var(--rem));
  margin-inline: auto;
  padding-top: calc(4 * var(--rem));
  background: #5184af;
  border-radius: calc(10 * var(--rem));
  color: #fff;
  font-size: calc(28 * var(--rem));
  font-weight: bold;
  letter-spacing: .075em;
  &::after {
    content: '';
    position: absolute;
    bottom: calc(-9 * var(--rem));
    left: 50%;
    width: calc(20 * var(--rem));
    height: calc(10 * var(--rem));
    background: #5184af;
    clip-path: polygon(0% 0%, 50% 100%, 100% 0%);
    translate: -50% 0;
  }
}
.limitedkit-head__heading {
  margin-top: calc(31 * var(--rem));
  font-size: calc(50 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}


/**
 * kit-list
 */
.kit-list {
  margin-top: calc(78 * var(--rem));
}
.kit-list__item {
  width: calc(700 * var(--rem));
  margin-inline: auto;
  background: #fff;
  border: calc(3 * var(--rem)) solid #afc9e8;
  border-radius: calc(16 * var(--rem));
  & + & {
    margin-top: calc(40 * var(--rem));
  }
}
.kit-list__item--2 {
  .kit-list__item-price__tag {
    margin-top: calc(-4 * var(--rem));
  }
  .kit-list__item-button {
    margin-top: calc(40 * var(--rem));
  }
}
.kit-list__item--3 {
  .kit-list__item-price__tag {
    left: calc(22 * var(--rem));
  }
}
.kit-list__item-inner {
  position: relative;
  display: block;
  padding-top: calc(78 * var(--rem));
  padding-bottom: calc(76 * var(--rem));
}
.kit-list__item-number {
  position: absolute;
  top: calc(74 * var(--rem));
  left: calc(57 * var(--rem));
  color: var(--color-accent);
  font-family: var(--lp-font-en);
  font-size: calc(160 * var(--rem));
  line-height: 1;
  letter-spacing: -.04em;
}
.kit-list__item-label {
  margin-bottom: calc(34 * var(--rem));
  text-align: center;
}
.kit-list__item-label__text {
  font-family: var(--lp-font-rn);
  font-size: calc(32 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
  &::before,
  &::after {
    content: '';
    display: inline-block;
    width: calc(2 * var(--rem));
    height: calc(27 * var(--rem));
    background: currentColor;
  }
  &::before {
    margin-right: calc(20 * var(--rem));
    rotate: -34deg;
    transform-origin: bottom right;
  }
  &::after {
    margin-left: calc(20 * var(--rem));
    rotate: 34deg;
    transform-origin: bottom left;
  }
  &.--only {
    &::before {
      margin-right: calc(6 * var(--rem));
    }
    &::after {
      margin-left: calc(6 * var(--rem));
    }
  }
}
.kit-list__item-image {
  position: relative;
  width: calc(360 * var(--rem));
  margin-inline: auto;
  & img {
    position: relative;
    z-index: 5;
    width: 100%;
  }
}
.kit-list__item-image__icon {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-family: var(--lp-font-rn);
  line-height: 1;
  letter-spacing: .075em;
}
.kit-list__item-image__icon--1 {
  top: calc(82 * var(--rem));
  right: calc(-139 * var(--rem));
  width: calc(230 * var(--rem));
  height: calc(230 * var(--rem));
  background: #acc9e2;
  color: #fff;
  font-size: calc(36 * var(--rem));
}
.kit-list__item-image__icon--2 {
  top: calc(-65 * var(--rem));
  right: calc(-102 * var(--rem));
  z-index: 6;
  width: calc(140 * var(--rem));
  height: calc(140 * var(--rem));
  background: #fff;
  border: calc(2 * var(--rem)) solid currentColor;
  color: #a9aaaa;
  font-size: calc(26 * var(--rem));
}
.kit-list__item-name {
  margin-top: calc(42 * var(--rem));
  color: var(--color-accent);
  font-size: calc(38 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}
.kit-list__item-price {
  position: relative;
  margin-top: calc(28 * var(--rem));
  color: var(--color-accent);
  font-family: var(--lp-font-en);
  font-size: calc(34 * var(--rem));
  font-weight: bold;
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}
.kit-list__item-price__tag {
  --distance: 6;
  position: absolute;
  top: 50%;
  left: calc(20 * var(--rem));
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(160 * var(--rem));
  height: calc(58 * var(--rem));
  background: #5184af;
  color: #fff;
  font-family: var(--lp-font-en);
  font-size: calc(30 * var(--rem));
  font-weight: bold;
  letter-spacing: .075em;
  text-align: center;
  translate: 0 -50%;
  &::after {
    content: '';
    position: absolute;
    top: 50%;
    right: calc(-10 * var(--rem));
    width: calc(10 * var(--rem));
    height: calc(15 * var(--rem));
    background: #5184af;
    clip-path: polygon(0 0, 0 100%, 100% 50%);
    translate: 0 -50%;
  }
}
.kit-list__item-button {
  position: relative;
  width: calc(400 * var(--rem));
  margin-top: calc(30 * var(--rem));
  margin-inline: auto;
  padding-bottom: calc(15 * var(--rem));
  &::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(80 * var(--rem));
    background: #5184af;
    border-radius: calc(16 * var(--rem));
  }
}
.kit-list__item-button__text {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: calc(80 * var(--rem));
  background: var(--color-accent);
  border-radius: calc(16 * var(--rem));
  font-family: var(--lp-font-rn);
  color: #fff;
  font-size: calc(28 * var(--rem));
  letter-spacing: .075em;
}
.kit-list__item-list {
  margin-top: calc(41 * var(--rem));
}
.kit-list__item-list__item {
  display: flex;
  align-items: center;
  justify-content: center;
  & + & {
    margin-top: calc(30 * var(--rem));
  }
  &::before {
    content: '';
    display: block;
    width: calc(24 * var(--rem));
    height: calc(24 * var(--rem));
    margin-right: calc(15 * var(--rem));
    background: #daecf7;
    border-radius: 50%;
  }
}
.kit-list__item-list__item-text {
  font-size: calc(26 * var(--rem));
  line-height: 1;
  letter-spacing: .075em;
}
.kit-list__item-note {
  margin-top: calc(40 * var(--rem));
  font-size: calc(20 * var(--rem));
  text-align: center;
}


/**
 * section-bottom
 */
.section-bottom {
  padding-block: calc(140 * var(--rem)) calc(160 * var(--rem));
  background: #fff;
}
.section-bottom__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(650 * var(--rem));
  height: calc(80 * var(--rem));
  margin-inline: auto;
  background: #787878;
  font-family: var(--lp-font-en);
  color: #fff;
  font-size: calc(36 * var(--rem));
  letter-spacing: .075em;
}


/**
 * campaign-button
 */
.campaign-button__container {
  position: fixed;
  bottom: calc(30 * var(--rem));
  right: calc(30 * var(--rem));
  z-index: 100;
  transition: opacity .5s var(--transition-timing), visibility .5s var(--transition-timing), bottom 0.6s .2s ease;
  @media (768px <= width) {
    bottom: calc(30 * var(--rem-pc));
    right: calc(30 * var(--rem-pc));
  }
  .footer-nav-visible & {
    @media (width < 768px) {
      bottom: calc(130 * var(--rem));
    }
  }
  &.is-hidden {
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
  }
}
.campaign-button {
  width: calc(220 * var(--rem));
  height: calc(220 * var(--rem));
  padding-top: calc(20 * var(--rem));
  padding-bottom: calc(14 * var(--rem));
  background: rgba(144, 170, 209, .6);
  border-radius: 50%;
  color: #fff;
  font-family: var(--lp-font-en);
  font-size: calc(28 * var(--rem));
  font-weight: bold;
  line-height: calc(34 / 28);
  letter-spacing: .05em;
  > span {
    letter-spacing: .05em;
  }
  .--large {
    font-size: calc(40 * var(--rem));
  }
  @media (768px <= width) {
    width: calc(120 * var(--rem-pc));
    height: calc(120 * var(--rem-pc));
    padding-top: calc(10 * var(--rem));
    padding-bottom: 0;
    font-size: calc(15 * var(--rem-pc));
    line-height: calc(22.5 / 15);
    .--large {
      font-size: calc(22 * var(--rem-pc));
    }
  }
}
.campaign-button__image {
  position: absolute;
  top: calc(-60 * var(--rem));
  right: calc(-20 * var(--rem));
  width: calc(121 * var(--rem));
  height: calc(153 * var(--rem));
  @media (768px <= width) {
    top: calc(-34 * var(--rem-pc));
    right: calc(-6 * var(--rem-pc));
    width: calc(67 * var(--rem-pc));
    height: calc(85 * var(--rem-pc));
  }
  & img {
    width: 100%;
  }
}
.campaign-button__close {
  position: absolute;
  top: calc(13 * var(--rem));
  left: calc(15 * var(--rem));
  width: calc(30 * var(--rem));
  height: calc(30 * var(--rem));
  @media (768px <= width) {
    top: calc(11 * var(--rem-pc));
    left: calc(4 * var(--rem-pc));
    width: calc(16 * var(--rem-pc));
    height: calc(16 * var(--rem-pc));
  }
  & img {
    width: 100%;
  }
}


/**
 * project-footer-nav
 */
.project-footer-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  opacity: 0;
  translate: 0 100%;
  transition: opacity 0.6s .2s ease, translate 0.6s .2s ease;
  will-change: opacity, translate;
  &.is-visible {
    opacity: 1;
    translate: 0 0;
  }
}
.project-footer-nav__list {
  display: flex;
}
.project-footer-nav__item {
  &.--1 {
    width: calc(269 * var(--rem));
    .project-footer-nav__item-body {
      padding-right: calc(8 * var(--rem));
      padding-bottom: calc(18 * var(--rem));
      .text {
        .--large {
          translate: calc(4 * var(--rem)) calc(4 * var(--rem));
        }
      }
    }
  }
  &.--2 {
    width: calc(275 * var(--rem));
    .project-footer-nav__item-body {
      padding-right: calc(8 * var(--rem));
      padding-bottom: calc(18 * var(--rem));
      .text {
        .--large {
          translate: calc(6 * var(--rem)) calc(4 * var(--rem));
        }
      }
    }
  }
  &.--3 {
    width: calc(206 * var(--rem));
  }
  & + & {
    position: relative;
    &::before {
      content: '';
      position: absolute;
      top: 50%;
      left: calc(-2 * var(--rem));
      z-index: 1;
      display: block;
      width: calc(4 * var(--rem));
      height: calc(66 * var(--rem));
      background-image: radial-gradient(circle, #5184af calc(2 * var(--rem)), transparent calc(2 * var(--rem)));
      background-size: calc(4 * var(--rem)) calc(10 * var(--rem));
      background-repeat: repeat-y;
      background-position: center;
      translate: 0 -50%;
    }
  }
}
.project-footer-nav__item-body {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  height: calc(100 * var(--rem));
  padding-bottom: calc(19 * var(--rem));
  background: #f9f9f9;
  &::after {
    content: '';
    display: block;
    width: calc(20 * var(--rem));
    height: calc(16 * var(--rem));
    margin-top: calc(11 * var(--rem));
    background: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2021.25%2010.06%22%3E%3Cpath%20d%3D%22m.62.78%2010%208%2010-8%22%20style%3D%22fill%3Anone%3Bstroke%3A%23000%3Bstroke-miterlimit%3A10%3Bstroke-width%3A2px%22%2F%3E%3C%2Fsvg%3E') no-repeat center / 100%;
  }
  .text {
    font-size: calc(22 * var(--rem));
    line-height: 1;
    letter-spacing: .075em;
    .--large {
      display: inline-block;
      font-family: var(--lp-font-en);
      font-size: calc(40 * var(--rem));
      letter-spacing: -.04em;
    }
  }
}


/**
 * project-logo-box
 */
.project-logo-box {
  margin-top: calc(165 * var(--rem-pc));
}
.project-logo-box__main {
  width: calc(112.605 * var(--rem-pc));
  margin-inline: auto;
  & img {
    width: 100%;
  }
}
.project-logo-box__text {
  margin-top: calc(32 * var(--rem-pc));
  font-family: var(--lp-font-en);
  font-size: calc(22 * var(--rem-pc));
  line-height: calc(35 / 22);
  letter-spacing: .075em;
  text-align: center;
}



/*=======================================
               Responsive
========================================*/

/*=======================================
                    PC
========================================*/
@media (768px <= width) {
  .u-d-md {
    display: none !important;
  }
}


/*=======================================
                    SP
========================================*/
@media (width < 768px) {
  .u-d-lg {
    display: none !important;
  }
}
