@charset "UTF-8";

html {
  font-size: 62.5%;
  box-sizing: border-box;
}

@media (max-width: 1400px) and (min-width: 768px) {
  html {
    font-size: 0.7142857143vw;
  }
}

@media only screen and (min-width: 1401px) {
  html {
    font-size: 62.5%;
  }
}

@media only screen and (min-width: 1061px) {
  #breadcrumb, .bredlist.lp{
    margin: 20px auto 27px;
  }
}

.LB250402puma {
  /* --font_en-ttl: "big-caslon-fb", serif; */
  --font_en: "neulis-sans", sans-serif;
  --font_jp: "ヒラギノ角ゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", Osaka, sans-serif;
  --color-black: #000;
  --color-red: #841220;
  --color-blue: #2A2E49;
  --color-pink-bg: #FFF2F0;
  --color-blue-bg: #EAF3F4;
  --color-purple-bg: #F2F3F9;
  text-align: center;
  font-weight: 400;
  margin: 0 auto;
}

.main-inner {
  /* margin-top: 8rem; */
  width: 100% !important;
}

/* Neulis Sans
Semi Bold
font-family: "neulis-sans", sans-serif;
font-weight: 600;
font-style: normal;

Medium
font-weight: 500;

Regular
font-weight: 400;
*/

@media screen and (max-width: 767px) {

  .pc {
    display: none !important;
  }

  .main-area.lp {
    overflow: unset;
  }

}

@media only screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }

  .LB250402puma {
    overflow: hidden;
  }

}

.LB250402puma li {
  list-style: none;
}

.LB250402puma img,
.LB250402puma svg {
  width: 100%;
  height: auto;
}

.LB250402puma a{
  display: inline-block;
}

.LB250402puma picture{
  display: block;
}

.LB250402puma span {
  display: inline;
}

.sec{
  overflow-x: clip;
}

.item_subttl{
  line-height: 1;
  font-family: var(--font_en);
  letter-spacing: 0.04em;
}

.sec .item_ttl {
  position: absolute;
  font-family: var(--font_en);
  font-weight: 600;
  font-style: normal;
  line-height: 1.1;
  text-align: left;
  pointer-events: none;
}

@media screen and (max-width: 767px) {
  .sec{
    margin-bottom: calc(180* (100vw / 750));
  }

  .sec .item_block01{
    margin-bottom: calc(180* (100vw / 750));
  }

  .item_subttl{
    font-size: calc(52* (100vw / 750));
    margin-bottom: calc(95* (100vw / 750));
  }

  .sec .item_ttl {
    font-size: calc(106* (100vw / 750));
    margin-left: calc(42* (100vw / 750));
  }
}

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

  .sec .item_block01{
    margin-bottom: 12rem;
  }

  .item_subttl{
    font-size: 3.6rem;
    margin-bottom: 5.3rem;
  }

  .sec .item_ttl {
    font-size: 6.8rem;
  }
}

