@charset "utf-8";

/* --- common --- */
._t50 {
  font-size: 50px;
}
._t36 {
  font-size: 36px;
}
._t28 {
  font-size: 28px;
}
._t24 {
  font-size: 24px;
}
._t20 {
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .btn_box a {
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
  }
  a:focus {
    outline: none;
  }
  .cookie_dialog_box {
    bottom: 45px;
  }
}
/* --- parts --- */
/* title */
.ttl_type1, .ttl_type2, .ttl_type4 {
  font-weight: 700;
}
.ttl_type1, .ttl_type2 {
  position: relative;
  padding-top: 60px;
  text-align: center;
}
.ttl_type1 {
  color: #fff;
}
.ttl_type1 > span,
.ttl_type2 > span {
  display: block;
}
.ttl_type1 > .rect,
.ttl_type2 > .rect {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0) rotate(45deg);
  width: 28px;
  aspect-ratio: 1/1;
}
.ttl_type1 > .rect {
  background-color: #fff;
  box-shadow: 0 0 20px #fff;
}
.ttl_type2 > .rect {
  background-color: #B81C22;
}
.ttl_type1 > .rect::before,
.ttl_type1 > .rect::after,
.ttl_type2 > .rect::before,
.ttl_type2 > .rect::after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 1/1;
}
.ttl_type1 > .rect::before,
.ttl_type1 > .rect::after {
  background-color: #fff;
  box-shadow: 0 0 20px #fff;
}
.ttl_type2 > .rect::before,
.ttl_type2 > .rect::after {
  background-color: #B81C22;
}
.ttl_type1 > .rect::before,
.ttl_type2 > .rect::before {
  transform: translate(-150%, 150%)
}
.ttl_type1 > .rect::after,
.ttl_type2 > .rect::after {
  transform: translate(150%, -150%)
}
@media screen and (max-width: 767px) {
  .ttl_type1, .ttl_type2 {
    padding-top: 36px;
  }
  .ttl_type1 > .rect,
  .ttl_type2 > .rect {
    width: 21px;
  }
}

/* btn */
.btn_box a {
  transition: opacity .2s;
}
.btn_box a:hover {
  opacity: .8;
}
.btn_type1 {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 300px;
  height: 69px;
  border-radius: 35px;
  border: 2px #B81C22 solid;
  background-color: #fff;
  box-shadow: 0 5px 5px rgba(0,0,0,0.1);
}
.btn_type1::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% + 1px);
  right: 23px;
  transform: translate(0, -50%);
  width: 16px;
  height: 20px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  background-image: url(../images/btn_arrow_red.svg);
}

.btn_type2 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100px;
  border-radius: 10px;
  background: linear-gradient(to left, #EC604A, #F39751, #EC604A, #F39751, #EC604A);
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
  font-weight: 700;
}
.btn_type2 > span {
  color: #fff;
}

.btn_type3 {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 70px;
  border-radius: 35px;
  border: 1px #999 solid;
  background-color: #fff;
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.1);
  color: #4D4D4D;
}

.btn_type3::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% + 1px);
  right: 24px;
  transform: translate(0, -50%);
  width: 14px;
  height: 18px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  background-image: url(../images/btn_arrow_black.svg);
}

.btn_type4 {
  width: 640px;
  aspect-ratio: 16/5;
  border-radius: 10px;
  border: 2px #f7af0e solid;
  overflow: hidden;
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
}
@media screen and (max-width: 767px) {
  .btn_type1 {
    width: 240px;
    height: 56px;
    border-radius: 28px;
  }
  .btn_type1 ._t20 {
    font-size: 16px;
  }
  .btn_type2 {
    height: 77px;
  }
  .btn_type2 > span {
    font-size: 20px;
  }
  .btn_type4 {
    width: calc(335 / 375 * 100%);
  }
}

.btn_oubo {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 281px;
  height: 75px;
  border-radius: 15px 0 0 15px;
  border: 3px #fff solid;
  border-right-style: none;
  background-color: #B81C22;
  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
  color: #fff !important;
  font-weight: 700;
}
.btn_oubo.for_sp {
  display: none;
}
.btn_oubo::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% + 1px);
  right: 24px;
  transform: translate(0, -50%);
  width: 16px;
  height: 20px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  background-image: url(../images/btn_arrow_white.svg);
}

