@charset "UTF-8";
/* ==========================================
   ■ 設定値（ここだけ触ればOK）
   ========================================== */
html {
  scroll-behavior: smooth;
}

:root {
  --limitSizeNum: 100vw;
  --spSize: 750;
  --pcSize: 1400;
  --spSizeInPc: 480;
}

.f-container {
  --pc-width: 1400; /*PCデザイン幅*/
  --sp-width: 750; /*SPデザイン幅*/
  --pc-artboard-width: 480; /*SP共通デザイン幅*/
  --sp-artboard-width: 750; /*PC共通デザイン幅*/
  --formula: calc(var(--variable) * var(--ratio)); /*SP→PC 可変設定*/
  --formula_pc: calc(var(--variable) * 1); /*PC 1400以上は固定*/
  --colorOrange: #f75e00;
}

@media (min-width: 1401px) {
  html {
    font-size: 62.5%;
  }
  .f-container {
    --ratio: calc(
      var(--pc-artboard-width) / var(--sp-artboard-width)
    ); /* PCとSPのデザイン幅の比率 */
    --variable: 1px; /* 固定値（可変しない） */
  }
}
@media (max-width: 1400px) {
  html {
    font-size: calc(100vw / (140));
  }
}
/* PC画面幅 768～1400px 可変 */
@media (min-width: 768px) and (max-width: 1400px) {
  html {
    font-size: calc(100vw / (140));
  }
  .f-container {
    --ratio: calc(
      var(--pc-artboard-width) / var(--sp-artboard-width)
    ); /* PCとSPのデザイン幅の比率 */
    --variable: calc(100vw / var(--pc-width)); /* 画面幅に基づく可変値 */
  }
}
/* SP画面幅 767px以下 可変 */
@media (max-width: 767px) {
  :root {
    --spSizeInPc: 750;
    --pcSize: 750;
  }
  html {
    font-size: calc(100vw / (75));
  }
  .f-container {
    --ratio: 1; /* 比率は1（変わらない） */
    --variable: calc(100vw / var(--sp-width)); /* 画面幅に基づく可変値 */
  }
  .f-right,
  .f-left {
    display: none !important;
  }
}
.l-container {
  width: 100%;
}

.l-footer {
  padding-top: 0;
}
.l-footer .pc-footer {
  margin-top: 0;
}