/* ▽_____________ credit ______________▽ */
.LB250402puma .credit_block {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.LB250402puma .credit_block a{
  display: inline;
}

.LB250402puma .credit_block li {
  font-family: var(--font_en);
  font-weight: 400;
  font-style: normal;
  line-height: 1;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

@media screen and (max-width: 767px) {
  .LB250402puma .credit_block {
    column-gap: calc(10*(100vw / 750));
    row-gap: calc(21*(100vw / 750));
    margin-top: calc(50*(100vw / 750));
  }

  .LB250402puma .credit_block li {
    font-size: calc(22* (100vw / 750));
  }
}

@media screen and (min-width: 768px) {
  .LB250402puma .credit_block {
    margin-top: 3rem;
    column-gap: 0.5rem;
    row-gap: 1.1rem;
  }

  .LB250402puma .credit_block li {
    font-size: 1.1rem;
  }
}

/* -----------------------------------------------
* txt_svg *
----------------------------------------------- */
@media screen and (max-width: 767px) {
  .gpt_svg{
    width: calc(477.1045* (100vw / 750));
    height: calc(308.886* (100vw / 750));
  }

  .mgsb_svg{
    width: calc(551.3008* (100vw / 750));
    height: calc(308.8857* (100vw / 750));
  }

  .prd_svg{
    width: calc(317.6787* (100vw / 750));
    height: calc(308.8862* (100vw / 750));
  }

  .bs_svg{
    width: calc(483.7871* (100vw / 750));
    height: calc(192.2852* (100vw / 750));
  }

  .pl_svg{
    width: calc(488.2324* (100vw / 750));
    height: calc(191.0137* (100vw / 750));
  }

  .alu_svg{
    width: calc(236.3926* (100vw / 750));
    height: calc(28.0752* (100vw / 750));
  }

  .cai_svg{
    width: calc(356.7939* (100vw / 750));
    height: calc(28.5547* (100vw / 750));
  }

}

@media screen and (min-width: 768px) {
  .gpt_svg{
    width: 30.60596rem;
    height: 19.81471rem;
  }

  .mgsb_svg{
    width: 35.36602rem;
    height: 19.81475rem;
  }

  .prd_svg{
    width: 32.58496rem;
    height: 12.33472rem;
  }

  .bs_svg{
    width: 31.03477rem;
    height: 12.33472rem;
  }

  .pl_svg{
    width: 31.32002rem;
    height: 12.25313rem;
  }

  .alu_svg{
    width: 14.18398rem;
    height: 1.68496rem;
  }

  .cai_svg{
    width: 21.40791rem;
    height: 1.71377rem;
  }

}

/* ===============================================
* heading *
=============================================== */
.LB250402puma .heading{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.LB250402puma .mv_cont{
  background-color: var(--color-pink-bg);
  width: 100vw;
}

.LB250402puma .txtAnimation-wrap,
.LB250402puma .mv_cont .ttl{
  width: 100%;
}

.LB250402puma .mv_img{
  position: relative;
  z-index: 100;
}

.LB250402puma .mv_img::after{
  content: "";
  position: absolute;
  background-color: var(--color-red);
  z-index: -100;
}

.LB250402puma .mv_ttl{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.LB250402puma .mv_subttl .ttl{
  font-family: var(--font_en);
  color: var(--color-red);
  line-height: 1;
  text-align: center;
  font-weight: 400;
}

.LB250402puma .mv_txt {
  font-family: var(--font_jp);
  font-style: normal;
  letter-spacing: 0.03em;
  text-align: center;
  font-feature-settings: "palt";
  line-height: 2;
}

.LB250402puma .sale-info{
  position: relative;
  font-family: var(--font_jp);
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--color-red);
  text-align: center;
}

.LB250402puma .sale-info::before,
.LB250402puma .sale-info::after{
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--color-red);
  height: 2px;
}

.LB250402puma .sale-info::before{
  top: 0;
}

.LB250402puma .sale-info::after{
  bottom: 0;
}

.LB250402puma .sale-info .date,
.LB250402puma .sale-info .day{
  font-family: var(--font_en);
  font-weight: 500;
}


@media screen and (max-width: 767px) {
  .LB250402puma .heading{
    margin-bottom: calc(180* (100vw / 750));
  }

  .LB250402puma .mv_cont{
    padding: calc(80* (100vw / 750)) 0 calc(140* (100vw / 750));
  }

  .LB250402puma .mv_img{
    width: calc(670* (100vw / 750));
    margin: 0 auto;
  }

  .LB250402puma .mv_img::after{
    width: calc(670* (100vw / 750));
    height: calc(670* (100vw / 750));
    top: calc(-40* (100vw / 750));
    left: calc(-40* (100vw / 750));
  }

  .LB250402puma .logo_top{
    width: calc(550* (100vw / 750));
    margin: calc(60* (100vw / 750)) 0 calc(40* (100vw / 750));
  }

  .LB250402puma .logo_top .item_ttl,
  .LB250402puma .logo_top .txtAnimation-wrap{
    height: calc(185* (100vw / 750));
  }

  .LB250402puma .mv_subttl{
    font-size: calc(30* (100vw / 750));
    padding-bottom: calc(3*(100vw / 750));
  }

  .LB250402puma .mv_subttl .ttl{
    padding-bottom: calc(3*(100vw / 750));
  }

  .LB250402puma .mv_txt {
    font-size: calc(24* (100vw / 750));
    /* font-weight: 300; */
    padding: calc(130* (100vw / 750)) 0 calc(125* (100vw / 750));
  }

  .LB250402puma .sale-info{
    font-size: calc(38* (100vw / 750));
    padding: calc(38*(100vw / 750)) 0;
    line-height: 1;
  }

  .LB250402puma .sale-info::before,
  .LB250402puma .sale-info::after{
    width: calc(670* (100vw / 750));
  }

  .LB250402puma .sale-info .date{
    font-size: calc(48* (100vw / 750));
  }

  .LB250402puma .sale-info .day{
    font-size: calc(38* (100vw / 750));
  }
}

@media screen and (min-width: 768px) {
  .LB250402puma .heading{
    margin-bottom: 12rem;
  }

  .LB250402puma .mv_cont__inner{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 92rem;
    padding: 5rem 0;
    margin: 0 auto;
  }

  .LB250402puma .mv_img{
    width: 40rem;
    margin: 0 0 3rem 3rem;
  }

  .LB250402puma .mv_img:before{
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    overflow: auto;
    z-index: -1;
    background-color: #fff;
  }

  .LB250402puma .mv_img:after{
    width: 40rem;
    height: 49.33333rem;
    bottom: -3rem;
    left: -3rem;
  }

  .LB250402puma .mv_ttl{
    margin-bottom: 2.5rem;
  }

  .LB250402puma .logo_top{
    width: 39rem;
    margin-bottom: 2.8rem;
  }

  .LB250402puma .mv_subttl{
    font-size: 1.8rem;
    padding-bottom: 0.3rem;
  }

  .LB250402puma .mv_subttl .ttl{
    padding-bottom: 0.3rem;
  }

  .LB250402puma .mv_txt {
    font-size: 1.4rem;
    /* font-weight: 500; */
    padding: 8.3rem 0 9.2rem;
  }

  .LB250402puma .sale-info{
    font-size: 2rem;
    padding: 1.4rem 0 1.1rem;
  }

  .LB250402puma .sale-info::before,
  .LB250402puma .sale-info::after{
    width: 34rem;
  }


  .LB250402puma .sale-info .date{
    font-size: 2.6rem;
  }

  .LB250402puma .sale-info .day{
    font-size: 2rem;
    padding-right: 0.4rem;
  }
}


/* ===============================================
* sec01 *
=============================================== */
.sec01{
  position: relative;
}

.sec01::after{
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  background-color: var(--color-pink-bg);
  z-index: -1;
  pointer-events: none;
}

.sec01 .item_ttl{
  color: var(--color-red);
  top: 0;
  left: 0;
}

.sec01 .item_inner{
  display: flex;
}

.sec01 .item__container01{
  position: relative;
  z-index: 1;
}

.sec01 .item01-png{
  position: absolute;
  z-index: 2;
}

.sec01 .item_img02{
  position: relative;
  z-index: 2;
}

.sec01 .item_img02::after{
  content: "";
  position: absolute;
  background-color: var(--color-red);
  z-index: -1;
  pointer-events: none;
}

@media screen and (max-width: 767px) {
  .sec01::after{
    height: calc(1256* (100vw / 750));
    top: calc(295* (100vw / 750));
  }

  .sec01 .item_inner{
    flex-direction: column;
    row-gap: calc(40* (100vw / 750));
  }

  .sec01 .item__container01{
    margin-top: calc(295*(100vw / 750));
    padding-top: calc(113* (100vw / 750));
  }

  .sec01 .item_ttl{
    top: calc(-296* (100vw / 750));
    left: 0;
  }

  .sec01 .item_img01{
    width: calc(540* (100vw / 750));
    margin-left: calc(40* (100vw / 750));
    margin-right: auto;
  }

  .sec01 .item01-png{
    top: calc(-137*(100vw / 750));
    right: calc(10*(100vw / 750));
    width: calc(300* (100vw / 750));
  }

  .sec01 .item_img02{
    width: calc(710* (100vw / 750));
    margin: 0 auto;
    padding-bottom: calc(40* (100vw / 750));
  }

  .sec01 .item_img02::after{
    width: calc(710* (100vw / 750));
    height: calc(875.6667* (100vw / 750));
    top: calc(40* (100vw / 750));
    left: calc(-40* (100vw / 750));
  }

  .sec01 .item__container02{
    width: calc(710* (100vw / 750));
    padding: 0 0 0 calc(40* (100vw / 750));
  }
}

@media screen and (min-width: 768px) {
  .sec01::after{
    width: 100vw;
    height: 52rem;
    top: 25rem;
  }

  .sec01 .item_inner{
    width: 103rem;
    margin: 0 auto;
    flex-direction: row-reverse;
    justify-content: space-between;
  }


  .sec01 .item__container01{
    width: 49rem;
    padding-top: 41rem;
  }

  .sec01 .item_ttl{
    top: 6rem;
    left: 8.2rem;
    letter-spacing: 0.005em;
  }

  .sec01 .item_img01{
    width: 36rem;
  }

  .sec01 .item01-png{
    top: 22rem;
    right: 0;
    width: 22rem;
  }

  .sec01 .item__container02{
    width: 50rem;
    padding-left: 3rem;
  }

  .sec01 .item_img02{
    width: 47rem;
    margin: 0 auto 0 0;
    margin-bottom: 6rem;
    z-index: 100;
  }

  .sec01 .item_img02:before{
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    overflow: auto;
    z-index: -1;
    background-color: #fff;
  }


  .sec01 .item_img02::after{
    width: 47rem;
    height: 57.96667rem;
    top: 3rem;
    left: -3rem;
    z-index: -100;
  }

  .sec01 .credit_block{
    width: 29.5rem;
  }

}


/* ===============================================
* sec02 *
=============================================== */

.sec02,
.sec02 .item_block01 {
  position: relative;
}

.sec02::after,
.sec02 .item_block01::after {
  content: "";
  position: absolute;
  background-color: var(--color-blue-bg);
  z-index: -100;
  pointer-events: none;
}



.sec02 .item_ttl{
  color: var(--color-blue);
  z-index: 10;
}

.sec02 .item02-img,
.sec02 .item03_1{
  position: relative;
}

.sec02 .item02-img::after,
.sec02 .item03_1::after{
  content: "";
  position: absolute;
  background-color: var(--color-blue);
  z-index: -1;
}


.sec02::before,
.sec02 .item_block02::before {
  content: "";
  position: absolute;
  background-color: var(--color-purple-bg);
  z-index: -1;
  pointer-events: none;
}


@media screen and (max-width: 767px) {
  .sec02::after{
    width: calc(300* (100vw / 750));
    height: calc(828* (100vw / 750));
    top: 0;
    left: 0;
  }

  .sec02::before{
    width: 100%;
    height: calc(860* (100vw / 750));
    left: 0;
    bottom: calc(230* (100vw / 750));
  }

  .sec02 .item02_container{
    width: calc(520*(100vw / 750));
    padding-top: calc(412*(100vw / 750));
    margin-left: auto;
    margin-right: calc(80*(100vw / 750));
  }

  .sec02 .item_block01 .item_ttl {
    top: calc(120*(100vw / 750));
  }

  .itemsec0202 .item02-img{
    margin-top: calc(414* (100vw / 750));
    margin-right: calc(80* (100vw / 750));
  }

  .sec02 .item02-img::after{
    width: calc(520*(100vw / 750));
    height: calc(641.3333*(100vw / 750));
    top: calc(40* (100vw / 750));
    right: calc(-40* (100vw / 750));
  }

  .sec02 .item_block01 .credit_block {
    margin-top: calc(90*(100vw / 750));
  }

  .sec02 .item_block02{
    overflow-x: clip;
    margin-top: calc(80* (100vw / 750));
  }

  .sec02 .item03_1{
    width: calc(710* (100vw / 750));
    padding-bottom: calc(40* (100vw / 750));
    margin-left: auto;
  }

  .sec02 .item03_1::after{
    width: calc(710* (100vw / 750));
    height: calc(875.6667* (100vw / 750));
    bottom: 0;
    left: calc(-40* (100vw / 750));
  }

  .sec02 .item_block02 .item_ttl{
    bottom: calc(953* (100vw / 750));
    margin-left: calc(45*(100vw / 750));
    z-index: 1;
  }


  .sec02 .item03-png{
    position: relative;
    width: calc(750* (100vw / 750));
    height: calc(670.2128* (100vw / 750));
    top: calc(107*(100vw / 750));
    right: calc(-120* (100vw / 750));
    z-index: 10;
  }

  .sec02 .item03_conteiner{
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    width: calc(670* (100vw / 750));
    margin: calc(105* (100vw / 750)) auto 0;
  }

  .sec02 .item__container01 .credit_block{
    flex-direction: column;
    align-items: baseline;
  }

  .sec02 .item03_2{
    width: calc(460* (100vw / 750));
  }
}

@media screen and (min-width: 768px) {
  .sec02{
    position: relative;
    padding-bottom: 6rem;
  }

  .sec02 .item_block01::after{
    height: 28rem;
    width: 100vw;
    /* width: calc(1010*(100vw / 1400)); */
    top: 33rem;
    left: 11rem;
  }

  .sec02 .item_block01{
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center;
    width: 83.6rem;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 11.8rem;
  }

  .sec02 .item_ttl{
    position: relative;
    left: 0;
    top: 0.3rem;
  }

  .sec02 .item_block01 .credit_block{
    margin-top: 2rem;
  }

  .sec02 .item02_container{
    width: 35rem;
    margin-left: 3rem;
  }

  .sec02 .item02-img{
    margin-top: 3rem;
    background: #fff;
  }

  .sec02 .item02-img::after{
    width: 35rem;
    height: 43.16667rem;
    top: -3rem;
    left: -3rem;
  }

  .sec02 .item03_1{
    display: flex;
    align-items: flex-end;
    width: 47rem;
    grid-row: 1 / 3;
    grid-column: 1;
    background-color: #fff;
    margin: 0 0 0 auto;
  }

  .sec02 .item03_1::after{
    width: 47rem;
    height: 57.96667rem;
    top: 3rem;
    right: -3rem;
  }

  .sec02 .item_block02{
    position: relative;
    display: grid;
    grid-template-rows: 32rem 26rem auto;
    width: 97rem;
    margin: 0 auto;
    padding-left: 1rem;
  }

  .sec02 .item_block02::before{
    width: 100vw;
    /* width: calc(800*(100vw / 1400)); */
    height: 80rem;
    bottom: -6rem;
    right: 39rem;
  }

  .sec02 .item_block02 .item_ttl{
    position: absolute;
    top: 9rem;
    left: 20.5rem;
  }

  .sec02 .item__container01{
    position: relative;
    grid-row: 2 / 4;
    grid-column: 1;
    width: 62rem;
    height: 62.57447rem;
  }

  .sec02 .item03-png{
    position: absolute;
    width: 51rem;
    right: 0;
    bottom: 0;
    z-index: 10;
  }

  .sec02 .item03_conteiner{
    width: 32rem;
  }

  .sec02 .item03_conteiner .credit_block{
    flex-direction: column;
    align-items: baseline;
  }

}

/* ===============================================
* sec03 *
=============================================== */

.sec03{
  position: relative;
}

.sec03::after{
  content: "";
  position: absolute;
  background-color: var(--color-blue-bg);
  z-index: -2;
  pointer-events: none;
}

.sec03 .item_block01 .item_ttl{
  color: var(--color-red);
  z-index: 1;
}

.sec03 .item_block02 .item_ttl{
  color: var(--color-blue);
  z-index: 1;
}

.sec03 .item04-img,
.sec03 .item05-img{
  position: relative;
}


.sec03 .item04-img::after{
  content: "";
  position: absolute;
  background-color: var(--color-red);
  z-index: -1;
  pointer-events: none;
}

.sec03 .item05-img::after{
  content: "";
  position: absolute;
  background-color: var(--color-blue);
  z-index: -1;
}

.sec03 .item04-png{
  position: relative;
  z-index: 10;
}
/* 
.sec03 .item04-png img{
  display: block;
} */

@media screen and (max-width: 767px) {
  .sec03{
    padding-bottom: calc(180*(100vw / 750));
  }

  .sec03::after{
    width: 100%;
    height: calc(2547* (100vw / 750));
    bottom: 0;
    left: 0;
  }

  .sec03 .item_block01 {
    padding-top: calc(175*(100vw / 750));
    margin-bottom: calc(162*(100vw / 750));
  }

  .sec03 .item_block01 .item_ttl{
    top: calc(3*(100vw / 750));
    z-index: -1;
  }

  .sec03 .item04_container{
    display: grid;
    grid-auto-rows: calc(540*(100vw / 750)) calc(205*(100vw / 750)) auto;
  }

  .sec03 .item_block01 .credit_block{
    margin-left: calc(40* (100vw / 750));
  }

  .sec03 .item04-img{
    width: calc(460* (100vw / 750));
    grid-column: 1;
    grid-row: 1 / 3;
    margin-right: calc(40* (100vw / 750));
    margin-left: auto;
  }

  .sec03 .item04-img::after{
    width: calc(460* (100vw / 750));
    height: calc(744.625* (100vw / 750));
    top: calc(40*(100vw / 750));
    right: calc(-40*(100vw / 750));
  }

  .sec03 .item04-png_container{
    grid-column: 1;
    grid-row: 2 / 4;
  }

  .sec03 .item04-png{
    width: calc(640* (100vw / 750));
  }

  .sec03 .credit__cont{
    width: calc(535* (100vw / 750));
  }

  .sec03 .item_block02 .item_ttl{
    margin-left: calc(87*(100vw / 750));
    margin-top: calc(20*(100vw / 750));
  }

  .sec03 .item_block02 .item__container01{
    width: calc(520* (100vw / 750));
    margin: 0 auto;
    padding-top: calc(185*(100vw / 750));
  }

  .sec03 .item05-img::after{
    width: calc(520* (100vw / 750));
    height: calc(641.3333* (100vw / 750));
    top: calc(40* (100vw / 750));
    right: calc(-40* (100vw / 750));
  }

  .sec03 .item_block02 .credit_block {
    margin-top: calc(90*(100vw / 750));
  }

}

@media screen and (min-width: 768px) {
  .sec03::after{
    width: 100%;
    height: 88.2rem;
    top: 17.7rem;
    left: 0;
  }

  .sec03 .item_inner{
    width: 110.4rem;
    margin: 0 auto;
  }

  .sec03 .item04_container{
    display: grid;
    grid-template-rows: 25.6rem 26.2rem auto;
  }

  .sec03 .item04-png_container{
    display: flex;
    flex-direction: row-reverse;
  }

  .sec03 .item_block01{
    display: grid;
    position: relative;
    width: 64.4rem;
    grid-template-rows: 25.6rem 26.2rem auto;
    grid-template-columns: 27rem 5.5rem auto;
    margin: 0 0 21.5rem auto;
  }

  .sec03 .item_block01 .item_ttl{
    left: 0;
    top: 6rem;
  }

  .sec03 .item_ttl{
    grid-row: 1 / 2;
    grid-column: 2 / 4;
    justify-self: baseline;
    align-self: center;
    padding-bottom: 0.5rem;
  }

  .sec03 .item04-img{
    background-color: #fff;
    width: 32rem;
    grid-row: 1 / 3;
    grid-column: 1 / 3;
  }

  .sec03 .item04-img::after{
    width: 32rem;
    height: 51.8rem;
    top: 3rem;
    left: -3rem;
  }

  .sec03 .item04-png{
    width: 38rem;
    top: -26rem;
    left: 2.5rem;
  }

  .sec03 .credit__cont{
    width: 24rem;
    grid-row: 3;
  }

  .sec03 .item_block01 .credit_block {
    margin-top: 6.2rem;
    width: 26rem;
  }

  .sec03 .item_block02{
    position: relative;
    width: 36rem;
    margin-right: auto;
    margin-left: 0;
  }

  .sec03 .item_block02 .item_ttl{
    position: absolute;
    width: 100%;
    bottom: 10.7rem;
    right: -31.8rem;
  }

  .sec03 .item_block02 .item__container01{
    width: 36rem;
    margin: 0 auto;
  }

  .sec03 .item05-img{
    display: flex;
    align-items: flex-end;
    background-color: #fff;
    width: 33rem;
    left: 3rem;
    margin-bottom: 6rem;
  }

  .sec03 .item05-img::after{
    width: 33rem;
    height: 40.7rem;
    top: 3rem;
    left: -3rem;
  }
}

/* ===============================================
* footer-logo *
=============================================== */
@media screen and (max-width: 767px) {
  .footer-logo{
    width: calc(260* (100vw / 750));
    margin: 0 auto calc(180* (100vw / 750));
  }
}

@media screen and (min-width: 768px) {
  .footer-logo{
    width: 15rem;
    margin: 0 auto 12rem;
  }
}

/* ===============================================
* all btn *
=============================================== */
.all_item_btn__wrapper{
  display: flex;
  position: relative;
  flex-direction: column;
  z-index: 100;
}

.all_item_btn{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.all_item_btn::after{
  content: "";
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
  z-index: -1;
  left: 50%;
  transform: translateX(-50%);
}

.all_item_btn a{
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: var(--font_en);
  text-align: center;
  width: 100%;
  height: 100%;
  letter-spacing: 0.03em;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .all_item_btn__wrapper{
    width: calc(670* (100vw / 750));
    row-gap: calc(20* (100vw / 750));
    margin: 0 auto calc(200* (100vw /750));
  }
  .all_item_btn{
    height: calc(140* (100vw / 750));
  }

  .all_item_btn::after{
    background-image: url(../img/SVG/cai-bg_sp.svg);
  }

  .all_item_btn a{
    font-size: calc(40* (100vw / 750));
    padding: 0 0 calc(5*(100vw / 750)) calc(15*(100vw / 750));
  }

}

@media screen and (min-width: 768px) {
  .all_item_btn__wrapper{
    width: 39rem;
    row-gap: 1rem;
    margin: 0 auto 15rem;
    padding-right: 1rem;
  }

  @media screen and (-webkit-min-device-pixel-ratio:0) {
    .all_item_btn__wrapper .txtAnimation-wrap{
      padding-top: 1rem;
    }
  }
  .all_item_btn{
    height: 7rem;
  }

  .all_item_btn::after{
    background-image: url(../img/SVG/cai-bg_pc.svg);
  }

  .all_item_btn a {
    font-size: 2.4rem;
    padding-bottom: 0.3rem;
}
}


/***************************** animation *****************************/
/* ______________________________ .js_fade  */
.LB250402puma .js_fade {
  opacity: 0;
  transition: all ease 1s;
}

.LB250402puma .js_fade.active {
  opacity: 1;
}

/* ______________________________ .js_fade  */
.js_slidIn{
  opacity: 0;
  position: relative;
  transition: all 0.35s ease-in 0.25s;
  transform: translateX(-10px);
}

.js_slidIn.active{
  opacity: 1;
  transform: translateX(0px);
}

.mv_cont .delay-05{
  transition-delay: 0.5s;
}

.mv_cont .delay-10{
  transition-delay: 1s;
}

/* ______________________________ .js_fade  */
.txtAnimation {
  display: inline-block;
  transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 1s;
  opacity: 0;
  transform: translate(0, 105%);
  font-weight: 500;
}

.js-txt-Vr.active .txtAnimation{
  opacity: 1;
  transform: translate(0, 0);
}

.js-txt-Vr span {
  display: inline-block;
}

.txtAnimation-wrap{
  overflow: hidden;
  padding: 0.1px;
}

/***************************** animation *****************************/