@media screen and (max-width: 767px) {
  .btn_oubo {
    width: calc(100% - 6px);
    height: 56px;
    box-sizing: content-box;
    border-radius: 15px 15px 0 0;
    border-right-style: solid;
    border-bottom-style: none;
    box-shadow: 0 -5px 5px rgba(0, 0, 0, 0.2);
  }
  .btn_oubo.for_sp {
    display: flex;
  }
  .btn_oubo.for_pc {
    display: none;
  }

  #page_top_btn {
    position: absolute;
    bottom: 386px !important;
    z-index: 1900;
  }
}

/* --- layout --- */
/* body */
body {
  padding-top: 101px;
}
@media screen and (max-width: 767px) {
  body {
    padding-top: 48px;
    /*padding-bottom: 56px;*/
  }
}

#container {
  position: relative;
}

@media screen and (max-width: 767px) {
  #main_box {
    padding: 0;
  }
}

/* text */
._ilbl {
  display: inline-block;
}
._center {
  text-align: center;
}
._idt_1 {
  padding-left: 1em;
  text-indent: -1em;
}
._pal_1 {
  padding-left: 1em;
}
@media screen and (min-width: 768px) {
  ._idt_2_pc {
    padding-left: 2em;
    text-indent: -2em;
  }  
}

/* flex */
._fl3 {
  display: flex;
  justify-content: center;
}
._fl3 > li > .image {
  width: 250px;
  aspect-ratio: 5/8;
}
._fl3 > li > .name {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 120px;
  aspect-ratio: 1 / 1;
  margin: 0 auto;
}
._fl3 > li > .name::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  width: 85px;
  aspect-ratio: 1/1;
  box-shadow: 0 0 20px #fff;
}
._fl3 > .item01 > .name::before { background-color: #7AA73B; }
._fl3 > .item02 > .name::before { background-color: #BA9A31; }
._fl3 > .item03 > .name::before { background-color: #8DB4C7; }
._fl3 > li > .name > span {
  position: relative;
  color: #fff;
}
@media screen and (max-width: 767px) {
  ._fl3 > li > .image {
    width: 101px;
  }
  ._fl3 > li > .name {
    width: 50px;
    font-size: 14px;
  }
  ._fl3 > li > .name::before {
    width: 34px;
  }
}

/* btn_box */
.btn_box {
  display: flex;
  justify-content: center;
}
.btn_fix {
  position: fixed;
  bottom: 110px;
  right: 0;
  z-index: 2000;
}
@media screen and (max-width: 767px) {
  .btn_fix {
    width: calc(100% + 6px);
    bottom: 0;
    right: -3px;
  }
}

/* MV */
.mv_box {
  position: relative;
  width: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  background-image: url(../images/mv.webp);
  overflow: hidden;
}
.mv_box > .ttl {
  display: block;
  position: relative;
  width: calc(121 / 160 * 100%);
  max-width: 1210px;
  min-width: 720px;
  aspect-ratio: 121 / 80;
  margin: 0 auto;
}
.mv_box > .ttl > span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  aspect-ratio: 1210/936;
  background-size: contain;
  background-image: url(../images/mv_logo.svg);
}
@media screen and (max-width: 767px) {
  .mv_box {
    background-image: url(../images/mv_sp.webp);
  }
  .mv_box > .ttl {
    width: 100%;
    min-width: auto;
    aspect-ratio: 375 / 619;
  }
  .mv_box > .ttl > span {
    width: calc(428 / 375 * 100%);
  }
}
.mv_box .close {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,.75);
  color: #FFF;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 40px;
  letter-spacing: .1em;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .mv_box .close {
    font-size: 30px;
    letter-spacing: 0;
  }
}


/* box_01 */
.box_01 {
  position: relative;
  padding-top: 150px;
  background: linear-gradient(#EC604A, #F39751);
  overflow: hidden;
}
.box_01::before {
  content: '';
  display: block;
  position: absolute;
  top: 140px;
  left: clamp(-220px, calc(13.8221vw - 326.1538px), -105px);
  width: 405px;
  aspect-ratio: 135/322;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_box_01_01.svg);
}
.sec_01 {
  position: relative;
  padding-bottom: 156px;
  color: #fff;
}
.sec_01 .sec_body {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sec_01 .text {
  font-weight: 700;
  /* font-size: clamp(25px, calc(0.6787vw + 19.7873px), 28px); */
}
.sec_01 .note {
  font-size: clamp(18px, calc(0.4525vw + 14.5249px), 20px);
}
@media screen and (max-width: 767px) {
  .box_01 {
    padding-top: 100px;
  }
  .box_01::before {
    display: none;
  }
  .sec_01 {
    padding-bottom: 100px;
  }
  .sec_01 .sec_header .ttl_type1 ._t36 {
    font-size: 20px;
  }
  .sec_01 .text {
    font-size: 20px;
  }
  .sec_01 .note {
    width: calc(305 / 375 * 100%);
    margin-right: auto;
    margin-left: auto;
    font-size: 16px;
    font-feature-settings: "palt";
    letter-spacing: .06em;
  }
}

.sec_02 .present_outer {
  background-color: #B81C22;
}
.sec_02 .sec_header {
  padding-top: 150px;
  padding-bottom: 60px;
}
.sec_02 .present_box {
  position: relative;
  padding-bottom: 156px;
}
.sec_02 .present_box::before {
  content: '';
  display: block;
  position: absolute;
  top: 202px;
  left: 0;
  width: 100%;
  height: 256px;
  background-color: #fff;
}
.sec_02 .present_box .present_inner {
  position: relative;
}
@media screen and (max-width: 767px) {
  .sec_02 {
    position: relative;
  }
  .sec_02::before {
    content: '';
    display: block;
    position: absolute;
    top: -48px;
    left: -60px;
    width: 170px;
    aspect-ratio: 170/90;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url(../images/bg_box_01_01_sp.svg);
  }
  .sec_02 .sec_header {
    padding-top: 100px;
    padding-bottom: 50px;
  }
  .sec_02 .sec_header ._t36 {
    font-size: 22px;
  }
  .sec_02 .sec_header ._t50 {
    font-size: 23px;
  }
  .sec_02 .present_box::before {
    top: 91px;
    height: 95px;
  }
}

.lte_box {
  position: relative;
  padding-top: 150px;
  padding-bottom: 150px;
}
.lte_box::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 113px;
  right: clamp(-220px, calc(13.8221vw - 326.1538px), -105px);
  width: 405px;
  aspect-ratio: 81/229;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_box_01_02.svg);
}
.lte_box .lte_inner {
  position: relative;
  width: calc(100 / 121 * 100%);
  max-width: 1000px;
  min-width: 720px;
  margin: 0 auto;
  border: 4px #FFB785 solid;
  border-radius: 20px;
  padding: 36px;
}
.lte_box .lte_inner h4 {
  font-weight: 700;
  color: #fff;
}
.lte_box .lte_inner .text {
  color: #fff;
}
.lte_box .lte_inner ._unterl {
  font-weight: 700;
  font-size: 20px;
}
.lte_box .lte_inner .image {
  width: 450px;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .lte_box {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  .lte_box::before {
    top: -45px;
    bottom: auto;
    right: -84px;
    width: 225px;
    aspect-ratio: 225/90;
    background-image: url(../images/bg_box_01_02_sp.svg);
  }
  .lte_box .lte_inner {
    width: calc(335 / 375 * 100%);
    min-width: auto;
    padding: 36px 11px;
  }
  .lte_box .lte_inner h4._t28 {
    font-size: 20px;
  }
  .lte_box .lte_inner .text {
    margin-bottom: 20px;
  }
  .lte_box .lte_inner ._unterl {
    font-size: 16px;
    font-weight: 400;
  }
  .lte_box .lte_inner .image {
    width: calc(305 / 335 * 100%);
  }
}


/* box_02 */
.box_02 {
  position: relative;
  padding-top: 150px;
  padding-bottom: calc(754 / 1600 * 100%);
  background-color: #FFF9E8;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  background-image: url(../images/bg_sec_03.webp);
  overflow: hidden;
}
.box_02::before {
  content: '';
  display: block;
  position: absolute;
  top: 100px;
  right: -200px;
  width: 400px;
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_box_02_01.svg);
}
.sec_03 {
  position: relative;
}
.sec_03::before {
  content: '';
  display: block;
  position: absolute;
  top: 715px;
  left: -155px;
  width: 400px;
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_box_02_02.svg);
}
.sec_03 .sec_header {
  position: relative;
}
.sec_03 .sec_header::before {
  content: '';
  display: block;
  position: absolute;
  top: -30px;
  left: -105px;
  width: 300px;
  aspect-ratio: 100/41;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_sec_03_01.svg);
}
.sec_03 .sec_body {
  position: relative;
  margin-top: 100px;
}
.sec_03 .about_campaign {
  width: calc(100 / 121 * 100%);
  max-width: 1000px;
  min-width: 720px;
  margin: 0 auto;
}
.sec_03 .about_campaign .campaign_info {
  padding: 0 5% 100px;
  border-bottom: 2px #B81C22 solid;
}
.sec_03 .about_campaign .campaign_info > li {
  display: flex;
  /* column-gap: clamp(20px, calc(2.9499vw - 5.6932px), 30px);*/
  font-size: clamp(22px, calc(1.7699vw + 6.5841px), 28px);
  font-weight: 700;
}
.sec_03 .about_campaign .campaign_info>li:nth-child(n+2) {
  margin-top: 25px;
}
.sec_03 .about_campaign .campaign_info > li .ttl {
  width: clamp(120px, calc(11.7994vw + 17.2271px), 160px);
  position: relative;
  padding-left: 20px;
  color: #B81C22;
}
.sec_03 .about_campaign .campaign_info>li .ttl::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: clamp(-10px, calc(-2.9499vw + 25.6932px), 0px);
  transform: translate(-50%, 55%) rotate(45deg);
  width: calc(28 / 180 * 100%);
  aspect-ratio: 1/1;
  background-color: #B81C22;
}
.sec_03 .about_campaign .campaign_info > li .item {
  width: calc(100% - clamp(120px, calc(11.7994vw + 17.2271px), 160px));
  font-feature-settings: "palt";
  letter-spacing: .03em;
}
.sec_03 .about_campaign .campaign_info > li .item .note {
  display: block;
  font-size: 14px;
  font-weight: 400;
}
.sec_03 .about_campaign h4 {
  font-weight: 700;
}
.sec_03 .about_campaign .notice_box {
  width: calc(936 / 1000 * 100%);
  margin: 100px auto;
}
.sec_03 .about_campaign .notice_box h4 {
  margin-bottom: 30px;
}
.sec_03 .about_campaign .notice_box .ttl {
  font-size: 110%;
  font-weight: 700;
}
.sec_03 .about_campaign .notice_box ul {
  color: #272727;
}

