@charset "UTF-8";
@media only screen and (max-width: 1400px) {
  html {
    font-size: 0.7142857143vw;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
setting - custom property
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents {
  --color-white: #fff;
  --color-black: #000;
  --color-green: #c5cdc1;
  --font-yu: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic";
  --font-hiragino: "Hiragino Sans";
  --font-nimbus: "nimbus-sans";
  --font-trajan: "trajan-pro-3";
  --font-ja: var(--font-yu), sans-serif;
  --font-en: var(--font-nimbus), sans-serif;
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  font-feature-settings: "palt";
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .l-lpcontents {
    --width-primary: 140rem;
    --fz-text__fv__maintitle: 3rem;
    --fz-text__fv__subtitle: 2rem;
    --fz-text__fv__lead: 1.4rem;
    --fz-text__style__title: 2.5rem;
    --fz-text__style__credit: 1.2rem;
    --fz-text__style__lead: 1.3rem;
    --fz-text_btn: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents {
    --width-primary: calc(750*100vw/750);
    --fz-text__fv__maintitle: calc(43*100vw/750);;
    --fz-text__fv__subtitle: calc(30*100vw/750);;
    --fz-text__fv__lead: calc(23*100vw/750);;
    --fz-text__style__title: calc(38*100vw/750);;
    --fz-text__style__credit: calc(23*100vw/750);;
    --fz-text__style__lead: calc(24*100vw/750);;
    --fz-text_btn: calc(30*100vw/750);
    margin-top: calc(-120*100vw/750);;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - others
//////////////////////////////////////////////////////////////////////////////////////////////
*/
@media screen and (min-width: 768px) {
  .l-lpcontents .sp_only {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents .pc_only {
    display: none !important;
  }
  .top_button {
    margin-top: calc(-110*100vw/750);
  }
}
.l-lpcontents img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - grid
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents [class*="c-grid_column"] {
  display: grid;
  grid-template-columns: repeat(var(--columns , 1), 1fr);
  gap: var(--row, 0) var(--column, 0);
}
@media screen and (min-width: 768px) {
  .l-lpcontents [class*="c-pc_grid_column"] {
    display: grid;
    grid-template-columns: repeat(var(--columns , 1), 1fr);
    gap: var(--row, 0) var(--column, 0);
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents [class*="c-sp_grid_column"] {
    display: grid;
    grid-template-columns: repeat(var(--columns , 1), 1fr);
    gap: var(--row, 0) var(--column, 0);
  }
}
.l-lpcontents :where([class*="p-style__wrap0"]) {
  position: relative;
  width: fit-content;
  height: fit-content;
  z-index: 2;
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - position
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .c-position {
  position: absolute;
}
@media screen and (min-width: 768px) {
  .l-lpcontents .c-pc_position {
    position: absolute;
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents .c-sp_position {
    position: absolute;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - flex
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .c-flex_row {
  display: flex;
  flex-direction: row;
  gap: var(--row, 0) var(--column, 0);
}
.l-lpcontents .c-flex_row_reverse {
  display: flex;
  flex-direction: row-reverse;
  gap: var(--row, 0) var(--column, 0);
}
.l-lpcontents .c-flex_column {
  display: flex;
  flex-direction: column;
  gap: var(--row, 0) var(--column, 0);
}
.l-lpcontents .c-flex_column_reverse {
  display: flex;
  flex-direction: column-reverse;
  gap: var(--row, 0) var(--column, 0);
}
@media screen and (min-width: 768px) {
  .l-lpcontents .c-pc_flex_row {
    display: flex;
    flex-direction: row;
    gap: var(--row, 0) var(--column, 0);
  }
  .l-lpcontents .c-pc_flex_row_reverse {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--row, 0) var(--column, 0);
  }
  .l-lpcontents .c-pc_flex_column {
    display: flex;
    flex-direction: column;
    gap: var(--row, 0) var(--column, 0);
  }
  .l-lpcontents .c-pc_flex_column_reverse {
    display: flex;
    flex-direction: column;
    gap: var(--row, 0) var(--column, 0);
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents .c-sp_flex_row {
    display: flex;
    flex-direction: row;
    gap: var(--row, 0) var(--column, 0);
  }
  .l-lpcontents .c-sp_flex_row_reverse {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--row, 0) var(--column, 0);
  }
  .l-lpcontents .c-sp_flex_column {
    display: flex;
    flex-direction: column;
    gap: var(--row, 0) var(--column, 0);
  }
  .l-lpcontents .c-sp_flex_column_reverse {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--row, 0) var(--column, 0);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - text
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .c-text__fv__maintitle {
  font-size: var(--fz-text__fv__maintitle);
  line-height: 1.444;
  letter-spacing: 0.12em;
  font-weight: var(--fw-bold);
  font-family: var(--font-hiragino);
  color: var(--color-black);
}
.l-lpcontents .c-text__fv__subtitle {
  font-size: var(--fz-text__fv__subtitle);
  line-height: 2.297;
  letter-spacing: 0.06em;
  font-weight: var(--fw-regular);
  font-family: var(--font-trajan);
  color: var(--color-black);
}
.l-lpcontents .c-text__fv__lead {
  font-size: var(--fz-text__fv__lead);
  line-height: 2.1428571429;
  letter-spacing: 0.1em;
  font-weight: var(--fw-medium);
  font-family: var(--font-hiragino);
  color: var(--color-black);
}
.l-lpcontents .c-text__style__title {
  position: relative;
  font-size: var(--fz-text__style__title);
  line-height: 2.036;
  letter-spacing: 0.06em;
  font-weight: var(--fw-regular);
  font-family: var(--font-trajan);
  color: var(--color-black);
  white-space: nowrap;
}

.l-lpcontents .c-text__style__credit {
  margin-top: 3.3rem;
  font-size: var(--fz-text__style__credit);
  line-height: 2.1666666667;
  letter-spacing: 0.005em;
  font-weight: var(--fw-regular);
  font-family: var(--font-en);
  color: var(--color-black);
  text-align: center;
}
.l-lpcontents .c-text__style__credit__item {
  display: inline-block;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  margin-inline: 0.4rem;
}
.l-lpcontents .c-text__style__lead {
  font-size: var(--fz-text__style__lead);
  line-height: 2.0769230769;
  letter-spacing: 0.05em;
  font-weight: var(--fw-regular);
  font-family: var(--font-hiragino);
  color: var(--color-black);
  text-align: justify;
}
.l-lpcontents .c-text_btn {
  width: fit-content;
  margin: 16.5rem auto 16rem;
  font-size: var(--fz-text_btn);
  line-height: 1.5;
  letter-spacing: 0.036em;
  font-weight: var(--fw-regular);
  font-family: var(--font-en)!important;
  color: var(--color-black);
  text-align: center;
  border-bottom: 0.1rem solid var(--color-black);
}
@media screen and (max-width: 767px) {
  .l-lpcontents .c-text__fv__maintitle {
    line-height: 1.4506976744;
    letter-spacing: 0.15em;
  }
  .l-lpcontents .c-text__fv__subtitle {
    line-height: 1.5313333333;
  }
  .l-lpcontents .c-text__fv__lead {
    line-height: 2.0434782609;
    letter-spacing: 0.05em;
  }
  .l-lpcontents .c-text__style__title {
    line-height: 1.9286842105;
  }
  
  .l-lpcontents .c-text__style__credit {
    margin-top: calc(41*100vw/750);
    line-height: 1.0833333333;
  }
  .l-lpcontents .c-text__style__credit__item {
    margin-inline: calc(8*100vw/750);
  }
  .l-lpcontents .c-text__style__lead {
    line-height: 1.8;
    letter-spacing: 0.06em;
    font-weight: var(--fw-medium);
  }
  .l-lpcontents .c-text_btn {
    margin-block: calc(199* 100vw / 750) calc(200* 100vw / 750);
    line-height: 1.25;
    letter-spacing: 0.037em;
    border-block: 1px solid var(--color-black);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - image
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .c-firstview__image01 {width: 56.5rem;}
.l-lpcontents .c-firstview__image02 {width: 50rem;}
.l-lpcontents .c-style__image0101 {width: 54rem;}
.l-lpcontents .c-style__image0102 {width: 43rem;}
.l-lpcontents .c-style__image0103 {width: 40rem;}
.l-lpcontents .c-style__image0201 {width: 56rem;}
.l-lpcontents .c-style__image0202 {width: 40rem;}
.l-lpcontents .c-style__image0203 {width: 32rem;}
.l-lpcontents .c-style__image0204 {width: 32rem;}
.l-lpcontents .c-style__image0301 {width: 110rem;}
.l-lpcontents .c-style__image0302 {width: 44rem;}
.l-lpcontents .c-style__image0303 {width: 41rem;}
@media screen and (max-width: 767px) {
  .l-lpcontents .c-firstview__image01 {width: calc(750*100vw/750);}
  .l-lpcontents .c-firstview__image02 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style__image0101 {width: calc(650*100vw/750);}
  .l-lpcontents .c-style__image0102 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style__image0103 {width: calc(580*100vw/750);}
  .l-lpcontents .c-style__image0201 {width: calc(650*100vw/750);}
  .l-lpcontents .c-style__image0202 {width: calc(550*100vw/750);}
  .l-lpcontents .c-style__image0203 {width: calc(363*100vw/750);}
  .l-lpcontents .c-style__image0204 {width: calc(363*100vw/750);}
  .l-lpcontents .c-style__image0301 {width: calc(750*100vw/750);}
  .l-lpcontents .c-style__image0302 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style__image0303 {width: calc(550*100vw/750);}
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - common
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style__inner {
  width: var(--width-primary);
  margin-inline: auto;
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - firstview
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-firstview {
  width: var(--width-primary);
  margin-inline: auto;
  text-align: center;
}
.l-lpcontents .p-firstview__inner {
  --row: 11.5rem;
}
.l-lpcontents .p-firstview__wrapper {
  --column: 2.6rem;
  margin-left: 15rem;
}
.l-lpcontents .p-firstview__wrap02 {
  --row: 2.4rem;
}
.l-lpcontents .p-firstview__title {
  --row: 0.3rem;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-firstview__inner {
    --row: calc(89*100vw/750);
  }
  .l-lpcontents .p-firstview__wrapper {
    --row: calc(36*100vw/750);
    --column: calc(0*100vw/750);
    margin-left: calc(0*100vw/750);
  }
  .l-lpcontents .p-firstview__wrap02 {
    --row: calc(39*100vw/750);
    margin-inline: auto;
  }
  .l-lpcontents .p-firstview__title {
    --row: calc(16*100vw/750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style01
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style01 {
  margin-top: 11.7rem;
}
.l-lpcontents .p-style01 .p-style__wrapper {
  margin-left: 18.3rem;
  grid-template-columns: 48.5rem 7rem;
  grid-template-rows: 16.1rem 28.2rem 31.2rem 22.8rem;
}
.l-lpcontents .p-style01 .p-style__wrap01 {
  grid-column: 1;
  grid-row: 2;
}
.l-lpcontents .p-style01 .p-style__wrap02 {
  grid-column: 2;
  grid-row: 1;
}
.l-lpcontents .p-style01 .p-style__wrap03 {
  grid-column: 1;
  grid-row: 3;
}
.l-lpcontents .p-style01 .p-style__wrap04 {
  grid-column: 2;
  grid-row: 4;
  width: 54rem;
}
.l-lpcontents .p-style01 .p-style__wrap05 {
  grid-column: 3;
  grid-row: 5;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style01 {
    margin-top: calc(116*100vw/750);;
  }
  .l-lpcontents .p-style01 .p-style__wrapper {
    margin-left: calc(0*100vw/750);
  }
  .l-lpcontents .p-style01 .p-style__wrap01 {
    margin-left: calc(75* 100vw / 750);
  }
  .l-lpcontents .p-style01 .p-style__wrap02 {
    margin-top: calc(78*100vw/750);;
    margin-left: auto;
  }
  .l-lpcontents .p-style01 .p-style__wrap03 {
    margin-top: calc(100*100vw/750);;
  }
  .l-lpcontents .p-style01 .p-style__wrap04 {
    width: calc(600*100vw/750);
    margin: calc(82*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style01 .p-style__wrap05 {
    margin: calc(93*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style01 .c-text__style__credit {
    text-align: right;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style02
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style02 {
  margin-top: 25.4rem;
}
.l-lpcontents .p-style02 .p-style__wrapper {
  position: relative;
  margin-left: 18.9rem;
  grid-template-columns: 17.5rem 44.4rem 19.4rem;
  grid-template-rows: 21.4rem 26.9rem 38.7rem 24.8rem;
}
.l-lpcontents .p-style02 .p-style__wrapper::before {
  position: absolute;
  content: "";
  display: block;
  width: 110rem;
  height: 30rem;
  background-color: var(--color-green);
  top: 62.5rem;
  left: -4.1rem;
  z-index: -1;
}
.l-lpcontents .p-style02 .p-style__wrap01 {
  grid-column: 4;
  grid-row: 2;
}
.l-lpcontents .p-style02 .p-style__wrap02 {
  grid-column: 1;
  grid-row: 1;
}
.l-lpcontents .p-style02 .p-style__wrap03 {
  grid-column: 3;
  grid-row: 3;
}
.l-lpcontents .p-style02 .p-style__wrap04 {
  grid-column: 1;
  grid-row: 4;
  width: 55.7rem;
}
.l-lpcontents .p-style02 .p-style__wrap05 {
  grid-column: 2;
  grid-row: 5;
  --column: 2.9rem
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style02 {
    margin-top: calc(200*100vw/750);;
  }
  .l-lpcontents .p-style02 .p-style__wrapper {
    margin-inline: auto;
  }
  .l-lpcontents .p-style02 .p-style__wrapper::before {
    width: var(--width-primary);
    height: calc(1300*100vw/750);;
    top: calc(984*100vw/750);;
    left: calc(0*100vw/750);;
  }
  .l-lpcontents .p-style02 .p-style__wrap01 {
    margin-left: calc(355*100vw/750);;
  }
  .l-lpcontents .p-style02 .p-style__wrap02 {
    width: var(--width-primary);
    margin: calc(76*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style02 .p-style__wrap03 {
    width: calc(550*100vw/750);;
    margin: calc(92*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style02 .p-style__wrap04 {
    width: calc(600*100vw/750);;
    margin: calc(93*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style02 .p-style__wrap05 {
    --column: calc(22*100vw/750);
    margin-top: calc(85* 100vw / 750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style03
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style03 {
  margin-top: 25.2rem;
}
.l-lpcontents .p-style03 .p-style__wrapper {
  margin-left: 14.8rem;
  grid-template-columns: 3.5rem 6.4rem 46.6rem;
  grid-template-rows: 55.3rem 9.6rem 7.5rem 30.1rem;
}
.l-lpcontents .p-style03 .p-style__wrap01 {
  grid-column: 2;
  grid-row: 2;
}
.l-lpcontents .p-style03 .p-style__wrap02 {
  grid-column: 1;
  grid-row: 1;
}
.l-lpcontents .p-style03 .p-style__wrap03 {
  grid-column: 4;
  grid-row: 3;
}
.l-lpcontents .p-style03 .p-style__wrap04 {
  grid-column: 3;
  grid-row: 4;
  width: 41.2rem;
}
.l-lpcontents .p-style03 .p-style__wrap05 {
  grid-column: 3;
  grid-row: 5;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style03 {
    margin-top: calc(208* 100vw / 750);
  }
  .l-lpcontents .p-style03 .p-style__wrapper {
    margin-inline: auto;
  }
  .l-lpcontents .p-style03 .p-style__wrap01 {
    margin-left: calc(75*100vw/750);;
  }
  .l-lpcontents .p-style03 .p-style__wrap02 {
    margin-top: calc(78*100vw/750);;
  }
  .l-lpcontents .p-style03 .p-style__wrap03 {
    width: var(--width-primary);
    margin: calc(150*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style03 .p-style__wrap03 > div {
    margin-inline: auto;
  }
  .l-lpcontents .p-style03 .p-style__wrap04 {
    width: calc(600*100vw/750);;
    margin: calc(85*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style03 .p-style__wrap05 {
    margin: calc(87*100vw/750) auto 0;;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
animation
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .js-fade {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s ease, transform 1s ease;
  transition-duration: 0.8s;
}
.l-lpcontents .js-fade.is-active {
  opacity: 1;
  transform: translateY(0);
}

.l-lpcontents .js-border::before {
  position: absolute;
  content: "";
  display: block;
  width: 0;
  height: 0.1rem;
  background-color: var(--color-black);
  z-index: -2;
  top: 2.5rem;
  transition: width 1.5s ease, height 1s ease;
}
.l-lpcontents .p-style01 .js-border::before {
  left: 21.5rem;
}
.l-lpcontents .p-style02 .js-border::before {
  right: 21.1rem;
}
.l-lpcontents .p-style03 .js-border::before {
  left: 8.6em;
}
.l-lpcontents .p-style01 .js-border.is-active::before,
.l-lpcontents .p-style02 .js-border.is-active::before {
  width: 75.9rem;
}
.l-lpcontents .p-style03 .js-border.is-active::before {
  width: 100vw;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .js-border::before {
    height: 1px;
    top: calc(35*100vw/750);
  }
  .l-lpcontents .p-style01 .js-border::before {
    left: calc(316*100vw/750);
  }
  .l-lpcontents .p-style02 .js-border::before {
    right: calc(330*100vw/750);
  }
  .l-lpcontents .p-style03 .js-border::before {
    left: calc(314*100vw/750);
  }
  .l-lpcontents .p-style01 .js-border.is-active::before,
  .l-lpcontents .p-style02 .js-border.is-active::before,
  .l-lpcontents .p-style03 .js-border.is-active::before {
    width: 100vw;
  }
}