@charset "UTF-8";
/*
//////////////////////////////////////////////////////////////////////////////////////////////
setting - custom property
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents {
  --color-blue: #2e83a0;
  --color-white: #fff;
  --color-black: #000;
  --color-text: #231815;
  --color-dot-default: #808080;
  --color-dot-active: var(--color-black);
  --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-hiragino), sans-serif;
  --font-en: var(--font-nimbus), sans-serif;
  --font-main: var(--font-nimbus), var(--font-hiragino), 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_lead: 1.4rem;
    --fz-text_fv_title: 6.5rem;
    --fz-text_style_device: 2rem;
    --fz-text_style_title: 3rem;
    --fz-text_style_lead: 1.3rem;
    --fz-text_style_credit: 1.2rem;
    --fz-text_style_title_primary: 7rem;
    --fz-text_style_title_secondary: 5rem;
    --fz-text_btn: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents {
    --width-primary: calc(750*100vw/750);
    --fz-text_fv_lead: calc(23*100vw/750);
    --fz-text_fv_title: calc(70*100vw/750);
    --fz-text_style_device: calc(28*100vw/750);
    --fz-text_style_title: calc(40*100vw/750);
    --fz-text_style_lead: calc(23*100vw/750);
    --fz-text_style_credit: calc(24*100vw/750);
    --fz-text_style_title_primary: calc(70*100vw/750);
    --fz-text_style_title_secondary: calc(50*100vw/750);
    --fz-text_btn: calc(30*100vw/750);
  }
}

@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;
  }
}
.l-lpcontents img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - grid
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents [class*="grid_column-1"] {--columns: 1;}
.l-lpcontents [class*="grid_column-2"] {--columns: 2;}
.l-lpcontents [class*="grid_column-3"] {--columns: 3;}
.l-lpcontents [class*="c-grid_column-"] {
  display: grid;
  grid-template-columns: repeat(var(--columns , 1), 1fr);
  gap: var(--row, 0) var(--column, 0);
}
.l-lpcontents .c-flex_column {
  display: flex;
  flex-direction: column;
}
@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);
  }
  .l-lpcontents .c-bg_white {
    background-color: var(--color-white);
  }
  .l-lpcontents .c-pc_flex_column {
    display: flex;
    flex-direction: column;
  }
  .l-lpcontents .c-pc_flex_row {
    display: flex;
    flex-direction: row;
  }
  .l-lpcontents .c-pc_flex_row_reverse {
    display: flex;
    flex-direction: row-reverse;
  }
}
@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);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - text
//////////////////////////////////////////////////////////////////////////////////////////////
*/