.sec_03 .about_campaign .close {
  font-size: 32px;
  font-weight: 700;
  color: #B81C22;
}

.sec_03 .about_campaign .terms_box {
  margin-top: 100px;
}
.sec_03 .about_campaign .terms_box .terms_outer {
  margin-top: 60px;
  border: 2px #EC6445 solid;
  border-radius: 10px;
  overflow: hidden;
}
.sec_03 .about_campaign .terms_box .terms_inner {
  height: 411px;
  overflow-y: scroll;
  padding: 40px 46px 40px 40px;
  background-color: #fff;
  color: #272727;
}
.sec_03 .about_campaign .terms_box .terms_inner > div:nth-child(n+2) {
  margin-top: 30px;
}
.sec_03 .about_campaign .terms_box .terms_inner h5 {
  margin-bottom: 20px;
}
.sec_03 .about_campaign .terms_box .terms_inner a {
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  .box_02 {
    padding-bottom: calc(350 / 375 * 100%);
    background-image: url(../images/bg_sec_03_sp.webp);
  }
  .box_02::before {
    top: 50px;
    width: 200px;
    right: -165px;
  }
  .box_02 .ttl_type2 ._t36 {
    font-size: 22px;
  }
  .sec_03::before {
    width: 200px;
    left: -165px;
    top: auto;
    bottom: 19.5%;
  }
  .sec_03 .sec_body {
    margin-top: 60px;
  }
  .sec_03 .sec_header::before {
    width: 150px;
    top: -70px;
    left: -67px;
  }
  .sec_03 .about_campaign {
    width: calc(335 / 375 * 100%);
    min-width: auto;
  }
  .sec_03 .about_campaign h4 {
    font-size: 18px;
  }
  .sec_03 .about_campaign .campaign_info > li {
    flex-direction: column;
    align-items: center;
    font-size: 20px;
  }
  .sec_03 .about_campaign .campaign_info > li .ttl {
    width: auto;
    margin-bottom: 15px;
    padding-left: 20px;
  }
  .sec_03 .about_campaign .campaign_info > li .ttl::before {
    left: 0;
    transform: translate(-100%, 40%) rotate(45deg);
    width: 21px;
  }
  .sec_03 .about_campaign .campaign_info > li .item {
    width: 100%;
  }
  .sec_03 .about_campaign .notice_box {
    margin: 80px auto;
  }
  .sec_03 .about_campaign .close {
    font-size: 24px;
  }
  .sec_03 .about_campaign .terms_box {
    margin-top: 80px;
  }
  .sec_03 .about_campaign .terms_box .terms_outer {
    margin-top: 30px;
  }
  .sec_03 .about_campaign .terms_box .terms_inner {
    padding: 15px 21px 15px 15px;
  }
}