.f-container {
  opacity: 0;
}
.f-container.show {
  opacity: 1;
}
.f-container {
  scroll-margin-top: 80px;
  width: 100%;
  overflow: clip;
  display: flex;
  position: relative;
}
.f-container * {
  box-sizing: border-box;
  margin-block-start: 0;
  margin-block-end: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
}
.f-container {
  color: #000000;
  font-feature-settings: "palt";
}
.f-container a.mask-img {
  position: relative;
}
.f-container a.mask-img::after {
  display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  transition: all 0.3s ease-in-out;
  -webkit-mask-size: cover;
          mask-size: cover;
  will-change: opacity;
}
.f-container a.mask-img:hover {
  opacity: 1;
}
.f-container a.mask-img:hover::after {
  background: rgb(255, 255, 255);
  opacity: 0.3;
}
@media (max-width: 768px) {
  .f-container a.mask-img:hover::after {
    opacity: 0;
  }
}
.f-container img,
.f-container video {
  width: 100%;
  height: auto;
  vertical-align: top;
  pointer-events: none;
}
.f-container svg {
  width: 100%;
  height: auto;
  display: block;
  pointer-events: none;
}
.f-container a {
  color: #000000;
  display: block;
  transition: all 0.3s ease-in-out;
  text-decoration: none;
  cursor: pointer;
}
.f-container a:hover {
  opacity: 0.7;
}
@media (max-width: 768px) {
  .f-container a:hover {
    opacity: 1;
  }
}
.f-container figure {
  display: block;
}
.f-container .f-left, .f-container .f-right {
  width: calc((100% - 50rem) / 2);
  height: calc(100vh - 80px);
  overflow: clip;
  position: sticky;
  top: 80px;
}
.f-container .f-left__img {
  height: calc((100vh - 80px) * 614 / 812);
  position: relative;
  z-index: 2;
}
.f-container .f-left__img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center bottom;
     object-position: center bottom;
}
.f-container .f-left__text {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc((100vh - 80px) * 0.7192118227);
  height: calc((100vh - 80px) * 0.2056650246);
}
.f-container .f-left__text img {
  height: 100%;
  width: auto;
}
.f-container .f-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  row-gap: 2.2rem;
}
.f-container .f-right img {
  height: 100%;
  width: auto;
}
.f-container .f-right a {
  height: 100%;
}
.f-container .f-right {
  row-gap: calc((100vh - 80px) * 0.0270935961);
}
.f-container .f-right__btn {
  width: auto;
  height: calc((100vh - 80px) * 0.0997536946);
}
.f-container .f-right__img {
  position: absolute;
  width: auto;
}
.f-container .f-right__img.img01 {
  height: calc((100vh - 80px) * 0.2684729064);
  left: calc((100vh - 80px) * 0.0517241379);
  top: calc((100vh - 80px) * 0.0467980296);
  transform: rotate(-4.84deg);
}
.f-container .f-right__img.img02 {
  height: calc((100vh - 80px) * 0.2315270936);
  right: calc((100vh - 80px) * 0.0640394089);
  bottom: calc((100vh - 80px) * 0.1366995074);
  transform: rotate(-354deg);
}
.f-container .f-main {
  width: 50rem;
  overflow: clip;
}
@media (max-width: 768px) {
  .f-container .f-main {
    max-width: calc(750 * var(--formula));
    width: 100%;
  }
}
.f-container .f-main-wrap {
  max-width: calc(750 * var(--formula));
  width: 100%;
  margin: 0 auto;
  overflow: clip;
  background-color: #fff;
}
.f-container .fadeIn {
  opacity: 0;
  transition: opacity 1s ease;
}
.f-container .fadeIn.showed {
  opacity: 1;
}
.f-container .fadeUp {
  opacity: 0;
  transition: all 1.5s ease;
  transform: translateY(10rem);
}
.f-container .fadeUp.showed {
  opacity: 1;
  transform: translate(0, 0);
}
.f-container .typing {
  opacity: 0;
}
.f-container .typing span {
  display: inline-block;
  opacity: 0;
}
.f-container .typing span.active {
  opacity: 1;
}
.f-container .typing.is-start {
  opacity: 1;
}
.f-container .fade-in-bck {
  perspective: 1000px;
}
.f-container .fade-in-bck img {
  transform: translate3d(0, 0, 0);
  transform-style: preserve-3d;
  opacity: 0;
}
.f-container .fade-in-bck.showed img {
  display: block;
  animation: 0.6s cubic-bezier(0.39, 0.575, 0.565, 1) 0.5s 1 normal both running fade-in-bck;
}
.f-container .rotate-center.showed {
  animation: rotate-center 5s linear forwards;
}
@keyframes fade-in-bck {
  0% {
    transform: translateZ(80px);
    opacity: 0;
  }
  to {
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes rotate-center {
  0% {
    transform: rotate(0);
  }
  12% {
    transform: rotate(360deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.f-container .hero {
  padding-top: calc(132 * var(--formula));
}
.f-container .hero {
  position: relative;
}
.f-container .hero__box {
  padding-top: calc(33 * var(--formula));
  position: relative;
}
.f-container .hero__mv {
  width: calc(531 * var(--formula));
  margin-left: auto;
}
.f-container .hero__img {
  position: absolute;
}
.f-container .hero .img01 {
  width: calc(316 * var(--formula));
  top: calc(5.5 * var(--formula));
  left: calc(8 * var(--formula));
  transform: rotate(-2.184deg);
}
.f-container .hero .img02 {
  width: calc(240 * var(--formula));
  left: calc(7 * var(--formula));
  bottom: calc(224.5 * var(--formula));
  transform: rotate(-358.2deg);
}
.f-container .hero .img03 {
  width: calc(252 * var(--formula));
  left: calc(22 * var(--formula));
  bottom: calc(-43.5 * var(--formula));
  transform: rotate(-4.321deg);
}
.f-container .hero__title {
  width: calc(690 * var(--formula));
  margin-top: calc(25 * var(--formula));
  margin-left: calc(40 * var(--formula));
}
.f-container .hero__text-jp {
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: calc(26 * var(--formula));
  line-height: calc(52 * var(--formula));
  letter-spacing: 0.025em;
  margin-top: calc(14 * var(--formula));
  margin-left: calc(40 * var(--formula));
}
.f-container .hero__text-en {
  font-family: "archer-pro", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: calc(20 * var(--formula));
  line-height: calc(23 * var(--formula));
  letter-spacing: 0.025em;
  margin-top: calc(43 * var(--formula));
  margin-left: calc(36 * var(--formula));
}
.f-container .hero__typing {
  width: calc(750 * var(--formula));
  margin-top: calc(140 * var(--formula));
  margin-left: calc(3 * var(--formula));
  margin-bottom: calc(140 * var(--formula));
  font-family: "archer-pro", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: calc(26 * var(--formula));
  line-height: calc(23 * var(--formula));
  letter-spacing: 0.04em;
  text-align: center;
}
.f-container .hero__plane {
  width: calc(750 * var(--formula));
  position: absolute;
  left: 0;
  bottom: calc(-35 * var(--formula));
  pointer-events: none;
}
.f-container .sec .r3 {
  position: relative;
  z-index: 3;
}
.f-container .sec .z2 {
  z-index: 2;
}
.f-container .sec .poa {
  position: absolute;
}
.f-container .sec .dfl {
  display: flex;
  flex-wrap: wrap;
}
.f-container .sec .js-section-sticky {
  position: sticky;
  top: 0;
}
.f-container .sec__area {
  position: relative;
}
.f-container .sec__bg {
  width: 100%;
}
.f-container .sec__img {
  position: relative;
}
.f-container .sec__img.w a {
  position: relative;
}
.f-container .sec__img.w a::before {
  display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
}
.f-container .sec__img.w a img {
  transition: all 0.3s ease-in-out;
  position: relative;
  z-index: 2;
}
.f-container .sec__img.w a:hover {
  opacity: 1;
}
.f-container .sec__img.w a:hover img {
  opacity: 0.7;
}
@media (max-width: 768px) {
  .f-container .sec__img.w a:hover img {
    opacity: 1;
  }
}
.f-container .sec__lc {
  pointer-events: none;
}
.f-container .sec01 {
  margin-bottom: calc(159 * var(--formula));
}
.f-container .sec01 .box01 {
  width: 100%;
  top: calc(141.55 * var(--formula));
  left: 0;
}
.f-container .sec01 .img01 {
  width: calc(620 * var(--formula));
  margin-left: calc(77 * var(--formula));
  margin-bottom: calc(33 * var(--formula));
}
.f-container .sec01 .img02 {
  width: calc(619 * var(--formula));
  margin-left: calc(15 * var(--formula));
  margin-bottom: calc(32 * var(--formula));
}
.f-container .sec01 .img03 {
  width: calc(607 * var(--formula));
  margin-left: calc(72 * var(--formula));
}
.f-container .sec01 .img04 {
  width: calc(300 * var(--formula));
  margin-top: calc(-260 * var(--formula));
  margin-left: calc(452 * var(--formula));
  margin-bottom: calc(33 * var(--formula));
}
.f-container .sec01 .img05 {
  width: calc(634 * var(--formula));
  margin-left: calc(40 * var(--formula));
}
.f-container .sec02 {
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec02 .img01 {
  margin-bottom: calc(20 * var(--formula));
}
.f-container .sec02 .img02,
.f-container .sec02 .img03 {
  width: calc(375 * var(--formula));
}
.f-container .sec03 {
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec03 .img02 {
  width: calc(550 * var(--formula));
  margin: 0 auto;
  height: calc(1000 * var(--formula));
  display: flex;
  justify-content: center;
  align-items: center;
}
.f-container .sec03 .img02 a {
  height: calc(730 * var(--formula));
  display: inline-block;
}
.f-container .sec04 {
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec04 .bg01 {
  pointer-events: none;
}
.f-container .sec04 .box01 {
  width: 100%;
  top: calc(12 * var(--formula));
  left: 0;
}
.f-container .sec04 .img01 {
  width: calc(730 * var(--formula));
  margin-left: calc(13 * var(--formula));
  margin-bottom: calc(10 * var(--formula));
}
.f-container .sec04 .img02 {
  width: calc(730 * var(--formula));
  margin-left: calc(13 * var(--formula));
  margin-bottom: calc(9.5 * var(--formula));
}
.f-container .sec04 .img03 {
  width: calc(730 * var(--formula));
  margin-left: calc(13 * var(--formula));
  margin-bottom: calc(9.5 * var(--formula));
}
.f-container .sec04 .pic01 {
  width: calc(182 * var(--formula));
  top: calc(30 * var(--formula));
  right: calc(31 * var(--formula));
  pointer-events: none;
}
.f-container .sec04 .img04 {
  width: calc(730 * var(--formula));
  margin-left: calc(11 * var(--formula));
}
.f-container .sec05 .img01 {
  width: calc(700 * var(--formula));
  margin: 0 auto;
}
.f-container .sec05 .img02 {
  width: calc(408 * var(--formula));
  border-radius: 50%;
  overflow: hidden;
  margin-top: calc(-96 * var(--formula));
  margin-left: calc(342 * var(--formula));
  margin-bottom: calc(140 * var(--formula));
}
.f-container .sec05 .lc01 {
  width: calc(217 * var(--formula));
  top: calc(755 * var(--formula));
  right: calc(13 * var(--formula));
}
.f-container .sec06 {
  padding-top: calc(59.6 * var(--formula));
  padding-bottom: calc(60.3 * var(--formula));
  margin-bottom: calc(159.2 * var(--formula));
  width: 100%;
  background: repeat-y url(../img/sec06_bg01.svg) 0 0/100% auto;
}
.f-container .sec06 .img01 {
  width: calc(650 * var(--formula));
  margin: 0 auto calc(99.5 * var(--formula));
}
.f-container .sec06 .slide01 {
  padding: calc(119.75 * var(--formula)) 0;
  width: calc(609 * var(--formula));
  margin: 0 auto calc(60.5 * var(--formula));
}
.f-container .sec06 .img04 {
  width: calc(560 * var(--formula));
  margin-left: calc(-58 * var(--formula));
}
.f-container .sec06 .img05 {
  width: calc(600 * var(--formula));
  margin-top: calc(-440 * var(--formula));
  margin-right: calc(-79 * var(--formula));
  margin-left: auto;
}
.f-container .sec07 .img01 {
  width: calc(600 * var(--formula));
}
.f-container .sec07 .img02 {
  width: calc(408 * var(--formula));
  border-radius: 50%;
  overflow: hidden;
  margin-top: calc(-294 * var(--formula));
  margin-left: auto;
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec07 .lc01 {
  width: calc(260 * var(--formula));
  top: calc(447 * var(--formula));
  right: calc(19 * var(--formula));
}
.f-container .sec08 {
  margin-bottom: calc(161 * var(--formula));
}
.f-container .sec08 .sec__img {
  width: calc(375 * var(--formula));
}
.f-container .sec09 {
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec09 .bg01 {
  pointer-events: none;
}
.f-container .sec09 .box01 {
  width: 100%;
  top: calc(11 * var(--formula));
  left: 0;
}
.f-container .sec09 .img01 {
  width: calc(733 * var(--formula));
  margin-left: calc(9 * var(--formula));
}
.f-container .sec09 .img02 {
  width: calc(726 * var(--formula));
  margin-left: calc(15 * var(--formula));
  margin-bottom: calc(9.5 * var(--formula));
}
.f-container .sec10 .img01 {
  width: calc(600 * var(--formula));
  margin-left: auto;
}
.f-container .sec10 .img02 {
  width: calc(408 * var(--formula));
  border-radius: 50%;
  overflow: hidden;
  margin-top: calc(-294 * var(--formula));
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec10 .lc01 {
  width: calc(221.15 * var(--formula));
  top: calc(451 * var(--formula));
  left: calc(19 * var(--formula));
}
.f-container .sec11 {
  margin-bottom: calc(162 * var(--formula));
}
.f-container .sec11 .box01 {
  width: 100%;
  top: calc(39 * var(--formula));
  left: 0;
}
.f-container .sec11 .sec__img {
  position: absolute;
}
.f-container .sec11 .img01 {
  width: calc(355 * var(--formula));
  top: calc(42 * var(--formula));
  right: calc(27 * var(--formula));
}
.f-container .sec11 .img02 {
  width: calc(395 * var(--formula));
  top: calc(102 * var(--formula));
  left: calc(25 * var(--formula));
}
.f-container .sec11 .img03 {
  width: calc(364 * var(--formula));
  top: calc(313 * var(--formula));
  left: calc(193 * var(--formula));
}
.f-container .sec11 .img04 {
  width: calc(382 * var(--formula));
  top: calc(551 * var(--formula));
  left: calc(-14 * var(--formula));
}
.f-container .sec11 .img05 {
  width: calc(408 * var(--formula));
  top: calc(571 * var(--formula));
  right: calc(-33 * var(--formula));
}
.f-container .sec11 .img06 {
  width: calc(368 * var(--formula));
  top: calc(716 * var(--formula));
  left: calc(204 * var(--formula));
}
.f-container .btm {
  margin-bottom: calc(117 * var(--formula));
}
.f-container .btm__btns {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: calc(157 * var(--formula));
}
.f-container .btm__btn {
  width: calc(460 * var(--formula));
}
.f-container .btm .btn01 {
  margin-bottom: calc(80.5 * var(--formula));
}
.f-container .staff {
  margin-bottom: calc(162 * var(--formula));
}
.f-container .staff__title {
  text-align: center;
  font-family: "ivypresto-display", serif;
  font-weight: 300;
  font-style: normal;
  font-size: calc(40 * var(--formula));
  line-height: calc(29 * var(--formula));
  padding-bottom: calc(3 * var(--formula));
  letter-spacing: 0.05em;
  margin-bottom: calc(34 * var(--formula));
}
.f-container .staff__frame {
  position: relative;
  width: calc(600 * var(--formula));
  margin: 0 auto;
}
.f-container .staff__list {
  width: calc(600 * var(--formula));
  position: absolute;
  left: 0;
  bottom: 0;
  display: flex;
  flex-wrap: wrap;
}
.f-container .staff__each {
  width: calc(300 * var(--formula));
  height: calc(300 * var(--formula));
  display: flex;
  flex-direction: column;
  align-items: center;
}
.f-container .staff__icon {
  width: calc(140 * var(--formula));
  margin-top: calc(56 * var(--formula));
  margin-bottom: calc(30 * var(--formula));
}
.f-container .staff__name {
  text-align: center;
  width: 100%;
}
.f-container .staff__name img {
  height: calc(27.2 * var(--formula));
  width: auto;
}
.f-container .fixed__btn {
  width: calc(140 * var(--formula));
  position: fixed;
  right: 0;
  bottom: calc(100 * var(--formula));
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  transition: all 0.8s ease;
}
.f-container .fixed__btn.show {
  opacity: 1;
  visibility: visible;
}