@charset "UTF-8";
/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Setting
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.header {
  position: fixed;
  top: 0;
} 
@media only screen and (max-width: 1400px) and (min-width: 767px) {
  html {
    font-size: calc(10*100vw/1400);
  }
}
.A1101 {
  --color_black: #000000;
  --color_white: #ffffff;
  --color_gold: #B9A900;
  --font_ja: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Hiragino Sans",  "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", Arial, "メイリオ", "Meiryo", sans-serif;
  --font_en01: "nimbus-sans", sans-serif;
  --font_en02: "trajan-pro-3", serif;
}
.A1101 {
  width: 100%;
  overflow: hidden;
}
.A1101 section {
  position: relative;
  z-index: 2;
}
.A1101 picture,
.A1101 picture > a {
  width: 100%;
  height: 100%;
}
.A1101 picture > a {
  display: block;
}
.A1101 img,
.A1101 video,
.A1101 svg {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.A1101 .font_ja {
  font-family: var(--font_ja);
  font-feature-settings: "palt";
}
.A1101 .font_en01 {
  font-family: var(--font-en);
  font-weight: 400;
}
.A1101 .font_en02 {
  font-family: var(--font_en02);
  font-weight: 400;
}
#header .header__inner svg {
  fill: #fff;
}
#header .navigation__list {
  color: #fff;
}
.header .drawer-btn__border, .header .drawer-btn__border::before, .header .drawer-btn__border::after {
  background: #fff;
}
.cls-4 {
  stroke: #fff;
}
@media screen and (min-width: 768px) {
  .A1101 .sp_only {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .A1101 {
    margin-top: calc(100*100vw/750);
  }
  .A1101 .pc_only {
    display: none !important;
  }
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Common
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .model_section {
  width: 140rem;
  margin-inline: auto;
}
.A1101 .model_flexWrap {
  position: relative;
  display: flex;
}
.A1101 .model_ttl {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.A1101 .model_ttl-en {
  font-size: 3.5rem;
  line-height: 1.2;
  letter-spacing: 0.045em;
  font-weight: 600;
}
.A1101 .model_ttl-border {
  height: 0.1rem;
  background-color: var(--color_black);
}
.A1101 .model_ttl-ja {
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.A1101 .model_credit {
  margin-top: 3.3rem;
  font-size: 1.2rem;
  line-height: 2.1666666667;
  letter-spacing: 0.05em;
}
.A1101 .model_credit > a {
  display: inline-block;
  text-decoration: underline;
  text-decoration-skip-ink: none;
}
.A1101 .model_desc,
.A1101 .model_lead {
  font-size: 1.3rem;
  line-height: 2.0769230769;
  letter-spacing: 0.05em;
  font-weight: 400;
  text-align: justify;
}
.A1101 .model_desc {
  margin-top: 1.6rem;
}
.A1101 .model_lead {
  position: relative;
  color: var(--color_white);
}
.A1101 .model_border {
  position: absolute;
  content: "";
  display: block;
  z-index: -1;
  pointer-events: none;
  background-color: var(--color_gold);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 200vw;
  height: 16rem;
}
@media screen and (max-width: 767px) {
  .A1101 .model_section {
    width: calc(750*100vw/750);
  }
  .A1101 .model_flexWrap {
    flex-direction: column;
  }
  .A1101 .model_ttl-en {
    font-size: calc(50*100vw/750);
  }
  .A1101 .model_ttl-ja {
    font-size: calc(25*100vw/750);
    line-height: 1.68;
  }
  .A1101 .model_credit {
    margin-top: calc(53*100vw/750);
    font-size: calc(24*100vw/750);
    line-height: 2;
  }
  .A1101 .model_credit > a {
    margin-inline: calc(7*100vw/750);
  }
  .A1101 .model_desc,
  .A1101 .model_lead {
    font-size: calc(23*100vw/750);
    line-height: 1.8260869565;
    font-weight: 600;
  }
  .A1101 .model_desc {
    margin-top: calc(18*100vw/750);
  }
  .A1101 .model_border {
    height: calc(350*100vw/750);
  }
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Hero
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .hero_wrapper {
  position: relative;
  display: flex;
}
.A1101 .hero_wrapper-img {
  flex-grow: 1;
}
.A1101 .hero_wrapper-ttl {
  position: absolute;
  content: "";
  bottom: calc(135*100vw/1400);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  pointer-events: none;
}
.A1101 .hero_wrapper-ttl > span {
  display: block;
  color: var(--color_white);
}
.A1101 .hero_wrapper-ttl > span:nth-child(1) {
  font-size: calc(42*100vw/1400);
  line-height: 1.2;
  letter-spacing: 0.045em;
}
.A1101 .hero_wrapper-ttl > span:nth-child(2) {
  width: 100%;
  height: calc(1*100vw/1400);
  background-color: var(--color_white);
  margin-block: calc(11*100vw/1400);
}
.A1101 .hero_wrapper-ttl > span:nth-child(3) {
  font-size: calc(35*100vw/1400);
  line-height: 1.2;
  letter-spacing: 0.065em;
}
.A1101 .hero_lead {
  margin-top: 8.6rem;
  font-size: 1.5rem;
  line-height: 1.8666666667;
  letter-spacing: 0.05em;
  font-weight: 500;
  text-align: center;
}
.A1101 .hero_lead > span {
  display: block;
  margin-top: 1.1rem;
}
@media screen and (min-width: 768px) {}
@media screen and (max-width: 767px) {
  .A1101 .hero_wrapper-ttl {
    bottom: calc(180*100vw/1400);
  }
  .A1101 .hero_wrapper-ttl > span:nth-child(1) {
    font-size: calc(46.2*100vw/750);
    white-space: nowrap;
  }
  .A1101 .hero_wrapper-ttl > span:nth-child(2) {
    height: calc(1*100vw/750);
    margin-block: calc(8*100vw/750) calc(15*100vw/750);
  }
  .A1101 .hero_wrapper-ttl > span:nth-child(3) {
    font-size: calc(35*100vw/750);
  }
  .A1101 .hero_lead {
    margin-top: calc(90*100vw/750);
    font-size: calc(23*100vw/750);
    line-height: 1.8260869565;
    font-weight: 600;
  }
  .A1101 .hero_lead > span {
    margin-top: calc(28*100vw/750);
  }

}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Content01
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .model_section01 {
  margin-top: 9rem;
}
.A1101 .model_section01 .model_block01 {
  width: 48rem;
  margin-left: 17.61rem;
}
.A1101 .model_section01 .model_block02 {
  width: 50.195rem;
  margin-top: 20.4rem;
  margin-left: 7.8rem;
}
.A1101 .model_section01 .model_block03 {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  text-align: center;
  width: 56.5rem;
  margin-top: -6rem;
}
.A1101 .model_section01 .model_block04 {
  flex-shrink: 0;
  margin-top: 9.5rem;
}
.A1101 .model_section01 .model_block05 {
  position: relative;
}
.A1101 .model_section01 .model_flexWrap03 {
  position: relative;
  z-index: 4;
  justify-content: flex-end;
  margin-right: -2.2rem;
}
.A1101 .model_section01 .model_flexWrap03 > figure:nth-child(1) {
  width: 29.07rem;
}
.A1101 .model_section01 .model_flexWrap03 > figure:nth-child(2) {
  width: 25.65rem;
  margin-top: 10.13rem;
}
.A1101 .model_section01 .model_lead {
  width: 55.29rem;
  margin-top: 10.2rem;
  margin-right: 10.6rem;
}
.A1101 .model_section01 .model_block06 > figure {
  width: 51rem;
  margin-top: -10.4rem;
  margin-left: 37.16rem;
}
.A1101 .model_section01 .model_ttl-border {
  width: 22.418rem;
}
@media screen and (min-width: 768px) {
  .A1101 .model_section01 .model_block01 .model_credit > a,
  .A1101 .model_section01 .model_block03 .model_credit > a {
    margin-right: 0.9rem;
  }
  .A1101 .model_section01 .model_block03 .model_credit {
    margin-left: 5.6rem;
  }
  .A1101 .model_section01 .model_flexWrap02 {
    flex-direction: row-reverse;
  }
  .A1101 .model_section01 .model_block06 {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: flex-end;
  }
  .A1101 .model_section01 .model_block06 .model_credit {
    margin-left: 4rem;
    margin-bottom: -0.7rem;
  }
  .A1101 .model_section01 .model_block06 .model_credit > a {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .A1101 .model_section01 {
    margin-top: calc(90*100vw/750);
  }
  .A1101 .model_section01 .model_block01 {
    width: calc(650*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section01 .model_block02 {
    width: calc(601*100vw/750);
    margin-top: calc(79*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section01 .model_block03 {
    width: calc(750*100vw/750);
    margin-top: calc(88*100vw/750);
  }
  .A1101 .model_section01 .model_block03 > figure {
    width: calc(550*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section01 .model_flexWrap03 {
    justify-content: center;
    flex-direction: row;
    margin-inline: auto;
  }
  .A1101 .model_section01 .model_block04 {
    margin-top: calc(58*100vw/750);
  }
  .A1101 .model_section01 .model_flexWrap03 > figure:nth-child(1) {
    width: calc(318.56*100vw/750);
  }
  .A1101 .model_section01 .model_flexWrap03 > figure:nth-child(2) {
    width: calc(281.08*100vw/750);
    margin-top: calc(111*100vw/750);
  }
  .A1101 .model_section01 .model_lead {
    width: calc(602*100vw/750);
    margin-top: calc(150*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section01 .model_block06 {
    text-align: center;
  }
  .A1101 .model_section01 .model_block06 > figure {
    width: calc(600*100vw/750);
    margin-top: calc(147*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section01 .model_ttl-border {
    width: calc(211.02*100vw/750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Content02
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .model_section02 {
  margin-top: 22rem;
}
.A1101 .model_section02 .model_block01 {
  width: 58rem;
  margin-right: 16.65rem;
  text-align: right;
}
.A1101 .model_section02 .model_block02 {
  width: 40rem;
  margin-top: -0.2rem;
  margin-right: 7.7rem;
}
.A1101 .model_section02 .model_block02 > figure {
  width: 26rem;
  margin-top: 2.5rem;
  margin-left: auto;
}
.A1101 .model_section02 .model_block03 {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: flex-end;
  flex-shrink: 0;
  margin-top: 1.7rem;
  margin-left: 18.61rem;
}
.A1101 .model_section02 .model_block03 > figure {
  width: 46rem;
}
.A1101 .model_section02 .model_block03 .model_credit {
  margin-left: 4.8rem;
  margin-bottom: -0.7rem;
}
.A1101 .model_section02 .model_block04 {
  position: relative;
  flex-shrink: 0;
  width: 48.81rem;
  margin-left: -5rem;
}
.A1101 .model_section02 .model_block04 .model_lead {
  margin-top: 24.4rem;
}
.A1101 .model_section02 .model_ttl-border {
  width: 10.348rem;
}
@media screen and (min-width: 768px) {
  .A1101 .model_section02 .model_flexWrap01 {
    flex-direction: row-reverse;
  }
  .A1101 .model_section02 .model_block01 .model_credit > a {
    margin-left: 0.9rem;
  }
  .A1101 .model_section02 .model_block03 .model_credit > a {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .A1101 .model_section02 {
    margin-top: calc(242*100vw/750);
  }
  .A1101 .model_section02 .model_block01 {
    width: calc(650*100vw/750);
    margin-inline: auto;
    text-align: center;
  }
  .A1101 .model_section02 .model_block02 {
    display: flex;
    flex-direction: column;
    width: calc(605*100vw/750);
    margin-top: calc(60*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section02 .model_block02 > figure {
    width: calc(450*100vw/750);
    margin-top: calc(0*100vw/750);
    margin-bottom: calc(95*100vw/750);
    margin-inline: auto;
    order: -1;
  }
  .A1101 .model_section02 .model_block03 {
    align-items: center;
    flex-direction: column;
    margin-top: calc(92*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section02 .model_block03 > figure {
    width: calc(600*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section02 .model_block03 .model_credit {
    margin-left: calc(20*100vw/750);
    margin-bottom: calc(0*100vw/750);
  }
  .A1101 .model_section02 .model_block04 {
    width: calc(600*100vw/750);
    margin-top: calc(138*100vw/750);
    margin-left: calc(0*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section02 .model_block04 .model_lead {
    margin-top: calc(0*100vw/750);
  }
  .A1101 .model_section02 .model_ttl-border {
    width: calc(171.02*100vw/750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Content03
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .model_section03 {
  margin-top: 22rem;
}
.A1101 .model_section03 .model_block01 {
  width: 47rem;
  margin-left: 17.61rem;
}
.A1101 .model_section03 .model_block02 {
  width: 50rem;
  margin-top: 20.8rem;
  margin-left: 8.8rem;
}
.A1101 .model_section03 .model_block03 {
  position: relative;
  width: 40.4rem;
  margin-top: -5.8rem;
  margin-left: 82.9rem;
}
.A1101 .model_section03 .model_block03 .position_item {
  position: absolute;
  top: 13.37rem;
  left: -31.12rem;
  width: 26rem;
}
.A1101 .model_section03 .model_block04 {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  display: flex;
  align-items: flex-end;
  margin-top: -10.2rem;
  margin-left: 25.58rem;
}
.A1101 .model_section03 .model_block04 > figure {
  width: 40.029rem;
}
.A1101 .model_section03 .model_block04 .model_credit {
  margin-left: 3.8rem;
  margin-bottom: -0.5rem;
}
.A1101 .model_section03 .model_block05 {
  flex-shrink: 0;
  width: 51.465rem;
  margin-top: 10.5rem;
  margin-left: -7.7rem;
  pointer-events: none;
}
.A1101 .model_section03 .model_ttl-border {
  width: 28.757rem;
}
@media screen and (min-width: 768px) {
  .A1101 .model_section03 .model_block01 .model_credit > a,
  .A1101 .model_section03 .model_block03 .model_credit > a {
    margin-right: 0.9rem;
  }
  .A1101 .model_section03 .model_block04 .model_credit > a {
    display: block;
  }
  .A1101 .model_section03 .model_desc {
    letter-spacing: 0.02em;
  }
}
@media screen and (max-width: 767px) {
  .A1101 .model_section03 .model_block05 .model_lead {
    letter-spacing: 0.03em;
  }
  .A1101 .model_section03 {
    margin-top: calc(300*100vw/750);
  }
  .A1101 .model_section03 .model_block01 {
    width: calc(650*100vw/750);
    margin-inline: auto;
    text-align: center;
  }
  .A1101 .model_section03 .model_block02 {
    width: calc(600*100vw/750);
    margin-top: calc(86*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section03 .model_block03 {
    position: relative;
    width: calc(500*100vw/750);
    margin-top: calc(90*100vw/750);
    margin-left: auto;
  }
  .A1101 .model_section03 .model_block03 .position_item {
    width: calc(320*100vw/750);
    top: calc(545.3*100vw/750);
    left: calc(-125*100vw/375);
  }
  .A1101 .model_section03 .model_block03 .model_credit {
    margin-top: calc(70*100vw/750);
    margin-left: calc(140*100vw/750);
  }
  .A1101 .model_section03 .model_block03 .model_credit > a {
    display: block;
  }
  .A1101 .model_section03 .model_flexWrap02 {
    flex-direction: column-reverse;
  }
  .A1101 .model_section03 .model_block04 {
    display: block;
    margin-top: calc(172*100vw/750);
    margin-left: calc(0*100vw/750);
  }
  .A1101 .model_section03 .model_block04 > figure {
    width: calc(600*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section03 .model_block04 .model_credit {
    text-align: center;
    margin-left: calc(0*100vw/750);
    margin-bottom: calc(0*100vw/750);
  }
  .A1101 .model_section03 .model_block05 .model_lead .model_border {
    height: calc(400*100vw/750);
  }
  .A1101 .model_section03 .model_block05 {
    width: calc(600*100vw/750);
    margin-top: calc(164*100vw/750);
    margin-inline: auto;
  }
  .A1101 .model_section03 .model_ttl-border {
    width: calc(286.96*100vw/750);
  }
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                End
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .end_section {
  position: relative;
  width: 100%;
  padding-block: 16.5rem 17rem;
  margin-inline: auto;
  z-index: 1;
  background-color: var(--color_white);
}
.A1101 .end_btn {
  margin-inline: auto;
  width: fit-content;
  padding-bottom: 0.5rem;
  font-size: 1.8rem;
  line-height: 1;
  letter-spacing: 0.037em;
  border-bottom: solid 1px #1A1311;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 767px) {
  .A1101 .end_section {
    position: relative;
    width: 100%;
    padding-block: calc(185*100vw/750) calc(200*100vw/750);
    margin-inline: auto;
    z-index: 1;
    background-color: var(--color_white);
  }
  .A1101 .end_btn {
    padding-bottom: calc(4*100vw/750);
    font-size: calc(30*100vw/750);
  }
  .top_button {
    position: relative;
    margin-top: calc(-110*100vw/750);
    z-index: 2;
  }
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                                                                Animation
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.A1101 .js-apper {
  opacity: 0;
  transition: opacity 1.2s ease;
}
.A1101 .js-apper.active {
  opacity: 1;
}

.A1101 .js-border.model_ttl-border {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s 0.5s ease;
}

.A1101 .js-fade .model_border {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 2s 0.2s ease-out;
}
.A1101 .js-fade.active .model_border {
  /* transition: clip-path 2s 0.2s cubic-bezier(0.77, 0, 0.175, 1); */
  clip-path: inset(0 0 0 0);
}
.A1101 .js-border.active.model_ttl-border {
  clip-path: inset(0 0 0 0);
}