@charset "UTF-8";

/* --------------- ▽ setting_area ▽ --------------- */
.header {
  position: fixed;
  top: 0;
}

html {
  font-size: 62.5%;
}

.A0607 {
  width: 100%;
  overflow: hidden;
  font-family: "HiraKakuProN-W5", "Hiragino Kaku Gothic ProN W5", "Hiragino Sans", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  letter-spacing: 0.075em;
}

.A0607 img {
  width: 100%;
}

.element {
  font-family: var(--font-jp);
  font-family: var(--font-en);
}

@media only screen and (max-width: 1399px) and (min-width: 768px) {
  html {
    font-size: calc(10* (100vw / 1400));
  }
}

@media only screen and (max-width: 767px) {
  html {
    font-size: calc(10* (100vw / 750));
  }
}

/* --------------- △ setting_area △ --------------- */

/* --------------- ▽ font_area ▽ --------------- */
.A0607 .font_jp {
  font-family: var(--font-jp);
  font-feature-settings: "palt";
}

.A0607 .font_en-01 {
  font-family: var(--font-en);
  font-weight: 400;
  font-style: normal;
}

.A0607 .font_en-02 {
  font-family: "trajan-pro-3", serif;
  font-weight: 600;
  font-style: normal;
}

/* --------------- △ font_area △ --------------- */

/* --------------- ▽ others_area ▽ --------------- */
.A0607 .sp_only {
  display: none;
}

@media screen and (max-width: 767px) {
  .A0607 {
    padding-block-start: calc(100*100vw/750);
  }

  .A0607 .pc_only {
    display: none;
  }

  .A0607 .sp_only {
    display: block;
  }
}

/* --------------- △ others_area △ --------------- */

/* --------------- ▽ animation__area ▽ --------------- */
.A0607 .fade_up {
  opacity: 0;
  transform: translate(0, 15%);
  transition: opacity 0.5s, transform 0.8s cubic-bezier(0, 0, 0.2, 1), -webkit-transform 0.5s cubic-bezier(0, 0, 0.2, 1);
}

.A0607 .fade_up.active {
  opacity: 1;
  transform: translate(0, 0);
}

.A0607 .fade_in {
  opacity: 0;
  transition: opacity 2s, transform 2s cubic-bezier(0, 0, 0.2, 1), -webkit-transform 2s cubic-bezier(0, 0, 0.2, 1);
}

.A0607 .fade_in.active {
  opacity: 1;
}

/* 文字送り */
.letterAnimation {
  position: relative;
}

.letterAnimation span {
  font-family: "trajan-pro-3", serif;
  font-weight: 600;
  font-style: normal;
  display: inline-block;
  position: relative;
  top: 20px;
  opacity: 0;
  transition: top .4s ease, opacity .4s ease;
}

.letterAnimation.showText span {
  top: 0;
  opacity: 1;

}




/* --------------- △ animation__area △ --------------- */

/* --------------- ▽ firstview_area ▽ --------------- */

.A0607 h2 {
  position: relative;
}

.A0607 .ttl_wrap {
  position: absolute;
  width: fit-content;
  bottom: calc(100* (100vw / 750));
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  color: #fff;
  line-height: 1;
  letter-spacing: 0;
  pointer-events: none;
  z-index: 1;
}

.A0607 .ttl_wrap .__1 {
  font-size: calc(42.35* (100vw / 750));
  letter-spacing: 0.2em;
  position: relative;
  left: calc(6* (100vw / 750));
}

.A0607 .ttl_wrap .__2 {
  font-size: calc(66.55* (100vw / 750));
  margin-top: calc(13* (100vw / 750));
  letter-spacing: 0.065em;
}

.A0607 .fv_lead {
  position: relative;
  width: 100vw;
  height: calc(350* (100vw / 750));
  font-size: calc(23* (100vw / 750));
  line-height: 1.869;
  letter-spacing: 0.04em;
  text-align: center;
  color: #fff;
  padding-top: calc(49* (100vw / 750));
}

.A0607 .fv_lead::before {
  content: "";
  position: absolute;
  background: url(../img/bg1_sp.jpg) center/cover no-repeat;
  width: 100%;
  height: 100%;
  top: calc(-1* (100vw / 750));
  left: 0;
  z-index: -1;
}