/* box_03 */
.box_03 {
  position: relative;
  background: linear-gradient(to left, #F8D263, #FFE9CC, #FFE9CC, #F8D263);
  overflow: hidden;
}
.box_03::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 50px;
  right: -105px;
  width: 300px;
  aspect-ratio: 100/41;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_sec_04_02.svg);
}
.sec_04 {
  position: relative;
  width: 100%;
  max-width: 1000px;
  min-width: 720px;
  margin: 0 auto;
  padding: 150px 3.2%;
}
.sec_04::before {
  content: '';
  display: block;
  position: absolute;
  top: 50px;
  left: -105px;
  width: 300px;
  aspect-ratio: 10/3;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_sec_04_01.svg);
}
.sec_04 h3 {
  font-weight: 700;
}
.sec_04 h3 > span {
  display: inline-block;
}
.sec_04 .sec_body {
  margin-top: 40px;
}
.sec_04 .sec_body p {
  color: #272727;
}
.sec_04 .sec_body .btn_box {
  margin-top: 55px;
}
.sec_04 .sec_body .btn_type3 {
  width: 80%;
  min-width: 720px;
}
@media screen and (max-width: 767px) {
  .box_03::before {
    width: 110px;
    right: -30px;
    bottom: 30px;
  }
  .sec_04::before {
    width: 150px;
    left: -70px;
    top: 30px;
  }
  .sec_04 {
    width: calc(335 / 375 * 100%);
    min-width: auto;
    padding: 100px 0;
  }
  .sec_04 .sec_header ._t28 {
    font-size: 19px;
    font-weight: 400;
  }
  .sec_04 .sec_body .text {
    width: calc(305 / 335 * 100%);
    margin: 0 auto;
  }
  .sec_04 .sec_body .btn_type3 {
    width: 100%;
    height: 80px;
    border-radius: 40px;
    min-width: auto;
    font-size: 16px;
  }
}

