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

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

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

@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; /* 固定値（可変しない） */
  }
}
/* 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: #000;
  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: #000;
  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 .pc-bg {
  width: 100vw;
  height: calc(100vh - 80px);
  position: absolute;
  left: 0;
  top: 0px;
}
.f-container .pc-bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top;
     object-position: top;
}
.f-container .f-left, .f-container .f-right {
  width: calc((100% - 31rem) / 2);
  height: calc(100vh - 80px);
  overflow: clip;
  position: sticky;
  top: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.f-container .f-left {
  align-self: flex-start;
}
.f-container .f-left__title {
  width: 28.0825rem;
}
.f-container .f-right {
  align-self: flex-end;
  margin-left: auto;
  flex-direction: column;
  row-gap: 2.7rem;
}
.f-container .f-right .btn01 {
  width: 12.21rem;
}
.f-container .f-right .btn02 {
  width: 28.183rem;
}
.f-container .f-right .btn03 {
  width: 13.407rem;
}
.f-container .f-main {
  width: 31rem;
  height: auto;
}
.f-container .f-main.pc {
  height: calc(1299 * var(--formula));
  align-self: center;
  background-color: #fff;
}
@media (max-width: 768px) {
  .f-container .f-main.pc {
    position: static;
    top: 0;
    left: 0;
    transform: translate(0, 0);
  }
}
.f-container .f-main.pc .f-main-wrap {
  position: relative;
}
.f-container .f-main.pc .f-main-wrap::before {
  display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
}
.f-container .f-main.pc .f-main-wrap {
  height: 100%;
  overflow: scroll;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
.f-container .f-main.pc .f-main-wrap::-webkit-scrollbar {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  background-color: transparent;
}
.f-container .f-main.pc .f-main-wrap::-webkit-scrollbar-thumb {
  background-color: transparent;
  border-radius: 0;
}
.f-container .f-main.pc .f-main-wrap {
  scrollbar-width: none;
  -ms-overflow-style: none;
  scrollbar-color: transparent transparent;
}
.f-container .f-main {
  overflow: clip;
}
@media (max-width: 768px) {
  .f-container .f-main {
    max-width: calc(750 * var(--formula));
    width: 100%;
  }
}
.f-container .f-main-wrap {
  width: 100%;
  background-color: #fff;
}
.f-container .fadeIn {
  filter: blur(10px);
  transform: scale(1.02);
  opacity: 0;
  transition: filter 1s, opacity 1s, transform 1s;
}
.f-container .fadeIn.first {
  transition-delay: 0 !important;
  visibility: hidden;
}
.f-container .fadeIn.first.showed {
  visibility: visible;
}
.f-container .fadeIn.showed {
  filter: blur(0);
  transform: scale(1);
  opacity: 1;
}
@keyframes upDown {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-5px);
  }
}
.f-container .fadeUp {
  opacity: 0;
  transform: translate(0px, 100px);
  backface-visibility: hidden;
  pointer-events: none;
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.f-container .fadeUp.showed {
  opacity: 1;
  transform: translate(0px, 0px);
  pointer-events: auto;
}
.f-container .hero__box {
  position: relative;
  margin-bottom: calc(151 * var(--formula));
}
.f-container .hero__title {
  width: calc(392.519 * var(--formula));
  position: absolute;
  top: calc(131 * var(--formula));
  left: calc(178.7 * var(--formula));
  display: flex;
  flex-direction: column;
  align-items: center;
}
.f-container .hero__title-brand {
  width: calc(269.303 * var(--formula));
  margin-bottom: calc(29 * var(--formula));
}
.f-container .hero__arrow {
  width: calc(81.5 * var(--formula));
  position: absolute;
  left: calc(327.5 * var(--formula));
  bottom: calc(60 * var(--formula));
  animation: upDown 0.6s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite alternate;
}
.f-container .hero__text {
  width: calc(564.189 * var(--formula));
  margin: 0 auto calc(156 * var(--formula));
}
.f-container .sec .abs {
  position: absolute;
  z-index: 3;
}
.f-container .sec .st {
  position: sticky;
  top: calc(93 * var(--formula));
}
.f-container .sec .scroll-container {
  position: relative;
  overflow: hidden;
}
.f-container .sec .scroll-content {
  display: flex;
  width: -moz-max-content;
  width: max-content;
}
.f-container .sec__area {
  position: relative;
}
.f-container .sec__bottom {
  position: relative;
  background-color: #fff;
  z-index: 30;
}
.f-container .sec__btn {
  display: block;
  width: 100%;
  height: calc(93 * var(--formula));
  background-color: #e7e7e7;
  cursor: pointer;
  z-index: 2;
  display: flex;
  align-items: center;
}
.f-container .sec__btn.btn02 {
  background-color: #ccdef4;
}
.f-container .sec__btn span {
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(32 * var(--formula));
  line-height: calc(38.4 * var(--formula));
  padding-left: calc(43 * var(--formula));
  margin-bottom: calc(-2 * var(--formula));
}
.f-container .sec__btn {
  position: relative;
}
.f-container .sec__btn::after {
  display: inline-block;
  content: "";
  width: calc(40.75 * var(--formula));
  height: calc(40.75 * var(--formula));
  background-color: none;
  background: no-repeat url(../img/open_btn.svg);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: calc(44.5 * var(--formula));
}
.f-container .sec__contents {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.2s ease;
}
.f-container .sec__area.open .sec__btn {
  position: sticky;
  top: 0;
  z-index: 10;
}
.f-container .sec__area.open .sec__btn.release {
  position: relative !important;
}
.f-container .sec__area.open .sec__btn::after {
  height: calc(40.75 * var(--formula));
  height: max(1px, 2 * var(--formula));
  background-color: #000;
  background-image: none;
}
.f-container .sec__area.open .sec__contents {
  overflow: visible;
}
.f-container .sec__title {
  display: flex;
  flex-direction: column;
}
.f-container .sec__title span {
  color: #fff;
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.f-container .sec__title span:nth-of-type(1) {
  font-size: calc(43.08 * var(--formula));
  line-height: calc(51.69 * var(--formula));
}
.f-container .sec__title span:nth-of-type(2) {
  font-size: calc(32 * var(--formula));
  line-height: calc(38.4 * var(--formula));
}
.f-container .sec__box {
  position: relative;
}
.f-container .sec01 .box01 {
  margin-bottom: calc(151 * var(--formula));
}
.f-container .sec01 .box01 .title01 {
  bottom: calc(55 * var(--formula));
  left: calc(45 * var(--formula));
}
.f-container .sec01 .box01 .title01 span:nth-of-type(1) {
  margin-bottom: calc(45 * var(--formula));
}
.f-container .sec01 .sec__pad {
  width: 100%;
}
.f-container .sec01 .sec__text {
  margin-left: calc(45 * var(--formula));
}
.f-container .sec01 .text01 {
  width: calc(657.382 * var(--formula));
  margin-bottom: calc(78 * var(--formula));
}
.f-container .sec01 .text02 {
  width: calc(653.249 * var(--formula));
  margin-bottom: calc(101 * var(--formula));
}
.f-container .sec01 .text03 {
  width: calc(636.612 * var(--formula));
  margin-bottom: calc(64 * var(--formula));
}
.f-container .sec01 .text04 {
  width: calc(656.619 * var(--formula));
  margin-bottom: calc(160 * var(--formula));
}
.f-container .sec01 .text05 {
  width: calc(429.616 * var(--formula));
  margin-bottom: calc(62 * var(--formula));
}
.f-container .sec01 .text06 {
  width: calc(658.432 * var(--formula));
}
.f-container .sec01 .pad01 {
  height: calc(142 * var(--formula));
}
.f-container .sec01 .text07 {
  width: calc(429.616 * var(--formula));
  margin-bottom: calc(63 * var(--formula));
}
.f-container .sec01 .text08 {
  width: calc(657.315 * var(--formula));
  margin-bottom: calc(156 * var(--formula));
}
.f-container .sec01 .img04 {
  margin-bottom: calc(153 * var(--formula));
}
.f-container .sec01 .text09 {
  width: calc(114.861 * var(--formula));
  margin-bottom: calc(61 * var(--formula));
}
.f-container .sec01 .text10 {
  width: calc(636.532 * var(--formula));
  margin-bottom: calc(69 * var(--formula));
}
.f-container .sec01 .text11 {
  width: calc(658.883 * var(--formula));
  margin-bottom: calc(157 * var(--formula));
}
.f-container .sec01__scroll {
  position: relative;
}
.f-container .sec01 .scroll-content {
  margin-bottom: calc(150 * var(--formula));
  -moz-column-gap: calc(10 * var(--formula));
       column-gap: calc(10 * var(--formula));
}
.f-container .sec01 .scroll-content .sec__img {
  width: calc(370 * var(--formula));
}
.f-container .sec01 .sec__about {
  width: calc(659.982 * var(--formula));
  padding-bottom: calc(107 * var(--formula));
  margin-left: calc(47 * var(--formula));
}
.f-container .sec01 .sec__about > * {
  font-size: 0;
}
.f-container .sec01 .sec__about-title {
  width: calc(309.803 * var(--formula));
  padding-bottom: calc(25 * var(--formula));
}
.f-container .sec01 .sec__about-text {
  border-top: calc(2 * var(--formula)) solid #000;
  padding-top: calc(35 * var(--formula));
  width: calc(655.262 * var(--formula));
}
@media (min-width: 768px) {
  .f-container .sec01.safari .text03,
  .f-container .sec01.safari .text05,
  .f-container .sec01.safari .text07 {
    margin-left: calc(30 * var(--formula));
  }
  .f-container .sec01.safari .sec__about-title {
    margin-left: calc(-27 * var(--formula));
  }
}
.f-container .sec02 {
  will-change: transform;
  backface-visibility: hidden;
  background-color: #ccdef4;
}
.f-container .sec02 .st2 {
  width: calc(585 * var(--formula));
  margin: 0 auto;
  padding: calc(77.5 * var(--formula)) 0;
}
.f-container .sec02 .dfl {
  display: flex;
  flex-wrap: nowrap;
}
.f-container .sec02 .sec__num {
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: calc(30 * var(--formula));
  line-height: calc(36 * var(--formula));
  padding-left: calc(45 * var(--formula));
  margin-bottom: calc(24 * var(--formula));
}
.f-container .sec02 .sec__img a {
  position: relative;
}
.f-container .sec02 .sec__img a::before {
  display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
}
.f-container .sec02 .sec__img a img {
  transition: all 0.3s ease-in-out;
  position: relative;
  z-index: 2;
}
.f-container .sec02 .sec__img a:hover {
  opacity: 1;
}
.f-container .sec02 .sec__img a:hover img {
  opacity: 0.7;
}
@media (max-width: 768px) {
  .f-container .sec02 .sec__img a:hover img {
    opacity: 1;
  }
}
.f-container .sec02 .sec__slide .splide {
  position: relative;
}
.f-container .sec02 .sec__slide .splide .splide__pagination {
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  align-items: center;
  padding: 0;
  -moz-column-gap: calc(8 * var(--formula));
       column-gap: calc(8 * var(--formula));
  margin-left: auto;
  bottom: calc(43 * var(--formula));
  right: calc(45 * var(--formula));
}
.f-container .sec02 .sec__slide .splide .splide__pagination .splide__pagination__page {
  transform: scale(1);
  width: calc(10 * var(--formula));
  height: calc(10 * var(--formula));
  border-radius: 50%;
  opacity: 1;
  border: max(1 * var(--formula), 1px) solid #fff;
  background-color: transparent;
  margin: 0;
}
.f-container .sec02 .sec__slide .splide .splide__pagination .splide__pagination__page.is-active {
  transform: scale(1);
  width: calc(10 * var(--formula));
  height: calc(10 * var(--formula));
  background-color: #fff;
}
.f-container .sec02 .sec__credit .credit .item a {
  display: flex;
  flex-wrap: wrap;
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(21 * var(--formula));
  line-height: calc(25.2 * var(--formula));
  letter-spacing: 0.014em;
}
.f-container .sec02 .sec__credit.abs {
  left: calc(45 * var(--formula));
  bottom: calc(34 * var(--formula));
}
.f-container .sec02 .sec__credit.abs .credit {
  display: flex;
  flex-direction: column;
}
.f-container .sec02 .sec__credit.abs .credit .item a {
  display: flex;
  flex-wrap: wrap;
  font-family: "helvetica-lt-pro", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: calc(21 * var(--formula));
  line-height: calc(31.6 * var(--formula));
  letter-spacing: 0.036em;
  color: #fff;
}
.f-container .sec02 .box00_1 .title00 {
  bottom: calc(61 * var(--formula));
  left: calc(45 * var(--formula));
}
.f-container .sec02 .box00_1 .title00 span:nth-of-type(1) {
  margin-bottom: calc(53 * var(--formula));
}
.f-container .sec02 .box00_2 {
  padding-top: calc(150 * var(--formula));
  padding-bottom: calc(153 * var(--formula));
}
.f-container .sec02 .box00_2 .img00_2 {
  width: calc(570 * var(--formula));
  margin-left: calc(90 * var(--formula));
  margin-bottom: calc(14 * var(--formula));
}
.f-container .sec02 .box00_2 .sec__sub {
  margin-left: calc(90 * var(--formula));
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(22 * var(--formula));
  line-height: calc(26.4 * var(--formula));
  letter-spacing: 0.014em;
}
.f-container .sec02 .cd01 .box02 {
  margin-bottom: calc(156 * var(--formula));
}
.f-container .sec02 .cd02 .box02 {
  margin-bottom: calc(220 * var(--formula));
}
.f-container .sec02 .cd02 .box03 {
  width: 100%;
  margin-bottom: calc(220 * var(--formula));
  -moz-column-gap: calc(10 * var(--formula));
       column-gap: calc(10 * var(--formula));
}
.f-container .sec02 .cd02 .box03 .sec__img {
  width: calc(370 * var(--formula));
}
.f-container .sec02 .cd02 .box03 .sec__img:nth-of-type(even) {
  margin-left: auto;
}
.f-container .sec02 .cd02 .box04 {
  width: calc(585 * var(--formula));
  margin: 0 auto;
  margin-bottom: calc(200 * var(--formula));
}
.f-container .sec02 .cd02 .box04 .slide02 {
  margin-bottom: calc(23 * var(--formula));
}
.f-container .sec02 .cd03 .box02 {
  margin-bottom: calc(156 * var(--formula));
}
.f-container .sec02 .cd04 .credit04.abs {
  bottom: calc(28 * var(--formula));
}
.f-container .sec02 .cd04 .sec__slide .splide .splide__pagination {
  bottom: calc(36 * var(--formula));
}
.f-container .sec02 .sec__all {
  padding-top: calc(56 * var(--formula));
  padding-bottom: calc(53 * var(--formula));
  padding-left: calc(44 * var(--formula));
}
.f-container .sec02 .sec__all-btn {
  width: calc(196.953 * var(--formula));
}
.f-container .sec02 .sec__staff {
  background-color: #e7e7e7;
  padding-top: calc(46 * var(--formula));
  padding-bottom: calc(46 * var(--formula));
  padding-left: calc(44 * var(--formula));
}
.f-container .sec02 .sec__staff-text {
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(21 * var(--formula));
  line-height: calc(36 * var(--formula));
}
.f-container .profile {
  display: flex;
  align-items: center;
  flex-direction: column;
  padding-top: calc(183 * var(--formula));
}
.f-container .profile__img {
  width: calc(585 * var(--formula));
  margin-bottom: calc(54 * var(--formula));
}
.f-container .profile__name {
  font-family: "tt-commons-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(32 * var(--formula));
  line-height: calc(38.4 * var(--formula));
  margin-bottom: calc(34 * var(--formula));
}
.f-container .profile__text {
  width: calc(587.4 * var(--formula));
  font-family: "yu-gothic-pr6n", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(18 * var(--formula));
  line-height: calc(34.5 * var(--formula));
  margin-bottom: calc(126 * var(--formula));
  text-align: justify;
}
.f-container .profile__text span {
  display: inline-block;
}
.f-container .back-to-top {
  width: calc(588.399 * var(--formula));
  margin: 0 auto;
  margin-bottom: calc(37.4 * var(--formula));
}
.f-container .brand-name {
  width: calc(248 * var(--formula));
  margin: 0 auto calc(155 * var(--formula));
}