@media screen and (min-width: 768px) {

  .A0607 .ttl_wrap {
    bottom: 14.9rem;
    letter-spacing: 0;
  }

  .A0607 .ttl_wrap .__1 {
    font-size: 3.5rem;
    letter-spacing: 0.2em;
    left: 0.5rem;
  }

  .A0607 .ttl_wrap .__2 {
    font-size: 5.5rem;
    margin-top: 0.9rem;
    letter-spacing: 0.07em;
  }

  .A0607 .fv_lead {
    height: 28rem;
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.088em;
    padding-top: 7.3rem;
    padding-left: 0.2rem;
  }

  .A0607 .fv_lead::before {
    background: url(../img/bg1_pc.jpg) center/cover no-repeat;
    top: -1px;
  }
}

/* --------------- △ firstview_area △ --------------- */







/* ▽_____________ item_wrap ______________▽ */
.A0607 .item_wrap {
  margin-top: calc(154* (100vw / 750));
}

.A0607 .item_wrap .letterAnimation {
  text-align: center;
  letter-spacing: -0.03em;
  left: calc(5* (100vw / 750));
}

.A0607 .item_wrap .letterAnimation::before {
  content: "";
  position: absolute;
  background: #3F80A4;
  height: calc(3.9* (100vw / 750));
  width: calc(546* (100vw / 750));
  bottom: calc(-6* (100vw / 750));
  left: 50%;
  transform: translateX(-50%);
}

.A0607 .item_wrap .letterAnimation span {
  font-size: calc(50* (100vw / 750));
}

.A0607 h4 {
  font-family: "HiraKakuProN-W6", "Hiragino Kaku Gothic ProN W6", "Hiragino Sans", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 600;
  letter-spacing: 0.05em;
  font-feature-settings: "palt";
  font-size: calc(30* (100vw / 750));
  line-height: 1.65;
  text-align: center;
  margin-top: calc(60* (100vw / 750));
}

.A0607 h4 span {
  position: relative;
  left: calc(-6* (100vw / 750));
  color: #3F80A4;
}

.A0607 .item_wrap_inner {
  width: calc(650* (100vw / 750));
  margin: calc(37* (100vw / 750)) auto 0;
}

.A0607 .item_tx {
  margin-top: calc(30* (100vw / 750));
  line-height: 1.869;
  font-size: calc(23* (100vw / 750));
  letter-spacing: 0.07em;
  font-feature-settings: "palt";
  text-align: justify;
}

.A0607 .item_img a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(51* (100vw / 750));
  margin-top: calc(40* (100vw / 750));
}

.A0607 .item_img p {
  text-decoration: underline;
  font-size: calc(24* (100vw / 750));
  letter-spacing: 0.05em;
  font-family: var(--font-en);
}

.A0607 .item_detail {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: calc(17* (100vw / 750)) calc(14* (100vw / 750));
  margin-top: calc(81* (100vw / 750));
}

.A0607 .item_detail li {
  width: calc(317.77* (100vw / 750));
}

.A0607 .item_detail .detail_tx {
  position: relative;
  width: calc(313* (100vw / 750));
  font-size: calc(23* (100vw / 750));
  line-height: 1.869;
  margin-top: calc(-9* (100vw / 750));
  letter-spacing: -0.035em;
  text-align: justify;
}

.A0607 .item_detail .detail_tx::after {
  content: '.';
  display: inline-block;
  width: 0;
  color: transparent;
  pointer-events: none;
}

.A0607 .item_detail .detail_tx span {
  font-size: calc(23* (100vw / 750));
  line-height: 1.869;
  white-space: nowrap;
  letter-spacing: -0.01em;
}

