﻿/* パンくず 追加スタイル PC */
@media only screen and (min-width: 768px) {
  .breadcrumb__list {
    padding-bottom: 1.6rem;
  }
}

/* ページ共通___________________________*/
.main-area {
  /* font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif; */
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "Yu Gothic", "Open Sans", "メイリオ", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  font-size: calc(13* (100vw / 375));
  padding-bottom: calc(100*(100vw / 375));
  text-align: center;
  overflow-x: clip;
  letter-spacing: 0.075em;
  color: #2C2C2C;
}

.main-area * {
  letter-spacing: 0.075em;
}

.main-area img,
.main-area picture {
  width: 100%;
  height: auto;
}

.main-area a,
.main-area picture {
  display: inline-block;
}

@font-face {
  font-family: "HKGrotesk_medium";
  src: url("../fonts/HKGrotesk-Medium.otf") format("opentype");
}

@font-face {
  font-family: "HKGrotesk_semibold";
  src: url("../fonts/HKGrotesk-SemiBold.otf") format("opentype");
}

@font-face {
  font-family: "HKGrotesk_bold";
  src: url("../fonts/HKGrotesk-Bold.otf") format("opentype");
}

.ff_hkg_m {
  font-family: "HKGrotesk_medium";
  font-weight: 500;
  font-style: normal;
  line-height: 1;
}

.ff_hkg_semi {
  font-family: "HKGrotesk_semibold";
  font-weight: 600;
  font-style: normal;
  line-height: 1;
}

.ff_hkg_b {
  font-family: "HKGrotesk_bold";
  font-weight: 700;
  font-style: normal;
  line-height: 1;
}

_:lang(x)+_:-webkit-full-screen-document,
.ff_hkg_b {
  font-weight: 600;
  -webkit-font-smoothing: antialiased;
}


.ff_bask {
  font-family: "Baskerville", serif;
  font-weight: 300;
  letter-spacing: 0.05em;
  line-height: 1;
}