.l-lpcontents .c-text_fv_lead {
  font-size: var(--fz-text_fv_lead);
  line-height: 2.0714285714;
  letter-spacing: 0.1em;
  font-weight: var(--fw-medium);
  font-family: var(--font-ja);
  color: var(--color-white);
}
.l-lpcontents .c-text_fv_title {
  position: absolute;
  top: 67rem;
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--fz-text_fv_title);
  line-height: 0.5923076923;
  letter-spacing: 0.03em;
  font-weight: var(--fw-bold);
  font-family: var(--font-en);
  color: var(--color-white);
}
.l-lpcontents .c-text_style_device {
  position: relative;
  font-size: var(--fz-text_style_device);
  line-height: 1.925;
  letter-spacing: 0.03em;
  font-weight: var(--fw-bold);
  font-family: var(--font-en);
  color: var(--color-white);
}
.l-lpcontents .c-text_style_device::before {
  position: absolute;
  content: "";
  width: 2rem;
  height: 0.2rem;
  background-color: var(--color-white);
}
.l-lpcontents .p-style02 .c-text_style_device::before,
.l-lpcontents .p-style05 .c-text_style_device::before {
top: 5.5rem;
right: 0;
}
.l-lpcontents .p-style01 .c-text_style_device::before,
.l-lpcontents .p-style04 .c-text_style_device::before {
  top: 5.1rem;
  left: 0;
}
.l-lpcontents .c-text_style_title {
  margin-top: 4.1rem;
  font-size: var(--fz-text_style_title);
  line-height: 0.76;
  letter-spacing: 0.15em;
  font-weight: var(--fw-semibold);
  font-family: var(--font-ja);
  color: var(--color-white);
}
.l-lpcontents .c-text_style_lead {
  margin-top: 3.6rem;
  font-size: var(--fz-text_style_lead);
  line-height: 2.0769230769;
  letter-spacing: 0.09em;
  font-weight: var(--fw-regular);
  font-family: var(--font-ja);
  color: var(--color-black);
  text-align: justify;
}
.l-lpcontents .c-text_style_credit {
  font-size: var(--fz-text_style_credit);
  line-height: 2.1666666667;
  letter-spacing: 0.025em;
  font-weight: var(--fw-regular);
  font-family: var(--font-en);
  color: var(--color-black);
  margin-top: 2.7rem;
}
.l-lpcontents .c-text_style_credit_item {
  display: inline-block;
  text-decoration: underline;
  text-decoration-skip-ink: none;
}
.l-lpcontents .c-text_style_title_primary {
  font-size: var(--fz-text_style_title_primary);
  line-height: 0.8;
  letter-spacing: 0.06em;
  font-weight: var(--fw-bold);
  font-family: var(--font-en);
  color: var(--color-black);
}
.l-lpcontents .c-text_style_title_secondary {
  font-size: var(--fz-text_style_title_secondary);
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: var(--fw-bold);
  font-family: var(--font-en);
  color: var(--color-white);
}
.l-lpcontents .c-text_btn {
  width: fit-content;
  margin: 19.3rem auto 17rem;
  font-size: var(--fz-text_btn);
  line-height: 1.4;
  letter-spacing: 0.036em;
  font-weight: var(--fw-regular);
  font-family: var(--font-en);
  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_lead {
    line-height: 2;
    letter-spacing: 0.07em;
  }
  .l-lpcontents .c-text_fv_title {
    top: calc(738* 100vw / 750);
    line-height: 0.55;
  }
  .l-lpcontents .c-text_style_device {
    margin-left: calc(100*100vw/750);;
    line-height: 1.925;
    letter-spacing: 0.07em;
  }
  .l-lpcontents .c-text_style_device::before {
    width: calc(32*100vw/750);
    height: calc(1.4*100vw/750);
  }
  .l-lpcontents .p-style02 .c-text_style_device::before,
  .l-lpcontents .p-style05 .c-text_style_device::before {
    top: calc(69*100vw/750);
    right: initial;
    left: 0;
  }
  .l-lpcontents .p-style01 .c-text_style_device::before,
  .l-lpcontents .p-style04 .c-text_style_device::before {
    top: calc(69*100vw/750);
  }
  .l-lpcontents .c-text_style_title {
    margin-top: calc(54* 100vw / 750);
    margin-left: calc(100* 100vw / 750);
    line-height: 0.798;
    letter-spacing: 0.15em;
  }
  .l-lpcontents .c-text_style_lead {
    margin-top: calc(37*100vw/750);
    line-height: 1.8695652174;
    letter-spacing: 0.075em;
    font-weight: var(--fw-medium);
  }
  .l-lpcontents .c-text_style_credit {
    margin-top: calc(25*100vw/750);
    line-height: 2.0833333333;
    letter-spacing: 0.025em;
    text-align: center;
  }
  .l-lpcontents .c-text_style_title_primary {
    line-height: 0.8;
  }
  .l-lpcontents .c-text_style_title_secondary {
    line-height: 1.1;
  }
  .l-lpcontents .c-text_btn {
    margin-block: calc(180* 100vw / 750) calc(90* 100vw / 750);
    line-height: 1.2;
    letter-spacing: 0.037em;
    border-block: 1px solid var(--color-black);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
component - image
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .c-firstview_image01 {width: 70rem;}
.l-lpcontents .c-firstview_image02 {width: 56.6rem;}
.l-lpcontents .c-style_image0101 {width: 50rem;}
.l-lpcontents .c-style_image0201 {width: 50rem;}
.l-lpcontents .c-style_image0301 {width: 50rem;}
.l-lpcontents .c-style_image0302 {width: 42.5rem;}
.l-lpcontents .c-style_image0303 {width: 42.5rem;}
.l-lpcontents .c-style_image0401 {width: 50rem;}
.l-lpcontents .c-style_image0501 {width: 50rem;}
@media screen and (max-width: 767px) {
  .l-lpcontents .c-firstview_image01 {width: calc(700*100vw/750);}
  .l-lpcontents .c-firstview_image02 {width: calc(570*100vw/750);margin-left: auto;}
  .l-lpcontents .c-style_image0101 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style_image0201 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style_image0301 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style_image0302 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style_image0303 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style_image0401 {width: calc(600*100vw/750);}
  .l-lpcontents .c-style_image0501 {width: calc(600*100vw/750);}
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - common
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style_wrapper {
  position: relative;
  width: var(--width-primary);
  margin-inline: auto;
  column-gap: 9rem;
}
.l-lpcontents .p-style_wrapper::before {
  position: absolute;
  content: "";
  width: 50rem;
  height: 50rem;
  background-color: var(--color-blue);
  z-index: -1;
}
.l-lpcontents .p-style_text {
  width: 44rem;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style_wrapper {
    column-gap: calc(0*100vw/750);
  }
  .l-lpcontents .p-style_wrapper::before {
    width: calc(650*100vw/750);
    height: calc(650*100vw/750);
  }
  .l-lpcontents .p-style_text {
    width: calc(650*100vw/750);
    margin-inline: auto;
  }
  .l-lpcontents .p-style_image_item {
    width: calc(505*100vw/750);;
  }

}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - firstview
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-firstview {
  background-color: var(--color-blue);
  text-align: center;
}
.l-lpcontents .p-firstview_inner {
  position: relative;
  width: var(--width-primary);
  margin-inline: auto;
  row-gap: 5rem;
  padding-bottom: 5.5rem;
}
.l-lpcontents .p-firstview_image {
  align-items: center;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-firstview_inner {
    row-gap: calc(59*100vw/750);
    padding-bottom: calc(62*100vw/750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style01
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style01 {
  margin-top: 21.6rem;
}
.l-lpcontents .p-style01 .p-style_inner {
  row-gap: 17.8rem;
}
.l-lpcontents .p-style01 .p-style_wrapper::before {
  top: 5.7rem;
  left: 45rem;
}
.l-lpcontents .p-style01 .p-style_image {
  margin-left: 18.6rem;
}
.l-lpcontents .p-style01 .p-style_text {
  margin-top: 11.4rem;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style01 {
    margin-top: calc(200*100vw/750);
  }
  .l-lpcontents .p-style01 .p-style_inner {
    row-gap: calc(90*100vw/750);
  }
  .l-lpcontents .p-style01 .p-style_wrapper::before {
    top: calc(377* 100vw / 750);
    left: calc(100* 100vw / 750);
  }
  .l-lpcontents .p-style01 .p-style_image {
    margin-left: calc(0*100vw/750);
  }
  .l-lpcontents .p-style01 .p-style_text {
    margin-top: calc(40* 100vw / 750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style02
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style02 {
  margin-top: 22.6rem;
}
.l-lpcontents .p-style02 .p-style_inner {
  row-gap: 18rem;
}
.l-lpcontents .p-style02 .p-style_wrapper::before {
  top: 5.9rem;
  left: 45rem;
  transform-origin: right;
}
.l-lpcontents .p-style02 .p-style_image {
  margin-right: 16rem;
}
.l-lpcontents .p-style02 .p-style_text {
  margin-top: 9.6rem;
}
.l-lpcontents .p-style02 .c-text_style_title {
  margin-top: 5rem;
}
.l-lpcontents .p-style02 .c-text_style_device,
.l-lpcontents .p-style02 .c-text_style_title {
  text-align: right;
}
.l-lpcontents .p-style02 .c-text_style_lead {
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style02 {
    margin-top: calc(270*100vw/750);
  }
  .l-lpcontents .p-style02 .p-style_inner {
    row-gap: calc(90*100vw/750);
  }
  .l-lpcontents .p-style02 .p-style_wrapper::before {
    top: calc(377* 100vw / 750);
    left: calc(0* 100vw / 750);
  }
  .l-lpcontents .p-style02 .p-style_image {
    margin-right: calc(0*100vw/750);
    margin-left: auto;
  }
  .l-lpcontents .p-style02 .p-style_text {
    margin-top: calc(40*100vw/750);
  }
  .l-lpcontents .p-style02 .c-text_style_title {
    margin-top: calc(54*100vw/750);
  }
  .l-lpcontents .p-style02 .c-text_style_device,
  .l-lpcontents .p-style02 .c-text_style_title {
    text-align: left;
  }
  .l-lpcontents .p-style02 .c-text_style_lead {
    letter-spacing: 0.075em;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style03
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style03 {
  margin-top: 22rem;
}
.l-lpcontents .p-style03 .p-style_wrapper {
  width: var(--width-primary);
  margin-inline: auto;
  grid-template-columns: 54.5rem 0.7rem 35.4rem;
  grid-template-rows: 16.6rem 7rem 54rem;
  column-gap: 0;
}
.l-lpcontents .p-style03 .p-style_wrapper::before {
  width: 100vw;
  height: 40rem;
  top: 27rem;
  left: 50%;
  transform: translateX(-50%);
}
.l-lpcontents .p-style03 :where([class*="p-style_wrap0"]) {
  position: relative;
  width: fit-content;
  height: fit-content;
  z-index: 2;
}
.l-lpcontents .p-style03 .p-style_wrap01 {
  grid-column: 1;
  grid-row: 3;
}
.l-lpcontents .p-style03 .p-style_wrap02 {
  grid-column: 2;
  grid-row: 1;
}
.l-lpcontents .p-style03 .p-style_wrap03 {
  grid-column: 4;
  grid-row: 2;
}
.l-lpcontents .p-style03 .p-style_wrap04 {
  grid-column: 3;
  grid-row: 4;
  width: 50.2rem;
}
.l-lpcontents .p-style03 .p-style_title {
  position: relative;
  left: 2.1rem;
  width: fit-content;
  margin-left: auto;
  margin-bottom: 6.3rem;
}
.l-lpcontents .p-style03 .c-text_style_lead {
  font-size: 1.4rem;
  line-height: 1.8571428571;
  letter-spacing: 0.075em;
}
.l-lpcontents .p-style03 .c-text_style_credit {
  text-align: center;
  margin-top: 3.2rem;
}
.l-lpcontents .p-style03 .c-text_style_credit_item {
  margin-inline: 0.3rem;
}
.l-lpcontents .p-style03 .p-style_wrap02 .c-text_style_credit {
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style03 {
    margin-top: calc(263*100vw/750);
  }
  .l-lpcontents .p-style03 .p-style_wrapper {
    margin-top: calc(0*100vw/750);;
  }
  .l-lpcontents .p-style03 .p-style_wrapper::before {
    height: calc(2700*100vw/750);
    top: calc(37*100vw/750);
  }
  .l-lpcontents .p-style03 .p-style_wrap01 {
    width: var(--width-primary);
    margin: calc(0*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style03 .p-style_wrap02 {
    width: var(--width-primary);
    margin: calc(90* 100vw / 750) auto 0;
  }
  .l-lpcontents .p-style03 .p-style_wrap02 > div {
    margin-left: auto;
  }
  .l-lpcontents .p-style03 .p-style_wrap02 .c-text_style_credit {
    position: relative;
    left: calc(10*100vw/750);;
  }
  .l-lpcontents .p-style03 .p-style_wrap03 {
    width: calc(650*100vw/750);;
    margin: calc(85*100vw/750) auto 0;;
  }
  .l-lpcontents .p-style03 .p-style_wrap03 > div {
    margin: calc(93*100vw/750) auto 0;
  }
  .l-lpcontents .p-style03 .p-style_wrap03 .c-text_style_credit {
    margin-top: calc(83* 100vw / 750);
    color: var(--color-black);
  }
  .l-lpcontents .p-style03 .p-style_title {
    left: calc(0*100vw/750);
    margin-inline: auto;
    margin-bottom: calc(47*100vw/750);
    text-align: center;
  }
  .l-lpcontents .p-style03 .c-text_style_lead {
    font-size: calc(23*100vw/750);
    line-height: 1.8695652174;
    color: var(--color-white);
  }
  .l-lpcontents .p-style03 .c-text_style_credit {
    margin-top: calc(24*100vw/750);
    color: var(--color-white);
  }
  .l-lpcontents .p-style03 .c-text_style_credit_item {
    margin-inline: calc(5*100vw/750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style04
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style04 {
  margin-top: 26.1rem;
}
.l-lpcontents .p-style04 .p-style_inner {
  row-gap: 18.3rem;
}
.l-lpcontents .p-style04 .p-style_wrapper::before {
  top: 6.4rem;
  left: 45rem;
  transform-origin: right;
}
.l-lpcontents .p-style04 .p-style_image {
  margin-left: 18.6rem;
}
.l-lpcontents .p-style04 .p-style_text {
  margin-top: 11.4rem;
}
@media screen and (min-width: 768px) {
  .l-lpcontents .p-style04 .c-text_style_lead {
    letter-spacing: 0.07em;
  }
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style04 {
    margin-top: calc(188*100vw/750);
  }
  .l-lpcontents .p-style04 .p-style_inner {
    row-gap: calc(90*100vw/750);
  }
  .l-lpcontents .p-style04 .p-style_wrapper::before {
    top: calc(377* 100vw / 750);
    left: calc(100* 100vw / 750);
  }
  .l-lpcontents .p-style04 .p-style_image {
    margin-left: calc(0*100vw/750);
  }
  .l-lpcontents .p-style04 .p-style_text {
    margin-top: calc(40* 100vw / 750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
project - style05
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .p-style05 {
  margin-top: 22.2rem;
}
.l-lpcontents .p-style05 .p-style_inner {
  row-gap: 18rem;
}
.l-lpcontents .p-style05 .p-style_wrapper::before {
  top: 5.9rem;
  left: 45rem;
}
.l-lpcontents .p-style05 .p-style_image {
  margin-right: 16rem;
}
.l-lpcontents .p-style05 .p-style_text {
  margin-top: 9.7rem;
}
.l-lpcontents .p-style05 .c-text_style_title {
  margin-top: 4.9rem;
}
.l-lpcontents .p-style05 .c-text_style_device,
.l-lpcontents .p-style05 .c-text_style_title {
  text-align: right;
}
.l-lpcontents .p-style05 .c-text_style_lead {
  letter-spacing: 0.05em;
}
.l-lpcontents .p-style05 .c-text_style_credit {
  text-align: right;
}
@media screen and (max-width: 767px) {
  .l-lpcontents .p-style05 {
    margin-top: calc(270*100vw/750);
  }
  .l-lpcontents .p-style05 .p-style_inner {
    row-gap: calc(90*100vw/750);
  }
  .l-lpcontents .p-style05 .p-style_wrapper::before {
    top: calc(377* 100vw / 750);
    left: calc(0* 100vw / 750);
  }
  .l-lpcontents .p-style05 .p-style_image {
    margin-right: calc(0*100vw/750);
    margin-left: auto;
  }
  .l-lpcontents .p-style05 .p-style_text {
    margin-top: calc(40*100vw/750);
  }
  .l-lpcontents .p-style05 .c-text_style_title {
    margin-top: calc(54*100vw/750);
  }
  .l-lpcontents .p-style05 .c-text_style_device,
  .l-lpcontents .p-style05 .c-text_style_title {
    text-align: left;
  }
  .l-lpcontents .p-style05 .c-text_style_lead {
    letter-spacing: 0.075em;
  }
  .l-lpcontents .p-style05 .c-text_style_credit {
    text-align: center;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
slick
//////////////////////////////////////////////////////////////////////////////////////////////
*/
.l-lpcontents .slick-dots {
  position: absolute;
  bottom: -2rem;
  left: var(--left, initial);
  right: var(--right, initial);
}
.l-lpcontents .slick-dots li {
  display: inline-block;
  margin-inline: 0.4rem;
}
.l-lpcontents .slick-dots li button {
  width: 0.6rem;
  height: 0.6rem;
  font-size: 0;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background-color: var(--color-dot-default);
}
.l-lpcontents .slick-dots li.slick-active button {
  background-color: var(--color-dot-active);
}
@media screen and (max-width: 767px) {
  .l-lpcontents .slick-dots {
    bottom: calc(-67* 100vw / 750);
    margin: initial;
  }
  .l-lpcontents .slick-dots li {
    margin: 0 calc(10*100vw/750);
  }
  .l-lpcontents .slick-dots li button {
    width: calc(16*100vw/750);;
    height: calc(16*100vw/750);;
  }
}

/************** ドットの位置がPC/SP共通の場合 **************/
.l-lpcontents .c-dot-right .slick-dots {
  --right: -0.5rem;
}
.l-lpcontents .c-dot-center .slick-dots {
  --left: 50%;
  transform: translateX(-50%);
}
.l-lpcontents .c-dot-left .slick-dots {
  --left: -0.5rem;
}
/************ ドットの位置がPCのみ指定したい場合 ************/
@media screen and (min-width: 768px) {
  .l-lpcontents .c-pc_dot-right .slick-dots {
    --right: -0.5rem;
  }
  .l-lpcontents .c-pc_dot-center .slick-dots {
    --left: 50%;
    transform: translateX(-50%);
  }
  .l-lpcontents .c-pc_dot-left .slick-dots {
    --left: -0.5rem;
  }
}
/************ ドットの位置がSPのみ指定したい場合 ************/
@media screen and (max-width: 767px) {
  .l-lpcontents .c-sp_dot-right .slick-dots {
    --right: calc(-12*100vw/750);
  }
  .l-lpcontents .c-sp_dot-center .slick-dots {
    --left: 50%;
    transform: translateX(-50%);
  }
  .l-lpcontents .c-sp_dot-left .slick-dots {
    --left: calc(-12*100vw/750);
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
animation - fade
//////////////////////////////////////////////////////////////////////////////////////////////
*/
/* firstviewのタイトルアニメーション */
.l-lpcontents .js-fade_fv_title {
  opacity: 0;
  transform: translate(-50%, 10px);
}
.l-lpcontents .js-fade_fv_title.is-active {
  opacity: 1;
  transform: translate(-50%, 0);
  transition: .8s ease 1.3s;
}
/* firstviewの画像の白背景のアニメーション */
.l-lpcontents .js-fade_scale {
  position: relative;
  overflow: hidden;
}
.l-lpcontents .js-fade_scale::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--color-blue);
  top: 0;
  right: 0;
  z-index: 2;
}
.l-lpcontents .js-fade_scale.is-active::before {
  transition: transform .8s ease .5s;
}
.l-lpcontents .c-firstview_image01.js-fade_scale.is-active::before {
  transform: translateX(100%);
}
.l-lpcontents .c-firstview_image02.js-fade_scale.is-active::before {
  transform: translateX(-100%);
}
/* firstviewの画像のアニメーション */
.l-lpcontents .js-fade_scale picture {
  display: block;
  transform: scale(1.13);
}
.l-lpcontents .js-fade_scale.is-active picture {
  transform: none;
  transition: transform .8s ease .5s;
}
/* firstviewのリード文アニメーション */
.l-lpcontents .js-fade_fv_text {
  opacity: 0;
  transform: translateY(15px);
  transition: .5s ease;
}
.l-lpcontents .js-fade_fv_text.is-active {
  opacity: 1;
  transform: none;
}
/* ページ全体のフェードアニメーション */
.l-lpcontents .js-fade {
  -webkit-transform: translateY(50px);
  transform: translateY(50px);
  opacity: 0;
}
.l-lpcontents .js-fade.is-active {
  animation: fadeAnimation 0.8s 0.3s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}
@keyframes fadeAnimation {
  0% {
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
    opacity: 0;
  }
  
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
  }
}

.l-lpcontents .js-bg::before {
  -webkit-transition: all 0.8s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.8s cubic-bezier(0.645, 0.045, 0.355, 1);
  -webkit-transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: left;
  transform-origin: left;
}
.l-lpcontents .js-bg.is-active::before {
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1);
}