@media screen and (min-width: 768px) {
  .A0607 .item_wrap {
    width: 90rem;
    margin: 24.2rem auto 0;
    position: relative;
  }

  .A0607 .item_wrap .item_ttl {
    position: absolute;
    top: -6rem;
    left: -0.3rem;
  }

  .A0607 .item_wrap .letterAnimation {
    letter-spacing: -0.02em;
    left: 0.3rem;
  }

  .A0607 .item_wrap .letterAnimation::before {
    height: 0.3rem;
    width: 44rem;
    bottom: -0.5rem;
    left: 50%;
    transform: translateX(-50%);
  }

  .A0607 .item_wrap .letterAnimation span {
    font-size: 4rem;
  }

  .A0607 h4 {
    letter-spacing: 0.05em;
    font-size: 2rem;
    line-height: 1.74;
    margin-top: 4.2rem;
    font-feature-settings: normal;
  }

  .A0607 h4 span {
    left: 0;
  }

  .A0607 .item_wrap_inner {
    width: 89.5rem;
    margin: 0 auto 0;
    display: grid;
    grid-template-columns: 46rem auto;
    grid-template-rows: 12rem 25.5rem auto;
  }

  .A0607 .item_tx {
    margin-top: 0;
    line-height: 2.076;
    font-size: 1.3rem;
    letter-spacing: 0.07em;
    width: 45rem;
    grid-column: 1;
    grid-row: 2;

  }

  .A0607 .item_img {
    width: 50rem;
    grid-column: 2;
    grid-row: 1;
  }

  .A0607 .item_img a {
    gap: 2.1rem;
    margin-top: 0;
  }

  .A0607 .item_img p {
    font-size: 1.5rem;
  }

  .A0607 .item_detail {
    gap: 1.1rem 1rem;
    margin-top: 0;
    grid-column: 1;
    grid-row: 3;
    width: 45rem;
  }

  .A0607 .item_detail li {
    width: 22rem;
  }

  .A0607 .item_detail .detail_tx {
    width: 21.6rem;
    font-size: 1.3rem;
    line-height: 2.076;
    margin-top: -0.6rem;
    letter-spacing: -0.01em;
  }
}

/* model_wrap */
.A0607 .model_wrap {
  margin-top: calc(136* (100vw / 750));
}

.A0607 .model_tx h4 {
  position: relative;
  letter-spacing: 0.12em;
  margin-top: calc(67* (100vw / 750));
}

.A0607 .model_tx h4 span {
  left: calc(1* (100vw / 750));
  letter-spacing: 0.1em;
}

.A0607 .model_tx .model_detail {
  position: relative;
  margin: calc(50* (100vw / 750)) auto 0;
  width: calc(652* (100vw / 750));
  font-size: calc(23* (100vw / 750));
  line-height: 1.869;
  font-feature-settings: "palt";
  letter-spacing: 0.08em;
  text-align: justify;
}

.A0607 .model_tx .model_detail::before,
.A0607 .model_tx .model_detail::after {
  content: "";
  position: absolute;
  background: #000;
  height: 99%;
  width: calc(1.7* (100vw / 750));
  top: calc(-1* (100vw / 750));
}

.A0607 .model_tx .model_detail::before {
  left: calc(-32* (100vw / 750));
}

.A0607 .model_tx .model_detail::after {
  right: calc(-35* (100vw / 750));
}

.A0607 .model_tx .model_credit {
  margin-top: calc(47* (100vw / 750));
}

.A0607 .model_credit {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0 calc(25*100vw/750);
  font-size: calc(24*100vw/750);
  line-height: 1.9166666667;
  letter-spacing: 0.05em;
}

.A0607 .model_credit::after {
  width: 100%;
  content: "";
}

.A0607 .model_credit a {
  display: inline-block;
  text-decoration: underline;
}



@media screen and (max-width: 767px) {
  .A0607 .model_credit li:nth-child(n+3) {
    order: 1;
  }

  .A0607 .model_wrap>li:nth-child(n+2) {
    margin-top: calc(109* (100vw / 750));
  }
}