.ff_ernie {
  font-family: "adobe-handwriting-ernie", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.main-area .lp_credit {
  font-size: calc(12*(100vw / 375));
  margin: calc(10 * (100vw / 375)) 0 0 0;
  text-align: right;
  line-height: 2;
  display: flex;
  flex-direction: column;
  white-space: nowrap;
  /* gap: calc(6*(100vw / 375)); */
}

.main-area .lp_credit a {
  text-decoration: underline;
}

@media screen and (max-width: 767px) {
  .main-area .pcOnly {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .main-area {
    font-size: 1.4rem;
    padding-bottom: 10.3rem;
  }

  .main-area .spOnly {
    display: none;
  }

  .main-area a {
    transition: all 0.3s;
  }

  .ff_gara {
    font-size: 5rem;
  }

  .main-area .lp_credit {
    font-size: 1.2rem;
    margin: 1rem 0 0 0;
    line-height: 2;
    gap: 0;
  }
}

/* ===============================================
* fv *
=============================================== */
.sec__fv {
  position: relative;
}

.fv_txt {
  width: calc(345* (100vw /375));
  margin: calc(50 * (100vw / 375)) auto 0;
}

.fv_txt .fv_title {
  font-weight: 600;
  font-size: calc(20 * (100vw / 375));
  text-align: center;
}

.fv_txt p {
  font-size: calc(14 * (100vw / 375));
  font-weight: 500;
  text-align: center;
  margin: calc(20 * (100vw / 375)) 0 0 0;
  line-height: 1.6;
}

.nav_list {
  width: calc(344* (100vw /375));
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc(8 * (100vw / 375));
  margin: calc(30* (100vw /375)) auto 0;
}

.nav_list li {
  width: calc(165* (100vw /375));
  position: relative;
}

.styled-button {
    display: inline-flex;
    align-items: center;
    justify-content: start;
    padding: calc(9* (100vw /375)) calc(20* (100vw /375));
    background-color: #5A6384;
    border: none;
    cursor: pointer;
    font-size: calc(15* (100vw /375));
    color: #fff;
    letter-spacing: 0.1em;
}

.button-text {
    margin-right: calc(20* (100vw /375));
}

/* CSSで描画する矢印アイコン */
.arrow-icon {
    width: calc(20* (100vw /375));
    height: calc(20* (100vw /375));
    stroke:#fff;
    transition: transform 0.3s ease;
    position: absolute;
    right: calc(15* (100vw /375));
    top: calc(5* (100vw /375));
}

@media screen and (min-width: 768px) {
  .sec__fv h2 {
    width: 120rem;
    margin: auto;
  }

  .fv_txt {
    width: 80rem;
    margin: 6rem auto 0;
  }

  .fv_txt .fv_title {
    font-size: 2.2rem;
  }

  .fv_txt p {
    font-size: 1.4rem;
    margin: 3rem 0 0 0;
  }

  .nav_list {
    width: 63rem;
    gap: 1.5rem;
    margin: 5rem auto 0;
  }

  .nav_list li {
    width: 20rem;
  }
  .styled-button {
      padding: 1rem 1.2rem 0.9rem 2.9rem;
      font-size: 1.6rem;
      /* ホバー時の矢印アニメーションのベース設定 */
      transition: background-color 0.3s ease; /* 背景色の変化を滑らかに */
  }
  .styled-button a:hover {
    opacity: 1;
  }

  .button-text {
      margin-right: 2rem;
  }

  /* CSSで描画する矢印アイコン */
  .arrow-icon {
      right: 1.2rem;
      top: 0.5rem;
      width: 2rem;
      height: 2rem;
      transition: transform 0.3s ease;
  }
  .styled-button:hover .arrow-icon {
      transform: translateY(5px); /* 下に5px移動 */
  }
}

/* ===============================================
* sec *
=============================================== */
.img-wrap {
  display: flex;
  justify-content: center;
}

.sec__style {
  width: calc(375 * (100vw / 375));
  margin-left: auto;
  margin-right: auto;
}

.sec__style__num {
  font-size: calc(14* (100vw /375));
  letter-spacing: 0.05em;
  color: #5A6384;
  text-align: center;
}

.sec__style__title {
  font-size: calc(34* (100vw /375));
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: calc(10* (100vw /375));
}

.sec__style__lead {
  font-size: calc(14* (100vw /375));
  text-align: center;
  margin-top: calc(15* (100vw /375));
  line-height: 1.6;
}

@media screen and (min-width: 768px) {
  .sec__style {
    width: 100%;
  }

  .sec__style__num {
    font-size: 1.7rem;
  }

  .sec__style__title {
    font-size: 4rem;
    margin-top: 1rem;
  }

  .sec__style__lead {
    font-size: 1.4rem;
    margin-top: 1.5rem;
  }
}

/* ===============================================
* sec1 *
=============================================== */
@media screen and (max-width: 767px) {
  .sec__style {
      margin-top: calc(65 * (100vw / 375));
  }

  .sec__style .img-wrap01 {
    margin-top: calc(30 * (100vw / 375));
    flex-direction: column;
    gap: calc(10* (100vw /375));
  }

  .sec__style1 .img0101 {
    width: calc(300* (100vw /375));
    margin-left: 0;
  }
  .sec__style1 .img0102 {
    width: calc(300* (100vw /375));
    margin-left: calc(75* (100vw /375));
  }
  .sec__style1 .lp_credit {
    padding-right: calc(15* (100vw /375));
  }
}

@media screen and (min-width: 768px) {
  .sec__style {
    margin-top: 10rem;
  }

  .sec__style1 .img-wrap01 {
    width: 100rem;
    margin-left: auto;
    margin-right: auto;
    margin-top: 3rem;
    gap: 0.8rem;
  }

  .sec__style1 .img-wrap01+.lp_credit {
    width: 100rem;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ===============================================
* sec2 *
=============================================== */
@media screen and (max-width: 767px) {
  .sec__style2 .img-wrap01 {
    flex-direction: column;
    gap: calc(20* (100vw /375));
  }
  .sec__style2 .lp_credit {
    padding-right: calc(15 * (100vw / 375));
  }
  .sec__style2 .img-wrap02 {
    margin: calc(40 * (100vw / 375)) auto 0;
    flex-direction: column;
    width: calc(300 * (100vw / 375));
    gap: calc(10 * (100vw / 375));
  }

  .sec__style2 .img-wrap02+.lp_credit {
    padding-right: calc(35 * (100vw / 375));
  }
}

@media screen and (min-width: 768px) {
  .sec__style2 {
    margin-top: 12.7rem;
  }

  .sec__style2 .img-wrap01 {
    width: 49.6rem;
    margin: 3rem auto 0;
    flex-direction: column;
  }
  .sec__style2 .lp_credit {
    width: 49.6rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
  .sec__style2 .img-wrap02 {
    width: 100rem;
    margin: 7rem auto 0;
    flex-direction: row;
    gap: 0.8rem;
  }

  .sec__style2 .img-wrap02+.lp_credit {
    width: 100rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
}

/* ===============================================
* sec3 *
=============================================== */
@media screen and (max-width: 767px) {
  .sec__style3 .lp_credit {
    padding-right: calc(15 * (100vw / 375));
  }
  .sec__style3 .img-wrap02 {
    margin: calc(40 * (100vw / 375)) auto 0;
  }
  .sec__style3 .img-wrap03 {
    margin: calc(11 * (100vw / 375)) auto 0;
    gap: calc(11 * (100vw / 375));
  }
}

@media screen and (min-width: 768px) {
  .sec__style3 {
    margin-top: 12rem;
  }

  .sec__style3 .img-wrap01 {
    width: 49.6rem;
    margin: 3rem auto 0;
    flex-direction: column;
  }
  .sec__style3 .lp_credit {
    width: 49.6rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
  .sec__style3 .img-wrap02 {
    width: 49.6rem;
    margin: 7rem auto 0;
  }

  .sec__style3 .img-wrap03 {
    width: 100rem;
    margin-left: auto;
    margin-right: auto;
    margin-top: 7rem;
    gap: 0.8rem;
  }

  .sec__style3 .img-wrap03+.lp_credit {
    width: 100rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
}

/* ===============================================
* sec4 *
=============================================== */
@media screen and (max-width: 767px) {
  .sec__style4 {
    margin-top: calc(89* (100vw /375));
  }

  .sec__style4 .img-wrap01 {
    /*height: calc(165 * (100vw / 375)); 親要素の切り取る高さを調整 */
    position: relative;
    overflow: hidden; /* ★ここが重要: はみ出る部分を隠す */
    padding-top: calc(215 * (100vw / 375)); /* ★画像に合わせて計算した縦横比 */
    height: 0; /* padding-topを使うためheightを0にする */
  }
  .sec__style4 .parallax_content {
    position: absolute;
    top: calc(50 * (100vw / 375));
    left: 0;
    width: 100%;
    height: calc(100% + 50px); /* ★少しだけ高さを大きくする (パララックス移動の余裕を持たせるため) */
    
    display: flex;
    /* background-attachment: fixed; は削除 */
    background-position: center top;
    background-size: cover; /* ★coverを維持 */
    background-repeat: no-repeat;
    
    /* JSで transform: translateY を適用するので、初期値を設定 */
    transform: translateY(0);
    will-change: transform; /* アニメーションのパフォーマンス最適化 */
  }
  .sec__style4 .img0601 {
    background-image: url(../img/sp/img0601.jpg);
  }

  .sec__style4 .img-wrap02 {
    width: calc(300* (100vw /375));
    margin: calc(40* (100vw /375)) auto 0;
  }
  .sec__style4 .lp_credit {
    padding-right: calc(37 * (100vw / 375));
  }
  .sec__style4 .img-wrap03 {
    width: calc(375* (100vw /375));
    margin: calc(40* (100vw /375)) auto 0;
    flex-direction: column;
  }
  .sec__style4 .img-wrap03+.lp_credit {
    padding-right: calc(15 * (100vw / 375));
  }
}

@media screen and (min-width: 768px) {
  .sec__style4 {
    margin-top: 12rem;
  }

  .sec__style4 .img-wrap01 {
    margin: 3rem auto 0;
    flex-direction: column;
  }

  .sec__style4 .parallax_content {
    display: flex;
    height: 50rem;
    justify-content: center;
    align-items: center;
    background-attachment: fixed;
    background-position: center top;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .sec__style4 .img0601 {
    background-image: url(../img/img0601.jpg);
  }

  .sec__style4 .img-wrap02 {
    width: 49.6rem;
    margin: 7rem auto 0;
  }
  .sec__style4 .lp_credit {
    width: 49.6rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
  .sec__style4 .img-wrap03 {
    width: 49.6rem;
    margin: 7rem auto 0;
    flex-direction: column;
  }
  .sec__style4 .img-wrap03+.lp_credit {
    width: 49.6rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }

}

/* ===============================================
* sec5 *
=============================================== */
@media screen and (max-width: 767px) {
  .sec__style5 .lp_credit {
    padding-right: calc(15 * (100vw / 375));
  }
  .sec__style5 .img-wrap01 {
    flex-direction: row;
    margin: calc(40 * (100vw / 375)) auto 0;
    gap: calc(13 * (100vw / 375));
  }
  .sec__style5 .img-wrap02 {
    margin: calc(11 * (100vw / 375)) auto 0;
  }
}

@media screen and (min-width: 768px) {
  .sec__style5 {
    margin-top: 12rem;
  }
  .sec__style5 .lp_credit {
    width: 49.6rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
  .sec__style5 .img-wrap01 {
    width: 100rem;
    flex-direction: row;
    margin: 3rem auto 0;
    gap: 0.8rem;
  }
  .sec__style5 .img-wrap02 {
    width: 49.6rem;
    margin: 7rem auto 0;
  }
}

/* ===============================================
* sec6 *
=============================================== */
@media screen and (max-width: 767px) {
  .sec__style6 .lp_credit {
    padding-right: calc(15 * (100vw / 375));
  }
  .sec__style6 .img-wrap01 {
    margin: calc(40 * (100vw / 375)) auto 0;
    gap: calc(10 * (100vw / 375));
  }
}

@media screen and (min-width: 768px) {
  .sec__style6 {
    margin-top: 12rem;
  }
  .sec__style6 .lp_credit {
    width: 100rem;
    margin-left: auto;
    margin-right: auto;
    padding-right: 0;
  }
  .sec__style6 .img-wrap01 {
    width: 100rem;
    flex-direction: row;
    margin: 3rem auto 0;
    gap: 0.8rem;
  }
}

/* ▽_____________ lp_foot_btn ______________▽ */
.main-area .lp_foot_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(345*(100vw / 375));
  height: calc(50*(100vw / 375));
  margin: calc(87 * (100vw / 375)) auto 0;
  line-height: 1;
  font-weight: 400;
  font-style: normal;
  font-size: calc(14*(100vw / 375));
  letter-spacing: 0.075em;
  background: #2C2C2C;
  color: #FFF;
}

.main-area .lp_foot_btn.second {
  margin: calc(15*(100vw / 375)) auto 0;
  border: #2C2C2C 1px solid;
  color: #2C2C2C;
  background: #FFF;
}

@media screen and (min-width: 768px) {
  .main-area .lp_foot_btn {
    width: 30rem;
    height: 5rem;
    font-size: 1.4rem;
    margin: 11.6rem auto 0;
  }

  .main-area .lp_foot_btn.second {
    margin: 1.5rem auto 0;
  }
}


/* ▽ imganime ▽ */
.js-fadeIn {
  opacity: 0;
  will-change: opacity;
  transition: ease-in, opacity 1000ms, transform 1000ms;
}

.show {
  opacity: 1;
}

.js-fadeIn.js-left {
  transform: translateX(-100px);
}

.js-fadeIn.js-right {
  transform: translateX(100px);
}

.js-fadeIn.js-bottom {
  transform: translateY(100px);
}

.js-fadeIn.js-left.show,
.js-fadeIn.js-right.show,
.js-fadeIn.js-bottom.show {
  transform: translate(0, 0);
}