/* content_bottom_box */
.content_bottom_box {
  position: relative;
  overflow: hidden;
  padding-top: 150px;
  padding-bottom: 150px;
  background: linear-gradient(#FFF9E9, #FFF7E1, #FDE397, #F18E49, #EB5F4A);
  overflow: hidden;
}
.content_bottom_box::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 200px;
  right: -200px;
  width: 400px;
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_content_bottom_box_02.svg);
}
.content_bottom_box .text {
  position: relative;
}
.content_bottom_box .text::before {
  content: '';
  display: block;
  position: absolute;
  top: 150px;
  left: -200px;
  width: 400px;
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/bg_content_bottom_box_01.svg);
}
.content_bottom_box .text > span {
  position: relative;
  display: block;
  width: 400px;
  aspect-ratio: 20/23;
  margin: 0 auto;
  background-size: contain;
  background-image: url(../images/text_content_bottom_box_01.svg);
}
.content_bottom_box .text>span::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  background-image: url(../images/logo_content_bottom_box.webp);
}
.content_bottom_box .btn_box {
  position: relative;
  flex-wrap: wrap;
}
.content_bottom_box .btn_box .ttl {
  width: 100%;
  margin-top: 60px;
  font-weight: 700;
  color: #fff;
}
.content_bottom_box .btn_box .btn_sns_box {
  display: flex;
  justify-content: center;
  column-gap: 25px;
  margin-top: 30px;
}
.content_bottom_box .btn_box .btn_sns_box .btn_sns {
  display: block;
  width: 80px;
  aspect-ratio: 1/1;
  border-radius: 40px;
  background-color: #fff;
  background-size: contain;
}
.content_bottom_box .btn_box .btn_sns_box .sns_i {
  background-image: url(../images/icon_sns_i.webp);
}
.content_bottom_box .btn_box .btn_sns_box .sns_y {
  background-image: url(../images/icon_sns_y.webp);
}
.content_bottom_box .btn_box .btn_sns_box .sns_x {
  background-image: url(../images/icon_sns_x.webp);
}
@media screen and (max-width: 767px) {
  .content_bottom_box {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  .content_bottom_box::before {
    display: none;
  }
  .content_bottom_box .text::before {
    display: none;
  }
  .content_bottom_box .text>span {
    width: calc(335 / 375 * 100%);
  }
  .content_bottom_box .btn_box .ttl {
    margin-top: 30px;
    font-size: 16px;
    font-weight: 400;
  }
  .content_bottom_box .btn_box .btn_sns_box {
    margin-top: 15px;
  }
  .content_bottom_box .btn_box .btn_sns_box .btn_sns {
    width: 10.6667vw;
  }
}


.swiper_box {
  position: relative;
  width: 380px;
  aspect-ratio: 19/8;
}
.swiper_box01 {
  margin-top: 150px;
  margin-left: auto;
}
.swiper_box02 {
  margin-top: 30px;
  margin-bottom: 150px;
}
.swiper_box .swiper-wrapper {
  transition-timing-function: linear;
}
.swiper_box .swiper-slide img {
  aspect-ratio: 19/8;
}
@media screen and (max-width: 767px) {
  .swiper_box {
    width: calc(265 / 375 * 100%);
  }
  .swiper_box01 {
    margin-top: 100px;
  }
  .swiper_box02 {
    margin-top: 15px;
    margin-bottom: 100px;
  }
}


/* --- animation --- */
._ani_outer {
  position: relative;
}
/* _anime クラスに対して、_start クラスが付与される */

._cas,
._cas_c {
  /* _cas   : _startが付与されるブロックを動かす場合に使用
	   _cas_c : _startが付与されるブロックの下位を動かす場合に使用
	*/
  animation-play-state: paused;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
  animation-delay: 0s;
  animation-duration: 0.8s;
}

._start._cas {
  animation-play-state: running;
}

._start ._cas_c {
  animation-play-state: running;
}

/* add setting */
._ad_04 {
  animation-delay: 0.4s;
}
._ad_06 {
  animation-delay: 0.6s;
}
._ad_08 {
  animation-delay: 0.8s;
}
._ad_10 {
  animation-delay: 1.0s;
}
._ad_12 {
  animation-delay: 1.2s;
}
._ad_14 {
  animation-delay: 1.4s;
}
._ad_24 {
  animation-delay: 2.4s;
}

/* scroll-fade-in */
._a_sfi {
  position: relative;
  opacity: 0;
  top: 10vw;
  animation-name: scroll-fade-in;
}
/* text_underline */
._a_ul {
  background-image: linear-gradient(to bottom,
        rgba(249, 247, 190, 0),
        rgba(249, 247, 190, 0) 90%,
        rgb(249, 247, 190) 90%,
        rgb(249, 247, 190) 100%);
    background-size: 0% 100%;
    background-repeat: no-repeat;
    background-position: left center;
    animation-name: text_underline;
  
    animation-iteration-count: 1;
    animation-play-state: paused;
    animation-fill-mode: forwards;
    animation-duration: 1.4s;
}

/* animation keyframe */
@keyframes scroll-fade-in {
  0% {
    opacity: 0;
    top: 10vw;
  }

  100% {
    opacity: 1;
    top: 0vw;
  }
}

@keyframes text_underline {
  0% {
    background-size: 0% 100%;
  }

  100% {
    background-size: 100% 100%;
  }
}