@media screen and (min-width: 768px) {
  .A0607 .model_wrap {
    margin-top: 14.7rem;
  }

  .A0607 .model_wrap>li {
    width: 140rem;
    margin: auto;
    display: flex;
  }

  .A0607 .sec1 .model_wrap li:nth-child(even) {
    flex-direction: row-reverse;
  }

  .A0607 .sec2 .model_wrap li:nth-child(odd) {
    flex-direction: row-reverse;
  }

  .A0607 .model_wrap .img_wrap {
    width: 70rem;
    position: relative;
  }

  .A0607 .model_tx {
    width: 70rem;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 23.9rem;
  }

  .A0607 .model_tx::before {
    content: "";
    position: absolute;
    width: 16.6rem;
    height: 0.1rem;
    background: #000;
    top: 42.3rem;
    left: -2.7rem;
    pointer-events: none;
  }

  .A0607 .sec1 .model_wrap li:nth-child(even) .model_tx::before {
    left: initial;
    right: -2.7rem;
  }

  .A0607 .sec2 .model_wrap li:nth-child(odd) .model_tx::before {
    left: initial;
    right: -2.7rem;
  }

  .A0607 .model_tx h4 {
    width: 37rem;
    letter-spacing: 0.05em;
    margin-top: 0;
    line-height: 1.6;
    text-align: left;
  }

  .A0607 .model_tx h4 span {
    left: 0;
    letter-spacing: 0.05em;
  }

  .A0607 .model_tx .model_detail {
    margin: 2.7rem auto 0;
    width: 37.2rem;
    font-size: 1.3rem;
    line-height: 2.076;
    font-feature-settings: "palt";
    letter-spacing: 0.075em;
  }

  .A0607 .model_tx .model_detail::before,
  .A0607 .model_tx .model_detail::after {
    width: 0.1rem;
    top: 0;
    height: 98%;
  }

  .A0607 .model_tx .model_detail::before {
    left: -2.5rem;
  }

  .A0607 .model_tx .model_detail::after {
    right: -2.5rem;
  }

  .A0607 .model_tx .model_credit {
    margin-top: 2.3rem;
  }

  .A0607 .model_credit {
    gap: 0 1.3rem;
    font-size: 1.2rem;
    line-height: 2.166;
    justify-content: left;
    margin-left: 11.6rem;
  }

  .A0607 .model_credit li:nth-child(n+4) {
    order: 1;

  }






  /* model2 */
  .A0607 .model2 .model_credit {
    width: initial;
    margin-left: 15.6rem;
  }

}

.A0607 .img_bg {
  position: relative;
  width: 100vw;
  height: calc(280* (100vw / 750));
  z-index: -1;
  top: calc(57* (100vw / 750));
  left: 0;
  pointer-events: none;
}

@media screen and (min-width: 768px) {

  .A0607 .img_bg {
    height: 28rem;
    top: -14rem;
  }
}

/* ▽_____________ sec2 ______________▽ */
.A0607 .sec2 {
  position: relative;
  margin-top: calc(-19* (100vw / 750));
}

.A0607 .sec2 .item_wrap .letterAnimation::before {
  width: calc(640* (100vw / 750));
}

.A0607 .sec2 .item_img a {
  margin-top: calc(46* (100vw / 750));
  gap: calc(26* (100vw / 750));
}

.A0607 .sec2 .item_detail .detail_tx {
  font-feature-settings: normal;
}

@media screen and (min-width: 768px) {
  .A0607 .sec2 {
    margin-top: -14.2rem;
  }

  .A0607 .sec2 .item_tx {
    letter-spacing: 0.05em;
  }

  .A0607 .sec2 .item_wrap .item_ttl {
    left: -3rem;
  }

  .A0607 .sec2 .item_wrap .letterAnimation::before {
    width: 51rem;
  }

  .A0607 .sec2 .item_img a {
    margin-top: 0.9rem;
    gap: 2.3rem;
  }

  .A0607 .sec2 .item_detail .detail_tx {
    font-feature-settings: "halt";
  }

  .A0607 .sec2 .model_wrap {
    margin-top: 14.1rem;
  }
}







/* ▽_____________ check_btn ______________▽ */
.A0607 .check_btn {
  width: fit-content;
  margin: calc(178*100vw/750) auto calc(91*100vw/750);
  padding-block-end: calc(1*100vw/750);
  font-size: calc(30*100vw/750);
  line-height: 1.2;
  letter-spacing: 0.037em;
  border-bottom: solid 1px #1A1311;
  text-align: center;
  color: #000;
}

@media screen and (min-width: 768px) {
  .A0607 .check_btn {
    margin: 16.7rem auto 17rem;
    padding-block-end: 0.1rem;
    font-size: 1.8rem;
  }
}