@charset "UTF-8";
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b, strong {
  font-weight: bolder;
}

code, kbd, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button, input {
  overflow: visible;
}

button, select {
  text-transform: none;
}

[type=button], [type=reset], [type=submit], button {
  -webkit-appearance: button;
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox], [type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}


/*
html--------------------------------------------------------*/
html,
body {
  scroll-behavior: smooth;
}

* {
  margin: 0px;
  padding: 0px;
}

body {
  color: #363636;
  margin: 0;
  padding: 0;
  font-family: "Century Gothic", "Zen Kaku Gothic New", sans-serif !important;
  text-align: center;
  line-height: 1.6;
  position: relative;
  transition: all ease 0.4s;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.is-open {
  position: fixed;
  width: 100%;
  top: var(--scroll-lock-top);
  left: 0;
  right: 0;
}

a {
  color: #8E0450;
  text-decoration: underline;
}

a:visited {
  color: #8E0450;
  text-decoration: underline;
}

a:hover {
  color: #8E0450;
  text-decoration: none;
}

a:active {
  color: #8E0450;
  text-decoration: underline;
}

ul {
  list-style: none;
}

img {
  margin: 0;
  padding: 0;
  vertical-align: top;
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
}

@media screen and (max-width: 767px) {
  a:hover img {
    opacity: 1 !important;
  }
}
.sp {
  display: none;
}

.pc {
  display: block;
}

img {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
}
/* header
===============================================================*/
header {
  z-index: 999;
  width: 100%;
  position: fixed;
  box-sizing: border-box;
  padding: 10px 1.5vw;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
}
header .logo {
  margin-bottom: 2em;
  width: 12.5vw;
}
@media screen and (max-width: 767px) {
  header .logo {
    margin-left: 2vw;
    margin-bottom: 2em;
    width: 31vw;
  }
}
header .logo img {
  width: 100%;
}

.navToggle {
  display: none;
  z-index: 1000;
}
@media screen and (max-width: 767px) {
  .navToggle {
    display: block;
  }
  .navToggle .nabToggle-in {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 15vw;
    background: #EAD0DF;
    aspect-ratio: 1/1;
    border-radius: 100px;
    font-size: 3.4vw;
    margin-right: 2vw;
    border: 1px solid #363636;
    position: relative;
    font-weight: 700;
  }
}
@media screen and (max-width: 767px) and (min-width: 768px) {
  .navToggle .nabToggle-in {
    font-size: 0.8vw;
  }
}
@media screen and (max-width: 767px) {
  .navToggle .nabToggle-in:after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: #9bc9e8;
    border: 1px solid #363636;
    transform-origin: left center;
    transform: translateY(1vw) scaleX(1.05);
    z-index: -1;
  }
  .navToggle em {
    font-style: normal;
  }
}

.gnav {
  text-align: left;
}
@media screen and (max-width: 767px) {
  .gnav {
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
    z-index: -100;
    height: 100dvh;
  }
}
.gnav ul {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  background: #EAD0DF;
  padding: 0.8vw 1.5vw 0.8vw 1.5vw;
  border-radius: 50px;
  border: 1px solid #363636;
  position: relative;
}
@media screen and (max-width: 767px) {
  .gnav ul {
    background: none;
    border: none;
    z-index: -100;
    width: 0;
  }
}
.gnav ul:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: #9bc9e8;
  border: 1px solid #363636;
  transform-origin: left center;
  transform: translateY(0.6vw) scaleX(1.005);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .gnav ul:after {
    display: none;
  }
}
.gnav ul li {
  margin: 0 0.506vw;
  font-size: 4.3vw;
  z-index: 999;
}
@media (min-width: 768px) {
  .gnav ul li {
    font-size: 1.2vw;
  }
}
@media screen and (max-width: 767px) {
  .gnav ul li {
    padding-left: 6vw;
    z-index: -100;
  }
}
.gnav ul li a {
  color: #363636;
  text-decoration: none;
  transition: all ease 0.4s;
  font-weight: 700;
}
.gnav ul li a:hover {
  transform: scale(1.1);
  transition: all ease 0.4s;
}
.gnav .object-01,
.gnav .object-02,
.gnav .object-03,
.gnav .object-04 {
  display: none;
}

@media screen and (max-width: 767px) {
  .gnav {
    opacity: 0;
    visibility: visible;
    z-index: -100;
    border-radius: 0;
    right: 0;
    width: 0;
    transition: all ease 0.4s;
  }
  .gnav ul {
    opacity: 0;
    z-index: -100;
  }
}
.nav-open .gnav {
  opacity: 1;
  visibility: visible;
  transition: all ease 0.4s;
  width: 64vw;
  background: #F2E1EA url(../images/ilife/menu-back.svg) repeat right top/100%;
}
@media screen and (max-width: 767px) {
  .nav-open .gnav ul {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    background: none;
    padding: 56vw 2vw 1.2vw 8vw;
    border-radius: 0;
    border: none;
    position: relative;
    height: 100dvh;
    right: 0;
    box-sizing: border-box;
    width: 100%;
    box-shadow: -1px 0 6px 0 rgba(0, 0, 0, 0.16);
    right: 0;
    opacity: 1;
    transition: all ease 0.4s;
  }
  .nav-open .gnav ul:after {
    display: none;
  }
  .nav-open .gnav ul li {
    margin: 0 0 7.9vw;
  }
  .nav-open .gnav ul li a {
    color: #DD469C;
    text-decoration: none;
    transition: all ease 0.4s;
    font-weight: 700;
  }
  .nav-open .gnav ul li a:hover {
    transform: scale(1.1);
    transition: all ease 0.4s;
  }
  .nav-open .gnav .object-01,
  .nav-open .gnav .object-02,
  .nav-open .gnav .object-03,
  .nav-open .gnav .object-04,
  .nav-open .gnav .object-05,
  .nav-open .gnav .object-06,
  .nav-open .gnav .object-07,
  .nav-open .gnav .object-08 {
    position: absolute;
    display: block;
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.9s ease-out, transform 0.9s ease-out;
    will-change: transform, opacity;
  }
  .nav-open .gnav .object-01,
  .nav-open .gnav .object-02,
  .nav-open .gnav .object-03,
  .nav-open .gnav .object-04 {
    position: absolute;
    display: block;
  }
  .nav-open .gnav .is-visible {
    opacity: 1;
    transform: translateY(0);
  }
  .nav-open .gnav .object-01 {
    right: 29vw;
    top: 5vw;
  }
  .nav-open .gnav .object-01 img {
    width: 30vw;
  }
  .nav-open .gnav .object-02 {
    right: -11vw;
    top: 23vw;
  }
  .nav-open .gnav .object-02 img {
    width: 30vw;
  }
  .nav-open .gnav .object-03 {
    right: 4vw;
    bottom: 42vw;
  }
  .nav-open .gnav .object-03 img {
    width: 28vw;
  }
  .nav-open .gnav .object-04 {
    right: 34vw;
    bottom: 33vw;
  }
  .nav-open .gnav .object-04 img {
    width: 24vw;
  }
}

@keyframes floatA {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-1.2vw);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes floatB {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(1vw, -1.8vw);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes floatC {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-2vw);
  }
  100% {
    transform: translateY(0);
  }
}
@media screen and (max-width: 767px) {
  @keyframes floatA {
    0% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-3.2vw);
    }
    100% {
      transform: translateY(0);
    }
  }
  @keyframes floatB {
    0% {
      transform: translate(0, 0);
    }
    50% {
      transform: translate(2vw, -3.8vw);
    }
    100% {
      transform: translate(0, 0);
    }
  }
  @keyframes floatC {
    0% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-5vw);
    }
    100% {
      transform: translateY(0);
    }
  }
}
/* 発火用クラス */
.float-pattern-1 {
  animation: floatA 9s ease-in-out infinite;
}

.float-pattern-2 {
  animation: floatB 10s ease-in-out infinite;
}

.float-pattern-3 {
  animation: floatC 11s ease-in-out infinite;
}

/* 出現前（まだ見えてない） */
.float-object {
  opacity: 0;
  transform: translateY(50px) scale(0.9);
  will-change: transform, opacity;
}

/* セクションに入ったらシュッと浮き上がる */
@keyframes floatIn {
  0% {
    opacity: 0;
    transform: translateY(50px) scale(0.9);
  }
  60% {
    opacity: 1;
    transform: translateY(-10px) scale(1);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
/* ヘッダー内アニメの初期状態 */
header .logo,
header .gnav,
header .navToggle {
  opacity: 1;
}

/* ロゴ：左 → 右にフェードイン */
header .logo {
  transform: translateX(-15vw);
  transition: opacity 0.6s ease-in, transform 0.6s ease-in;
}

/* メニュー：上 → 下にフェードイン */
header .gnav {
  transform: translateY(-5vw);
  transition: opacity 0.7s ease-out 0.3s, transform 0.7s ease-out 0.3s;
}

/* PC でも navToggle を使っているならここに共通初期値 */
/* SPだけ動かすならアニメ部分はメディアクエリ側に書いてもOK */
header .navToggle {
  transform: translateX(24px);
}

/* 画面に入ったら “通常状態” に遷移（= フェードイン） */
header.is-header-entered .logo,
header.is-header-entered .gnav {
  opacity: 1;
  transform: translate(0, 0);
}

/* navToggle は SP のときだけアニメさせる */
@media (max-width: 767px) {
  header .navToggle {
    opacity: 0;
    transform: translateX(24px) rotate(0deg);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }
  /* 右から左 + 回転しながらイン */
  header.is-navtoggle-entered .navToggle {
    opacity: 1;
    transform: translateX(0) rotate(360deg);
  }
}
/* 出現前：かなり下＆小さめからスタート */
.object-01,
.object-02,
.object-03,
.object-04,
.object-05,
.object-06,
.object-07 {
  opacity: 0;
  transform: translateY(100px) scale(0.15);
  transition: opacity 1s ease-out, transform 1.3s cubic-bezier(0.17, 0.84, 0.44, 1);
  will-change: transform, opacity;
}

/* 画面に入ったらふわっと浮き上がる */
.object-01.is-visible,
.object-02.is-visible,
.object-03.is-visible,
.object-04.is-visible,
.object-05.is-visible,
.object-06.is-visible,
.object-07.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* footer
===============================================================*/
footer {
  background: #DD469C;
}
footer .footer-inner {
  width: 86vw;
  margin: 0 auto;
  padding: 8vw 3vw;
  box-sizing: border-box;
  text-align: left;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  footer .footer-inner {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    padding: 8vw 1vw;
  }
}
footer .footer-inner .f-logo {
  width: 31vw;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-logo {
    width: 38vw;
    margin: 9vw auto;
  }
}
footer .footer-inner .f-navi-wrap {
  width: 70vw;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-navi-wrap {
    width: 90vw;
  }
}
footer .footer-inner .f-navi-wrap dl.f-navi {
  width: 30%;
  margin-bottom: 2.7vw;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-navi-wrap dl.f-navi {
    width: 47%;
    margin-bottom: 5vw;
  }
}
footer .footer-inner .f-navi-wrap dl.f-navi dt {
  color: #fff;
  font-weight: 900;
  font-size: 4.5vw;
  margin-bottom: 0.8em;
}
@media (min-width: 768px) {
  footer .footer-inner .f-navi-wrap dl.f-navi dt {
    font-size: 1.5vw;
  }
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-navi-wrap dl.f-navi dt {
    margin-bottom: 1em;
  }
}
footer .footer-inner .f-navi-wrap dl.f-navi dd {
  margin-bottom: 1.1vw;
  font-weight: 900;
  color: #fff;
  font-size: 3vw;
}
@media (min-width: 768px) {
  footer .footer-inner .f-navi-wrap dl.f-navi dd {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-navi-wrap dl.f-navi dd {
    margin-bottom: 6vw;
  }
}
footer .footer-inner .f-navi-wrap dl.f-navi dd a {
  color: #fff;
  font-weight: normal;
  font-size: 3vw;
  text-decoration: none;
  font-weight: 900;
}
@media (min-width: 768px) {
  footer .footer-inner .f-navi-wrap dl.f-navi dd a {
    font-size: 1vw;
  }
}
footer .footer-inner .f-navi-wrap dl.f-navi dd a.ico-x {
  background: url(../images/ilife/x.svg) no-repeat left 50%/contain;
  padding: 0 0 0 2em;
}
footer .footer-inner .f-navi-wrap dl.f-navi dd a.ico-fb {
  background: url(../images/ilife/fb.svg) no-repeat left 50%/contain;
  padding: 0 0 0 2em;
}
footer .footer-inner .f-app {
  width: 49%;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-app {
    width: 100%;
  }
}
footer .footer-inner .f-app .f-app-list {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-app .f-app-list {
    margin-bottom: 8vw;
  }
}
footer .footer-inner .f-app .f-app-list dt {
  width: 100%;
  color: #fff;
  font-size: 4vw;
  margin-bottom: 1.5em;
  font-weight: 900;
}
@media (min-width: 768px) {
  footer .footer-inner .f-app .f-app-list dt {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-app .f-app-list dt {
    margin-bottom: 0.5em;
  }
}
footer .footer-inner .f-app .f-app-list dd {
  height: 3.4vw;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-app .f-app-list dd {
    height: 13vw;
  }
}
footer .footer-inner .f-app .f-app-list dd img {
  height: 100%;
  width: auto;
  margin-right: 1vw;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-app .f-app-list dd img {
    margin-right: 2vw;
  }
}
footer .footer-inner .f-contact {
  width: 50%;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-contact {
    width: 100%;
  }
}
footer .footer-inner .f-contact .f-contact-list {
  color: #fff;
}
footer .footer-inner .f-contact .f-contact-list dt {
  font-size: 4vw;
  margin-bottom: 1.3em;
  font-weight: 900;
}
@media (min-width: 768px) {
  footer .footer-inner .f-contact .f-contact-list dt {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-contact .f-contact-list dt {
    margin-bottom: 1.4em;
  }
}
footer .footer-inner .f-contact .f-contact-list dd {
  display: inline-block;
  position: relative;
  z-index: 10;
}
footer .footer-inner .f-contact .f-contact-list dd a {
  display: inline-block;
  padding: 1vw 1.5vw;
  z-index: 0;
  font-size: 3vw;
  border-radius: 50px;
  text-decoration: none;
  color: #DD469C;
  font-weight: 700;
  border-radius: 50px;
  border: 1px solid #363636;
  background: #fff;
  text-align: center;
}
@media (min-width: 768px) {
  footer .footer-inner .f-contact .f-contact-list dd a {
    font-size: 0.9vw;
  }
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-contact .f-contact-list dd a {
    padding: 3vw 2vw;
    width: 56vw;
  }
}
footer .footer-inner .f-contact .f-contact-list dd a::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: #9bc9e8;
  border: 1px solid #363636;
  transform-origin: left center;
  transform: translateY(0.3vw) scaleX(1.01);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  footer .footer-inner .f-contact .f-contact-list dd a::after {
    transform: translateY(1.4vw) scaleX(1.015);
  }
}
footer .copyright {
  text-align: center;
  padding: 1.5vw 3vw 0 0;
  text-align: right;
  color: #fff;
  font-size: 4vw;
}
@media (min-width: 768px) {
  footer .copyright {
    font-size: 1vw;
  }
}
footer .gototop {
  position: fixed;
  right: 1.5vw;
  bottom: 2vw;
  z-index: 10000;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
}
footer .sp-footer {
  position: fixed;
  bottom: -100px;
  width: 100%;
  transition: all ease 0.4s;
}

.qr-code {
  position: fixed;
  bottom: 1.5vw;
  right: 1.5vw;
  z-index: 200;
  width: 12.5vw;
}
.qr-code img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .qr-code {
    right: 3vw;
    bottom: calc(3vw + env(safe-area-inset-bottom, 0px));
    width: 32vw;
  }
}
.qr-code:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 200px;
  background: #9bc9e8;
  border: 1px solid #363636;
  transform-origin: left bottom;
  transform: translateY(0.4vw) scaleX(1.04);
  z-index: -1;
}

.qr-code_in {
  position: relative;
  animation: spin 50s linear infinite;
}
.qr-code_in:after {
  background: url(../images/ilife/pc_qr.png) no-repeat center center/100%;
  content: "";
  aspect-ratio: 1/1;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  z-index: 100;
  animation: spin2 50s linear infinite;
}
@media screen and (max-width: 767px) {
  .qr-code_in:after {
    background: url(../images/ilife/sp_dl.png) no-repeat center center/100%;
  }
}

.qr-code {
  opacity: 0;
  transform: translateX(40px) rotate(0deg);
  transition: opacity 1.2s ease-out, transform 1.2s ease-out;
}

/* 画面内に入ってくる状態 */
.qr-code.is-qr-show {
  opacity: 1;
  transform: translateX(0) rotate(720deg);
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}
@keyframes spin2 {
  100% {
    transform: rotate(-360deg);
  }
}
.code {
  position: fixed;
  right: 3.6vw;
  bottom: 3.9vw;
  width: 5vw;
}
@media screen and (max-width: 767px) {
  .code {
    width: 10vw;
    right: 11vw;
    bottom: calc(12.5vw + env(safe-area-inset-bottom, 0px));
  }
}
.code img {
  width: 100%;
  height: auto;
}

/* body
===============================================================*/
main {
  transition: all ease 0.4s;
  background: #DD469C;
  overflow: hidden;
}

.mv {
  margin: 0;
  width: 100%;
  position: relative;
  margin-bottom: 6vw;
}
@media screen and (max-width: 767px) {
  .mv {
    margin-bottom: 0;
  }
}
.mv figure img {
  width: 100%;
}
.mv .campaign-link {
  bottom: 0;
  left: 1.5vw;
  position: absolute;
  background: #EA8DC2;
  border-radius: 8px;
  padding: 0.3vw 0.8vw 0.7vw;
  width: 16vw;
}
@media screen and (max-width: 767px) {
  .mv .campaign-link {
    bottom: 7vw;
    width: 92vw;
    left: 4vw;
    box-sizing: border-box;
    padding: 2vw 3vw 2vw;
  }
}
.mv .campaign-link h3 {
  text-align: left;
  color: #fff;
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  .mv .campaign-link h3 {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .mv .campaign-link h3 {
    margin-bottom: 1vw;
    margin-left: 1.5vw;
  }
}
.mv .campaign-link ul {
  background: #fff;
  border-radius: 7px;
  padding: 0.5vw 0.8vw;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .mv .campaign-link ul {
    padding: 3vw 3vw;
  }
}
.mv .campaign-link ul li {
  font-size: 4vw;
  font-weight: 700;
}
@media (min-width: 768px) {
  .mv .campaign-link ul li {
    font-size: 0.9vw;
  }
}
.mv .campaign-link ul li a {
  color: #DD469C;
  text-decoration: none;
}
.mv .campaign-link ul li:before {
  content: "• ";
  color: #DD469C;
}
.mv .object-01,
.mv .object-02 {
  position: absolute;
}
.mv .object-01 {
  left: 1.2vw;
  bottom: 10vw;
}
@media screen and (max-width: 767px) {
  .mv .object-01 {
    left: 6vw;
    top: 76vw;
  }
}
.mv .object-01 img {
  width: 3vw;
}
@media screen and (max-width: 767px) {
  .mv .object-01 img {
    width: 8vw;
  }
}
.mv .object-02 {
  right: 0.5vw;
  top: 6vw;
}
@media screen and (max-width: 767px) {
  .mv .object-02 {
    right: 20vw;
    top: 5vw;
  }
}
.mv .object-02 img {
  width: 12vw;
}
@media screen and (max-width: 767px) {
  .mv .object-02 img {
    width: 20vw;
  }
}

.point-area {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  border: 1px solid #fff;
  box-sizing: border-box;
  border-width: 1px 0 0 1px;
  padding-right: 7vw;
  position: relative;
  border-bottom: 1px solid #fff;
}
@media screen and (max-width: 767px) {
  .point-area {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: stretch;
    padding-right: 0;
    box-sizing: border-box;
  }
}
.point-area .point-tit {
  font-weight: bold;
  line-height: 1;
  font-size: 10vw;
  background-color: #82BAEA;
  width: 12.3vw;
  display: block;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) {
  .point-area .point-tit {
    font-size: 8vw;
  }
}
@media screen and (max-width: 767px) {
  .point-area .point-tit {
    width: 100vw;
    padding: 8vw 0;
  }
}
.point-area .point-tit span {
  transform: rotate(90deg);
  display: block;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .point-area .point-tit span {
    transform: rotate(0);
    width: 100%;
  }
}
.point-area .point-list {
  width: 90vw;
  box-sizing: border-box;
  border-right: 1px solid #fff;
}
@media screen and (max-width: 767px) {
  .point-area .point-list {
    width: 100vw;
  }
}
.point-area .point-list ul li {
  text-align: right;
  padding: 2.7vw 3vw;
  border-bottom: 1px solid #fff;
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
}
.point-area .point-list ul li .point-01 {
  width: 40vw;
}
@media screen and (max-width: 767px) {
  .point-area .point-list ul li .point-01 {
    width: 67vw;
    padding: 3.2vw 0;
  }
}
.point-area .point-list ul li .point-01 img {
  width: 100%;
}
.point-area .point-list ul li .point-02 {
  width: 53.7vw;
}
@media screen and (max-width: 767px) {
  .point-area .point-list ul li .point-02 {
    width: 60vw;
    padding: 0 0;
  }
}
.point-area .point-list ul li .point-02 img {
  width: 100%;
}
.point-area .point-list ul li .point-03 {
  width: 56.5vw;
}
@media screen and (max-width: 767px) {
  .point-area .point-list ul li .point-03 {
    width: 83vw;
    padding: 3.1vw 0;
  }
}
.point-area .point-list ul li .point-03 img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .point-area .point-list ul li.point-02 span {
    transform: rotate(-15deg) translateY(-8vw) translateX(1vw);
  }
}
.point-area .point-list ul li:last-child {
  margin-bottom: 0;
  border: none;
}
.point-area .point-list ul li span {
  color: #fff;
  display: inline-block;
  position: relative;
  transform: rotate(-15deg) translateY(-4.2vw) translateX(0.4vw);
  font-size: 6vw;
  font-weight: 900;
}
@media (min-width: 768px) {
  .point-area .point-list ul li span {
    font-size: 2.4vw;
  }
}
.point-area .point-list ul li.point-02 {
  padding: 1.6vw 3vw;
}
.point-area .object-01,
.point-area .object-02,
.point-area .object-03,
.point-area .object-04,
.point-area .object-05,
.point-area .object-06 {
  position: absolute;
}
.point-area .object-01 {
  right: 0.1vw;
  top: 4.4vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-01 {
    left: 20vw;
    right: auto;
    top: 55vw;
  }
}
.point-area .object-01 img {
  width: 9.4vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-01 img {
    width: 14vw;
  }
}
.point-area .object-02 {
  right: 13vw;
  top: -11vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-02 {
    right: 7vw;
    top: -56vw;
  }
}
.point-area .object-02 img {
  width: 7vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-02 img {
    width: 16vw;
  }
}
.point-area .object-03 {
  left: 15vw;
  top: -2vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-03 {
    left: 5vw;
    top: -7vw;
  }
}
.point-area .object-03 img {
  width: 12vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-03 img {
    width: 27vw;
  }
}
.point-area .object-04 {
  left: 16vw;
  bottom: -7vw;
}
@media screen and (max-width: 767px) {
  .point-area .object-04 {
    display: none;
  }
}
.point-area .object-04 img {
  width: 12vw;
}
.point-area .object-05,
.point-area .object-06 {
  display: none;
}
@media screen and (max-width: 767px) {
  .point-area .object-05 {
    left: 2vw;
    top: 32vw;
    display: block;
  }
  .point-area .object-05 img {
    width: 18vw;
  }
  .point-area .object-06 {
    left: 2vw;
    bottom: 0vw;
    display: block;
  }
  .point-area .object-06 img {
    width: 7vw;
  }
}

.scroll-01,
.scroll-02,
.scroll-03 {
  overflow: hidden;
  background: #82BAEA;
  padding: 2.5vw 0;
}
@media (max-width: 767px) {
  .scroll-01,
  .scroll-02,
  .scroll-03 {
    border: solid #fff;
    border-width: 2px 0;
  }
}
.scroll-01 img,
.scroll-02 img,
.scroll-03 img {
  display: block;
  height: 7.5vw;
}
@media (max-width: 767px) {
  .scroll-01 img,
  .scroll-02 img,
  .scroll-03 img {
    height: 20vw;
    padding: 5vw 0;
  }
}

.scroll-02 {
  background: #DD469C;
  padding: 2.2vw 0;
}
.scroll-02 .marquee__track {
  animation: marquee2 45s linear infinite;
}

.scroll-03 {
  background: #EA8DC2;
}
.scroll-03 .marquee__track {
  animation: marquee 45s linear infinite;
}

.marquee__track {
  display: flex;
  width: -moz-max-content;
  width: max-content;
  animation: marquee 45s linear infinite;
}

.marquee__set {
  margin: 0 2vw;
}

.marquee__set img {
  display: block;
}

/* アニメーション（右 → 左） */
@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes marquee2 {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0);
  }
}
.slide {
  background: url(../images/ilife/bg-1.svg) repeat top left/100%;
  padding: 8vw 0 2vw;
  position: relative;
}
@media (max-width: 767px) {
  .slide {
    padding: 11.8vw 0 6vw;
    background-size: 200%;
  }
}
.slide .slide-wrap {
  background: url(../images/ilife/card_back.svg) no-repeat top center/90vw;
  position: relative;
}
@media (max-width: 767px) {
  .slide .slide-wrap {
    margin: 32vw 0 3vw;
    background: url(../images/ilife/card_back.svg) no-repeat top center/90vw;
  }
}
@media screen and (max-width: 767px) {
  .slide .slide-wrap {
    background: url(../images/ilife/card_back_sp.svg) no-repeat top center/96vw;
  }
}
.slide .slide-wrap .comment {
  padding-left: 51vw;
  text-align: left;
}
@media (max-width: 767px) {
  .slide .slide-wrap .comment {
    padding-left: 20.5vw;
    transform: translateY(-30vw);
  }
}
.slide .slide-wrap .comment span {
  background: #363636;
  color: #fff;
  display: inline;
  margin: 0.1vw 0;
  font-weight: 700;
  padding: 0.3vw 0.5vw;
  line-height: 2;
  font-size: 4.18vw;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
@media (min-width: 768px) {
  .slide .slide-wrap .comment span {
    font-size: 1.2vw;
  }
}
@media (max-width: 767px) {
  .slide .slide-wrap .comment span {
    -webkit-box-decoration-break: slice;
    box-decoration-break: slice;
  }
}
.slide .slide-wrap .swiper-button-next .swiper-navigation-icon,
.slide .slide-wrap .swiper-button-prev .swiper-navigation-icon {
  display: none;
}
.slide .slide-wrap .swiper-button-next,
.slide .slide-wrap .swiper-button-prev {
  background: url(../images/ilife/arrow-l.svg) no-repeat left center/contain;
  height: 4vw;
  aspect-ratio: 1/1;
  padding: 1.9vw;
  box-sizing: border-box;
  display: inline-block;
  z-index: 100 !important;
}
@media (max-width: 767px) {
  .slide .slide-wrap .swiper-button-next,
  .slide .slide-wrap .swiper-button-prev {
    padding: 4vw;
  }
}
.slide .slide-wrap .swiper-button-next {
  background: url(../images/ilife/arrow-r.svg) no-repeat left center/contain;
  z-index: 100 !important;
}
.slide .slide-wrap .swiper-button-next {
  right: 16vw;
}
.slide .slide-wrap .swiper-button-prev {
  left: 16vw;
}
@media (max-width: 767px) {
  .slide .slide-wrap .swiper {
    transform: translateY(-10vw);
  }
  .slide .slide-wrap .swiper-button-next {
    right: 8vw;
    top: 40%;
  }
  .slide .slide-wrap .swiper-button-prev {
    left: 8vw;
    top: 40%;
  }
}
.slide .slide-wrap .slider-1 {
  padding: 5vw 0 0;
}
@media (max-width: 767px) {
  .slide .slide-wrap .slider-1 {
    padding: 0;
  }
}
.slide .slide-wrap .slider-1 .swiper-wrapper {
  margin: 5vw 0 2vw;
}
.slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide.swiper-slide-prev img, .slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide.swiper-slide-next img {
  transform: rotate(-4deg);
  transition: all ease 0.4s;
}
.slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide.swiper-slide-active img {
  transform: rotate(4deg);
  transition: all ease 0.4s;
}
.slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide figure img {
  transition: all ease 0.4s;
}
.slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide figure figcaption {
  margin-top: 2.5vw;
  background: #DD469C;
  display: inline-block;
  border-radius: 11px;
  border: 1px solid #363636;
  color: #fff;
  padding: 0.53vw 2vw;
  font-weight: 700;
  font-size: 5vw;
  visibility: hidden;
  transition: all ease 0.4s;
  transform: scale(0.2);
  opacity: 0;
  width: 14.2vw;
}
@media (min-width: 768px) {
  .slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide figure figcaption {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 767px) {
  .slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide figure figcaption {
    width: 46vw;
    padding: 1vw 2vw;
    margin-top: 10vw;
  }
}
.slide .slide-wrap .slider-1 .swiper-wrapper .swiper-slide.swiper-slide-active figure figcaption {
  opacity: 1;
  visibility: visible;
  transition: all ease 0.4s;
  transform: scale(1);
}
.slide .object-01,
.slide .object-02,
.slide .object-03,
.slide .object-04 {
  position: absolute;
}
.slide .object-01 {
  left: 7vw;
  top: 2.8vw;
}
@media screen and (max-width: 767px) {
  .slide .object-01 {
    left: 2vw;
    top: -35vw;
  }
}
.slide .object-01 img {
  width: 9.6vw;
}
@media screen and (max-width: 767px) {
  .slide .object-01 img {
    width: 15vw;
  }
}
.slide .object-02 {
  left: 19vw;
  bottom: 12vw;
}
@media screen and (max-width: 767px) {
  .slide .object-02 {
    left: 5vw;
    bottom: 26vw;
  }
}
.slide .object-02 img {
  width: 7vw;
}
@media screen and (max-width: 767px) {
  .slide .object-02 img {
    width: 14vw;
  }
}
.slide .object-03 {
  right: 3vw;
  top: 7vw;
}
@media screen and (max-width: 767px) {
  .slide .object-03 {
    top: 12vw;
  }
}
.slide .object-03 img {
  width: 14vw;
}
@media screen and (max-width: 767px) {
  .slide .object-03 img {
    width: 28vw;
  }
}
.slide .object-04 {
  right: 21vw;
  bottom: 14vw;
}
@media screen and (max-width: 767px) {
  .slide .object-04 {
    right: 5vw;
    bottom: 28vw;
  }
}
.slide .object-04 img {
  width: 3vw;
}
@media screen and (max-width: 767px) {
  .slide .object-04 img {
    width: 8vw;
  }
}

.swiper-thumb {
  width: 55vw;
  margin: 0 auto;
  text-align: center;
  padding: 1vw 0 5vw !important;
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .swiper-thumb {
    width: 96vw;
    padding: 10vw 0 0 !important;
    margin-bottom: 0;
  }
}
.swiper-thumb .swiper-wrapper {
  margin: 0 0.3vw !important;
  padding: 0;
  background: url(../images/ilife/thumb-back.svg) no-repeat center center/100%;
  align-items: center;
}
.swiper-thumb .swiper-slide {
  width: 4vw;
  cursor: pointer;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .swiper-thumb .swiper-slide {
    width: calc(100% / 11);
  }
}
.swiper-thumb .swiper-slide.swiper-slide-thumb-active .thumb-media img {
  width: 11vw;
  transition: all ease 0.4s;
}
@media screen and (max-width: 767px) {
  .swiper-thumb .swiper-slide.swiper-slide-thumb-active .thumb-media img {
    width: 14vw;
  }
}
.swiper-thumb .swiper-slide .thumb-media img {
  width: 3vw;
  transition: all ease 0.4s;
}
@media screen and (max-width: 767px) {
  .swiper-thumb .swiper-slide .thumb-media img {
    width: 6vw;
  }
}

.card-introduction {
  padding: 7.03vw 0 0;
  background: url(../images/ilife/bg-1.svg) repeat top left/100%;
}
@media screen and (max-width: 767px) {
  .card-introduction {
    padding: 16vw 0 0;
    background-size: 200%;
  }
}

.card-intro {
  width: 88vw;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  background: #F2E1EA;
  border-radius: 8vw;
  margin: 0 auto 2.8vw;
  padding: 4.7vw 3.3vw 3vw 3.4vw;
  box-sizing: border-box;
  position: relative;
}
@media (min-width: 768px) {
  .card-intro {
    border-radius: 6.25vw;
  }
}
@media screen and (max-width: 767px) {
  .card-intro {
    padding: 15vw 2.2vw 15vw;
    margin: 0 auto 10vw;
    width: 96vw;
  }
}
.card-intro.int02 {
  background: #F4EFDE;
  margin-bottom: 8vw;
}
@media screen and (max-width: 767px) {
  .card-intro.int02 {
    margin-bottom: 20vw;
    padding: 15vw 7vw 14vw;
  }
}
.card-intro.int02 .intro-right {
  padding-top: 2.5vw;
}
.card-intro.int02 .intro-left {
  padding-top: 2vw;
}
@media screen and (max-width: 767px) {
  .card-intro.int02 .intro-left {
    padding-top: 12vw;
    padding: 13.2vw 0 0 0;
  }
}
.card-intro.int02 .app-join {
  padding-top: 4vw;
}
.card-intro .intro-left {
  flex: 1;
  text-align: left;
  color: #DD469C;
  padding-top: 4.5vw;
}
@media screen and (max-width: 767px) {
  .card-intro .intro-left {
    padding: 5vw 0 0 3vw;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
  }
}
.card-intro .intro-left p {
  font-size: 7vw;
  line-height: 1;
  font-weight: 900;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-end;
}
@media (min-width: 768px) {
  .card-intro .intro-left p {
    font-size: 2.4vw;
  }
}
.card-intro .intro-left p strong {
  font-size: 9vw;
}
@media (min-width: 768px) {
  .card-intro .intro-left p strong {
    font-size: 4vw;
  }
}
@media screen and (max-width: 767px) {
  .card-intro .intro-left p strong {
    margin-left: 0.6em;
  }
}
.card-intro .intro-left p span {
  font-size: 3.6vw;
  display: inline-block;
  margin: 0 0 0.6vw 0.3vw;
}
@media (min-width: 768px) {
  .card-intro .intro-left p span {
    font-size: 1.3vw;
  }
}
.card-intro .intro-left p span.min {
  font-weight: normal;
  font-size: 3vw;
  justify-self: flex-end;
  padding-left: 9.5vw;
  padding-top: 0.4vw;
}
@media (min-width: 768px) {
  .card-intro .intro-left p span.min {
    font-size: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .card-intro .intro-left p span.min {
    padding-left: 50vw;
  }
}
@media screen and (max-width: 767px) {
  .card-intro .intro-left p.sp-noflex {
    width: 100%;
  }
  .card-intro .intro-left p figure {
    width: 90vw;
  }
}
.card-intro .intro-right {
  width: 59.82vw;
}
@media screen and (max-width: 767px) {
  .card-intro .intro-right {
    display: none;
  }
}
.card-intro .app-join {
  width: 100%;
  position: relative;
  padding: 5vw 0 1vw;
}
.card-intro .app-join .app-join-link {
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .card-intro .app-join .app-join-link {
    margin-top: 11vw;
  }
}
.card-intro .app-join a {
  background: #DD469C;
  color: #fff;
  text-decoration: none;
  padding: 1.2vw 3vw;
  border-radius: 50px;
  position: relative;
  display: inline-block;
  border: 1px solid #363636;
  font-weight: 700;
  font-size: 4vw;
  transition: all ease 0.4s;
}
@media (min-width: 768px) {
  .card-intro .app-join a {
    font-size: 1.07vw;
  }
}
@media screen and (max-width: 767px) {
  .card-intro .app-join a {
    padding: 4vw 0;
    width: 76vw;
  }
}
.card-intro .app-join a:hover {
  color: #DD469C;
  background: #fff;
  transition: all ease 0.4s;
}
.card-intro .app-join a:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 200px;
  background: #9bc9e8;
  border: 1px solid #363636;
  transform-origin: left bottom;
  transform: translateY(0.4vw) scaleX(1.01);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .card-intro .app-join a:after {
    transform: translateY(1.4vw) scaleX(1.02);
  }
}
.card-intro .app-join-comment {
  position: absolute;
  left: 0;
  top: 2vw;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .card-intro .app-join-comment {
    position: relative;
    margin-left: 3vw;
  }
}
.card-intro .app-join-comment p {
  margin-bottom: 0.3vw;
}
@media screen and (max-width: 767px) {
  .card-intro .app-join-comment p {
    margin-bottom: 1vw;
  }
}
.card-intro .app-join-comment p span {
  display: inline-block;
  background: #363636;
  color: #fff;
  font-weight: 700;
  padding: 0 0.5vw;
  font-size: 4.2vw;
}
@media (min-width: 768px) {
  .card-intro .app-join-comment p span {
    font-size: 1.2vw;
  }
}
.card-intro .app-join-comment p.lvl2 span {
  font-weight: 400;
  font-size: 2.8vw;
}
@media (min-width: 768px) {
  .card-intro .app-join-comment p.lvl2 span {
    font-size: 0.9vw;
  }
}
.card-intro .object-01,
.card-intro .object-02,
.card-intro .object-03,
.card-intro .object-04,
.card-intro .object-05,
.card-intro .object-06 {
  position: absolute;
}
.card-intro .object-01 {
  right: -2vw;
  top: -2vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-01 {
    right: 2vw;
    top: -2vw;
  }
}
.card-intro .object-01 img {
  width: 9.6vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-01 img {
    width: 14vw;
  }
}
.card-intro .object-02 {
  right: 21vw;
  bottom: 2vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-02 {
    right: 2vw;
    bottom: 17vw;
  }
}
.card-intro .object-02 img {
  width: 6vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-02 img {
    width: 16vw;
  }
}
.card-intro .object-03 {
  left: -2vw;
  bottom: -1vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-03 {
    left: 0vw;
    bottom: 16vw;
  }
}
.card-intro .object-03 img {
  width: 3.3vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-03 img {
    width: 8.3vw;
  }
}
.card-intro .object-04 {
  right: -2.3vw;
  top: 2vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-04 {
    right: 6vw;
    top: -3vw;
  }
}
.card-intro .object-04 img {
  width: 5vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-04 img {
    width: 14vw;
  }
}
.card-intro .object-05 {
  left: 16vw;
  top: 0.3vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-05 {
    left: auto;
    right: 3vw;
    top: 58vw;
  }
}
.card-intro .object-05 img {
  width: 6.7vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-05 img {
    width: 24vw;
  }
}
.card-intro .object-06 {
  left: -1vw;
  bottom: 6vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-06 {
    left: -10vw;
    bottom: -10vw;
  }
}
.card-intro .object-06 img {
  width: 8vw;
}
@media screen and (max-width: 767px) {
  .card-intro .object-06 img {
    width: 28vw;
  }
}

.membership {
  background: url(../images/ilife/bg-2.svg) repeat top left/100%;
  padding: 6.7vw 0 10vw;
  position: relative;
}
@media screen and (max-width: 767px) {
  .membership {
    padding: 14vw 0 18vw;
    background-size: 200%;
  }
}
.membership .swiper-pagination {
  bottom: 2vw !important;
}
@media screen and (max-width: 767px) {
  .membership .swiper-pagination {
    bottom: 6vw !important;
  }
}
.membership .swiper-pagination .swiper-pagination-bullet {
  background: #fff !important;
  opacity: 1;
  margin: 0 0.6vw !important;
}
@media screen and (max-width: 767px) {
  .membership .swiper-pagination .swiper-pagination-bullet {
    margin: 0 1.5vw !important;
  }
}
.membership .swiper-pagination .swiper-pagination-bullet-active {
  background: #DD469C !important;
}
.membership .swiper-button-next .swiper-navigation-icon,
.membership .swiper-button-prev .swiper-navigation-icon {
  display: none;
}
.membership .swiper-button-next,
.membership .swiper-button-prev {
  background: url(../images/ilife/arrow-l.svg) no-repeat left center/contain;
  height: 3vw;
  aspect-ratio: 1/1;
  padding: 2vw;
  box-sizing: border-box;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .membership .swiper-button-next,
  .membership .swiper-button-prev {
    height: 10vw;
    padding: 4vw;
  }
}
.membership .swiper-button-next {
  background: url(../images/ilife/arrow-r.svg) no-repeat left center/contain;
}
.membership .swiper-button-next {
  right: 5vw;
}
.membership .swiper-button-prev {
  left: 5vw;
}
@media screen and (max-width: 767px) {
  .membership .swiper-button-next {
    right: 4vw;
  }
  .membership .swiper-button-prev {
    left: 4vw;
  }
}
.membership h2 {
  width: 96vw;
  margin: 0 auto 2.53vw;
  text-align: left;
  font-size: 15.6vw;
  color: #80B4DB;
  line-height: 0.9;
  letter-spacing: 0.01em;
  position: relative;
  font-weight: 900;
}
@media (min-width: 768px) {
  .membership h2 {
    font-size: 12.3vw;
  }
}
@media screen and (max-width: 767px) {
  .membership h2 {
    line-height: 1;
  }
}
.membership h2 span {
  display: inline-block;
  margin-left: 4vw;
  color: #DD469C;
}
.membership .object-01,
.membership .object-02,
.membership .object-03,
.membership .object-04,
.membership .object-05,
.membership .object-06,
.membership .object-07 {
  position: absolute;
}
.membership .object-01 {
  right: 2vw;
  top: 11vw;
}
@media screen and (max-width: 767px) {
  .membership .object-01 {
    top: 37vw;
  }
}
.membership .object-01 img {
  width: 8vw;
}
@media screen and (max-width: 767px) {
  .membership .object-01 img {
    width: 17vw;
  }
}
.membership .object-02 {
  right: 22vw;
  top: 14vw;
}
@media screen and (max-width: 767px) {
  .membership .object-02 {
    right: 44vw;
    top: 42vw;
  }
}
.membership .object-02 img {
  width: 7.6vw;
}
@media screen and (max-width: 767px) {
  .membership .object-02 img {
    width: 18vw;
  }
}
.membership .object-03 {
  left: 16.5vw;
  top: 15vw;
}
@media screen and (max-width: 767px) {
  .membership .object-03 {
    display: none;
  }
}
.membership .object-03 img {
  width: 3.1vw;
}
@media screen and (max-width: 767px) {
  .membership .object-03 img {
    width: 8vw;
  }
}
.membership .object-04 {
  right: 5vw;
  top: 33vw;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .membership .object-04 {
    right: 7vw;
    top: 70vw;
  }
}
.membership .object-04 img {
  width: 11vw;
}
@media screen and (max-width: 767px) {
  .membership .object-04 img {
    width: 26vw;
  }
}
.membership .object-05 {
  right: 29vw;
  bottom: 13vw;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .membership .object-05 {
    right: 5vw;
    bottom: 13vw;
    z-index: 100;
  }
}
.membership .object-05 img {
  width: 7.5vw;
}
@media screen and (max-width: 767px) {
  .membership .object-05 img {
    width: 18vw;
  }
}
.membership .object-06 {
  left: 21vw;
  bottom: 10vw;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .membership .object-06 {
    left: -1vw;
    bottom: 11vw;
  }
}
.membership .object-06 img {
  width: 13vw;
}
@media screen and (max-width: 767px) {
  .membership .object-06 img {
    width: 22vw;
  }
}
.membership .object-07 {
  left: 7vw;
  top: 34vw;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .membership .object-07 {
    left: 2vw;
    top: 76vw;
  }
}
.membership .object-07 img {
  width: 8.8vw;
}
@media screen and (max-width: 767px) {
  .membership .object-07 img {
    width: 20vw;
  }
}
.membership .member-title {
  position: relative;
}
.membership .member-title .member-title-sub {
  position: absolute;
  left: 60vw;
  top: 15.5vw;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .membership .member-title .member-title-sub {
    position: relative;
    left: 2.5vw;
    top: 0;
    margin-bottom: 7vw;
  }
}
.membership .member-title .member-title-sub dt {
  color: #DD469C;
  font-size: 8vw;
  font-weight: 900;
}
@media (min-width: 768px) {
  .membership .member-title .member-title-sub dt {
    font-size: 2.5vw;
  }
}
.membership .member-title .member-title-sub dd {
  background: #363636;
  color: #fff;
  padding: 0 0.5vw;
  font-weight: bold;
  font-size: 4.2vw;
}
@media (min-width: 768px) {
  .membership .member-title .member-title-sub dd {
    font-size: 1.2vw;
  }
}
@media screen and (max-width: 767px) {
  .membership .member-title .member-title-sub dd {
    display: inline-block;
  }
}
.membership .member-wrap {
  position: relative;
  background: url(../images/ilife/member-back.svg) no-repeat top center/90%;
  padding: 5.2vw 0 8vw;
}
@media screen and (max-width: 767px) {
  .membership .member-wrap {
    background: url(../images/ilife/member-back_sp.svg) no-repeat top center/90%;
    padding: 14vw 0 15vw;
  }
}
.membership .member-wrap .swiper-slide {
  aspect-ratio: 366/486;
}
.membership .member-wrap .swiper-slide.p-01 {
  background: url(../images/ilife/member-back-01.svg) no-repeat top center/100%;
  margin-top: 3vw;
}
@media screen and (max-width: 767px) {
  .membership .member-wrap .swiper-slide.p-01 {
    margin-top: 0;
  }
}
.membership .member-wrap .swiper-slide.p-02 {
  background: url(../images/ilife/member-back-02.svg) no-repeat top center/100%;
}
.membership .member-wrap .swiper-slide figure {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 3vw;
  box-sizing: border-box;
  height: 100%;
}
.membership .member-wrap .swiper-slide figure figcaption {
  color: #DD469C;
  font-weight: 700;
  font-size: 4.5vw;
}
@media (min-width: 768px) {
  .membership .member-wrap .swiper-slide figure figcaption {
    font-size: 1.3vw;
  }
}

.about-nudge {
  background: #80B4DB;
  padding: 5.9vw 0 10vw;
}
@media screen and (max-width: 767px) {
  .about-nudge {
    padding: 19vw 0 22vw;
  }
}

h2 {
  color: #fff;
  margin-bottom: 6.3vw;
  font-size: 12vw;
  letter-spacing: -0.07em;
}
@media (min-width: 768px) {
  h2 {
    font-size: 5.7vw;
  }
}
@media screen and (max-width: 767px) {
  h2 {
    margin-bottom: 10vw;
  }
}
h2 span {
  font-size: 8vw;
}
@media (min-width: 768px) {
  h2 span {
    font-size: 3.8vw;
  }
}
h2.lvl2 {
  font-size: 8vw;
  margin-bottom: 3.3vw;
}
@media (min-width: 768px) {
  h2.lvl2 {
    font-size: 3.5vw;
  }
}
@media screen and (max-width: 767px) {
  h2.lvl2 {
    margin-bottom: 4.4vw;
  }
}

.about-list {
  margin-bottom: 3vw;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about-list {
    padding-top: 4vw;
  }
}
.about-list ul {
  width: 82vw;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
.about-list ul li {
  width: calc(33.3333333333% - 1.3vw);
  aspect-ratio: 366/380;
  margin-bottom: 5vw;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about-list ul li {
    width: 100%;
    margin-bottom: 14vw;
  }
  .about-list ul li.about-01 {
    background: url(../images/ilife/about-back-01_sp.svg) no-repeat top center/100% !important;
    aspect-ratio: 311/247;
  }
  .about-list ul li.about-02 {
    background: url(../images/ilife/about-back-02_sp.svg) no-repeat top center/100% !important;
    aspect-ratio: 311/247;
  }
  .about-list ul li.about-03 {
    background: url(../images/ilife/about-back-03_sp.svg) no-repeat top center/100% !important;
    aspect-ratio: 311/334;
  }
  .about-list ul li.about-04 {
    background: url(../images/ilife/about-back-04_sp.svg) no-repeat top center/100% !important;
    aspect-ratio: 311/334;
  }
  .about-list ul li.about-05 {
    background: url(../images/ilife/about-back-05_sp.svg) no-repeat top center/100% !important;
    aspect-ratio: 311/274;
  }
  .about-list ul li.about-06 {
    background: url(../images/ilife/about-back-06_sp.svg) no-repeat top center/100% !important;
    aspect-ratio: 311/274;
  }
}
.about-list ul li.about-01 .card-heading, .about-list ul li.about-03 .card-heading, .about-list ul li.about-05 .card-heading {
  width: 20vw;
  left: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .about-list ul li.about-01 .card-heading, .about-list ul li.about-03 .card-heading, .about-list ul li.about-05 .card-heading {
    width: 62vw;
  }
}
.about-list ul li.about-02 .card-heading, .about-list ul li.about-04 .card-heading, .about-list ul li.about-06 .card-heading {
  width: 20vw;
  left: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .about-list ul li.about-02 .card-heading, .about-list ul li.about-04 .card-heading, .about-list ul li.about-06 .card-heading {
    width: 62vw;
  }
}
.about-list ul li.about-02 .card-heading h3:after, .about-list ul li.about-04 .card-heading h3:after, .about-list ul li.about-06 .card-heading h3:after {
  background: #EA8DC2;
}
.about-list ul li.about-06 .card-heading {
  width: 24vw;
  margin-right: 1.5vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li.about-06 .card-heading {
    width: 70vw;
    margin: auto;
  }
}
.about-list ul li .card-heading {
  position: absolute;
  margin: auto;
  z-index: 10;
  text-align: center;
  transform: translateY(-2vw);
}
@media screen and (max-width: 767px) {
  .about-list ul li .card-heading {
    transform: translateY(-7vw);
  }
}
.about-list ul li .card-heading h3 {
  text-align: center;
  font-size: 5vw;
  padding: 0.5vw 0.2vw;
  background: #fff;
  color: #DD469C;
  border-radius: 10px;
  border: 1px solid #363636;
}
@media (min-width: 768px) {
  .about-list ul li .card-heading h3 {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list ul li .card-heading h3 {
    padding: 2.5vw 0.2vw;
  }
}
.about-list ul li .card-heading h3:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: #9bc9e8;
  border: 1px solid #363636;
  transform-origin: left center;
  transform: translateY(0.4vw) scaleX(1.015);
  z-index: -1;
}
.about-list ul li.list-a {
  background: url(../images/ilife/about-back-01.svg) no-repeat top center/100%;
}
@media screen and (max-width: 767px) {
  .about-list ul li.list-a {
    background: none;
  }
}
.about-list ul li.list-b {
  background: url(../images/ilife/about-back-02.svg) no-repeat top center/100%;
}
@media screen and (max-width: 767px) {
  .about-list ul li.list-b {
    background: none;
  }
}
.about-list ul li figure {
  padding: 0 2vw 1vw 1.6vw;
}
.about-list ul li figure.about-01 {
  padding: 6vw 3vw 1vw 2.4vw;
}
.about-list ul li figure.about-01 img {
  margin-bottom: 1vw;
  width: 23.5vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li figure.about-01 img {
    width: 54vw;
    margin-top: 5vw;
  }
}
.about-list ul li figure.about-02 {
  padding: 2.5vw 4.8vw 1vw 4.4vw;
}
.about-list ul li figure.about-02 img {
  margin-bottom: 1vw;
  width: 23.5vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li figure.about-02 img {
    width: 34vw;
    margin-top: 5vw;
    margin-bottom: 5vw;
  }
}
.about-list ul li figure.about-03 {
  padding: 2.6vw 1.9vw 1vw 1.3vw;
}
.about-list ul li figure.about-03 img {
  margin-bottom: 0.9vw;
  width: 19vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li figure.about-03 img {
    width: 52vw;
    margin-top: 5vw;
  }
}
.about-list ul li figure.about-04 {
  padding: 5vw 2.4vw 1vw 2vw;
}
.about-list ul li figure.about-04 img {
  margin-bottom: 1.4vw;
  width: 18vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li figure.about-04 img {
    width: 50vw;
    margin-top: 5vw;
    margin-bottom: 6vw;
  }
}
.about-list ul li figure.about-05 {
  padding: 5.3vw 4.4vw 1vw 3vw;
}
.about-list ul li figure.about-05 img {
  margin-bottom: 3.1vw;
  width: 11.5vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li figure.about-05 img {
    width: 36vw;
    margin-top: 5vw;
  }
}
.about-list ul li figure.about-06 {
  padding: 4vw 1.5vw 1.5vw 1vw;
}
.about-list ul li figure.about-06 img {
  margin-bottom: 2.8vw;
  width: 13.5vw;
}
@media screen and (max-width: 767px) {
  .about-list ul li figure.about-06 img {
    width: 36.5vw;
    margin-top: 5vw;
    margin-bottom: 5vw;
  }
}
.about-list ul li figure figcaption {
  font-size: 4.8vw;
  color: #DD469C;
  font-weight: bold;
  list-style: 1.35;
}
@media (min-width: 768px) {
  .about-list ul li figure figcaption {
    font-size: 1.15vw;
  }
}
@media screen and (max-width: 767px) {
  .about-list ul li figure figcaption {
    line-height: 1.4;
  }
}
.about-list ul li figure figcaption a {
  color: #DD469C;
}
.about-list ul li figure figcaption span {
  font-size: 3.6vw;
}
@media (min-width: 768px) {
  .about-list ul li figure figcaption span {
    font-size: 0.9vw;
  }
}
.about-list .object-01,
.about-list .object-02,
.about-list .object-03,
.about-list .object-04,
.about-list .object-05,
.about-list .object-06 {
  position: absolute;
}
.about-list .object-01 {
  left: 5.5vw;
  top: -12vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-01 {
    left: 0vw;
    top: -12vw;
  }
}
.about-list .object-01 img {
  width: 4vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-01 img {
    width: 12vw;
  }
}
.about-list .object-02 {
  right: 6vw;
  top: -15vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-02 {
    right: 1vw;
    top: -36vw;
  }
}
.about-list .object-02 img {
  width: 10vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-02 img {
    width: 20vw;
  }
}
.about-list .object-03 {
  left: 3vw;
  top: 21vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-03 {
    left: -3vw;
    top: 120vw;
  }
}
.about-list .object-03 img {
  width: 8vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-03 img {
    width: 22vw;
  }
}
.about-list .object-04 {
  right: 6vw;
  bottom: 15vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-04 {
    right: -16vw;
    bottom: 155vw;
  }
}
.about-list .object-04 img {
  width: 8vw;
}
@media screen and (max-width: 767px) {
  .about-list .object-04 img {
    width: 32vw;
  }
}

.campaign {
  background: #80B4DB;
  padding: 2.8vw 0 4vw;
  position: relative;
  background: url(../images/ilife/bg-3.svg) repeat top left/100%;
}
@media screen and (max-width: 767px) {
  .campaign {
    padding: 17vw 0 8.5vw;
    background-size: 200%;
  }
}
.campaign h2 {
  width: 96vw;
  margin: 0 auto;
  text-align: left;
  font-size: 16vw;
  color: #EA8DC2;
  font-weight: 900;
  letter-spacing: 0.01em;
  line-height: 1.54;
}
@media (min-width: 768px) {
  .campaign h2 {
    font-size: 11.1vw;
  }
}
@media screen and (max-width: 767px) {
  .campaign h2 {
    line-height: 1;
    margin-bottom: 5vw;
    letter-spacing: 0;
  }
}
.campaign h2 span {
  display: inline-block;
  margin-left: 4.4vw;
  color: #DD469C;
  font-size: 8vw;
}
@media (min-width: 768px) {
  .campaign h2 span {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 767px) {
  .campaign h2 span {
    line-height: 1;
    margin-left: 0;
    font-weight: 900;
    transform: translateY(-5vw);
  }
}
.campaign .object-01,
.campaign .object-02,
.campaign .object-03,
.campaign .object-04,
.campaign .object-05,
.campaign .object-06 {
  position: absolute;
}
.campaign .object-01 {
  right: 5vw;
  top: 7vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-01 {
    right: 1vw;
    top: 2vw;
  }
}
.campaign .object-01 img {
  width: 11vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-01 img {
    width: 18vw;
  }
}
.campaign .object-02 {
  left: 15vw;
  top: -2vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-02 {
    left: auto;
    right: 2vw;
    top: -14vw;
  }
}
.campaign .object-02 img {
  width: 8.2vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-02 img {
    width: 22vw;
  }
}
.campaign .object-03 {
  left: 3vw;
  bottom: 3vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-03 {
    left: -6vw;
    bottom: -11vw;
  }
}
.campaign .object-03 img {
  width: 9vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-03 img {
    width: 21vw;
  }
}
.campaign .object-04 {
  left: 10.5vw;
  top: -0.5vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-04 {
    left: 2vw;
    top: 9vw;
  }
}
.campaign .object-04 img {
  width: 3vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-04 img {
    width: 10vw;
  }
}
.campaign .object-05 {
  left: 1vw;
  bottom: -1.5vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-05 {
    left: -6vw;
    bottom: -10.5vw;
  }
}
.campaign .object-05 img {
  width: 9vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-05 img {
    width: 20vw;
  }
}
.campaign .object-06 {
  right: -5vw;
  top: 3.4vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-06 {
    right: -3.4vw;
    top: 35vw;
  }
}
.campaign .object-06 img {
  width: 10vw;
}
@media screen and (max-width: 767px) {
  .campaign .object-06 img {
    width: 23vw;
  }
}

.campaign-list {
  width: 86vw;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .campaign-list {
    width: 94vw;
  }
}
.campaign-list li {
  background: #F2E1EA;
  border-radius: 8vw;
  position: relative;
  padding: 3.5vw 3vw;
  margin-bottom: 2.5vw;
}
@media (min-width: 768px) {
  .campaign-list li {
    border-radius: 3.90625vw;
  }
}
@media screen and (max-width: 767px) {
  .campaign-list li {
    padding: 13vw 3vw;
    margin-bottom: 10vw;
  }
}
.campaign-list li h3 {
  font-size: 7vw;
  color: #DD469C;
  margin-bottom: 0.2em;
}
@media (min-width: 768px) {
  .campaign-list li h3 {
    font-size: 2.4vw;
  }
}
@media screen and (max-width: 767px) {
  .campaign-list li h3 {
    line-height: 1.5;
  }
}
.campaign-list li p {
  margin: 0 auto 0.7em;
  display: inline-block;
  font-size: 6.6vw;
  letter-spacing: 0.03em;
  padding: 0 1vw;
  font-weight: 700;
}
@media (min-width: 768px) {
  .campaign-list li p {
    font-size: 2vw;
  }
}
@media (max-width: 767px) {
  .campaign-list li p {
    padding: 0.3vw 1.3vw;
  }
}
.campaign-list li p span {
  background: #DD469C;
  color: #fff;
  padding: 0 0.5vw;
}
@media (max-width: 767px) {
  .campaign-list li p span .comment span {
    -webkit-box-decoration-break: slice;
    box-decoration-break: slice;
  }
}
.campaign-list li dl {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  font-size: 3.8vw;
  color: #DD469C;
  font-weight: 700;
}
@media (min-width: 768px) {
  .campaign-list li dl {
    font-size: 1.14vw;
  }
}
@media screen and (max-width: 767px) {
  .campaign-list li dl {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    margin: 0 0 0 0.8em;
  }
}
.campaign-list li dl dt {
  margin-right: 1em;
  font-weight: 600;
}
.campaign-list li dl dd {
  font-weight: 500;
  text-align: left;
}
.campaign-list li .caution {
  position: absolute;
  font-size: 3.6vw;
  bottom: 14px;
  right: 3vw;
  color: #DD469C;
  font-weight: 500;
}
@media (min-width: 768px) {
  .campaign-list li .caution {
    font-size: 0.9vw;
  }
}
@media screen and (max-width: 767px) {
  .campaign-list li .caution {
    position: relative;
    display: block;
    left: 2vw;
    padding-top: 0.5vw;
    text-align: left;
    bottom: auto;
    line-height: 1.2;
  }
}
.campaign-list li figure {
  position: absolute;
  right: 0;
  top: 0;
}
@media screen and (max-width: 767px) {
  .campaign-list li figure {
    position: relative;
    left: auto;
    right: auto;
  }
}
.campaign-list li figure.campaign-img-01 {
  width: 19vw;
  top: 1vw;
  right: 3vw;
}
@media screen and (max-width: 767px) {
  .campaign-list li figure.campaign-img-01 {
    width: 53vw;
    left: 6vw;
    right: 0;
    top: -1vw;
    margin: auto auto 5vw;
  }
}
.campaign-list li figure.campaign-img-02 {
  width: 13vw;
  top: 4vw;
  right: 6vw;
}
@media screen and (max-width: 767px) {
  .campaign-list li figure.campaign-img-02 {
    width: 38vw;
    left: 0;
    right: 0;
    top: -1vw;
    margin: auto auto 0;
  }
}

.app-join-wrap {
  width: 86vw;
  margin: auto;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 8vw;
  background: #F4EFDE;
  padding: 5vw 6vw 5vw;
  box-sizing: border-box;
  position: relative;
  border-radius: 8vw;
}
@media (min-width: 768px) {
  .app-join-wrap {
    border-radius: 6.25vw;
  }
}
@media screen and (max-width: 767px) {
  .app-join-wrap {
    width: 94vw;
    margin-bottom: 14vw;
    padding: 12vw 0vw 20vw 5vw;
  }
}
.app-join-wrap .swiper-pagination {
  bottom: 1vw !important;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .swiper-pagination {
    top: 73vw !important;
  }
}
.app-join-wrap .swiper-pagination .swiper-pagination-bullet {
  background: #fff !important;
  margin: 0 0.6vw;
  opacity: 1 !important;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .swiper-pagination .swiper-pagination-bullet {
    margin: 0 2vw;
  }
}
.app-join-wrap .swiper-pagination .swiper-pagination-bullet-active {
  background: #DD469C !important;
}
.app-join-wrap .slider-2 {
  position: relative;
}
.app-join-wrap .slider-2 .swiper-slide {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .slider-2 .swiper-slide {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
  }
}
.app-join-wrap .slider-2 .swiper-slide figure {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .slider-2 .swiper-slide figure {
    width: 100%;
  }
}
.app-join-wrap .slider-2 .swiper-slide figure img {
  width: 20vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .slider-2 .swiper-slide figure img {
    width: 33vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method {
  width: 48%;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method {
    width: 100%;
    padding-bottom: 20vw;
    box-sizing: border-box;
    padding: 4px;
    margin-bottom: 20vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method h3 {
  line-height: 1.5;
  font-weight: 800;
  color: #DD469C;
  margin-top: -0.8vw;
  font-size: 7vw;
  letter-spacing: -0.07em;
  margin-bottom: 2.1vw;
}
@media (min-width: 768px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method h3 {
    font-size: 3vw;
  }
}
@media (max-width: 767px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method h3 {
    padding-top: 11vw;
    padding-bottom: 3vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method h3 span {
  letter-spacing: 0;
  font-size: 5vw;
}
@media (min-width: 768px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method h3 span {
    font-size: 1.5vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method h3 strong {
  letter-spacing: 0;
  display: inline-block;
  margin-left: 0.5vw;
  font-size: 8vw;
}
@media (min-width: 768px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method h3 strong {
    font-size: 3.4vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method .app-txt span {
  background: #363636;
  color: #fff;
  display: inline;
  font-weight: 500;
  margin: 0 0 0.7vw;
  padding: 0.2vw 0.35vw;
  font-size: 3.3vw;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  line-height: 2.4;
}
@media (min-width: 768px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method .app-txt span {
    font-size: 1.2vw;
  }
}
@media (max-width: 767px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method .app-txt span {
    -webkit-box-decoration-break: slice;
    box-decoration-break: slice;
    line-height: 1.8;
    padding: 0.5vw 0.8vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method .app-txt span.lvl2 {
  list-style: 1;
  font-size: 2.8vw;
}
@media (min-width: 768px) {
  .app-join-wrap .slider-2 .swiper-slide .app-in-method .app-txt span.lvl2 {
    font-size: 0.96vw;
  }
}
.app-join-wrap .slider-2 .swiper-slide .app-in-method .app-txt span a {
  color: #fff;
}
.app-join-wrap .app-btn {
  position: absolute;
  bottom: 7vw;
  left: 44vw;
  z-index: 10;
}
@media (max-width: 767px) {
  .app-join-wrap .app-btn {
    left: 6vw;
    bottom: 14vw;
    z-index: 100;
  }
}
.app-join-wrap .app-btn a {
  display: inline-block;
  padding: 1.3vw 1vw;
  z-index: 0;
  font-size: 4vw;
  border-radius: 50px;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  border-radius: 50px;
  border: 1px solid #363636;
  background: #DD469C;
  width: 20.5vw;
  transition: all ease 0.4s;
}
@media (min-width: 768px) {
  .app-join-wrap .app-btn a {
    font-size: 1.1vw;
  }
}
@media screen and (max-width: 767px) {
  .app-join-wrap .app-btn a {
    padding: 4vw 2vw;
    width: 74vw;
  }
}
.app-join-wrap .app-btn a:hover {
  color: #DD469C;
  background: #fff;
  transition: all ease 0.4s;
}
.app-join-wrap .app-btn a::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: #9bc9e8;
  border: 1px solid #363636;
  transform-origin: left center;
  transform: translateY(0.3vw) scaleX(1.01);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .app-btn a::after {
    transform: translateY(1.4vw) scaleX(1.015);
  }
}
.app-join-wrap .object-01,
.app-join-wrap .object-02,
.app-join-wrap .object-03,
.app-join-wrap .object-04,
.app-join-wrap .object-05,
.app-join-wrap .object-06 {
  position: absolute;
  z-index: 10;
}
.app-join-wrap .object-01 {
  left: 13.5vw;
  top: -13vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-01 {
    left: -5vw;
    top: -46vw;
  }
}
.app-join-wrap .object-01 img {
  width: 9vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-01 img {
    width: 20vw;
  }
}
.app-join-wrap .object-02 {
  right: 1.3vw;
  top: -3.5vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-02 {
    right: 3vw;
  }
}
.app-join-wrap .object-02 img {
  width: 10vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-02 img {
    width: 18vw;
  }
}
.app-join-wrap .object-03 {
  right: -3vw;
  top: 7vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-03 {
    top: 14vw;
    right: -5vw;
  }
}
.app-join-wrap .object-03 img {
  width: 9vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-03 img {
    width: 16vw;
  }
}
.app-join-wrap .object-04 {
  left: -2vw;
  bottom: 3vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-04 {
    left: -7vw;
    bottom: auto;
    top: 50vw;
  }
}
.app-join-wrap .object-04 img {
  width: 12vw;
}
@media screen and (max-width: 767px) {
  .app-join-wrap .object-04 img {
    width: 25vw;
  }
}

.hensai-wrap {
  width: 86vw;
  position: relative;
  margin: auto;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .hensai-wrap {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    width: 94vw;
    margin-top: 9vw;
  }
}
.hensai-wrap .hensai {
  background: #fff;
  width: 48.5%;
  aspect-ratio: 1/1.07;
  padding: 3.8vw 4vw 1.2vw;
  box-sizing: border-box;
  border-radius: 8vw;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai {
    border-radius: 6.25vw;
  }
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai {
    width: 100%;
    padding: 10vw 4vw 11.5vw;
    margin-bottom: 6vw;
  }
}
.hensai-wrap .hensai h3 {
  color: #DD469C;
  font-size: 7vw;
  font-weight: 800;
  margin-bottom: 0.5vw;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai h3 {
    font-size: 2.8vw;
  }
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai h3 {
    margin-bottom: 4vw;
  }
}
.hensai-wrap .hensai h3 span {
  display: block;
  list-style: 1.2;
  font-size: 4vw;
  margin-bottom: 0.5vw;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai h3 span {
    font-size: 1.3vw;
  }
}
.hensai-wrap .hensai h3 strong {
  font-family: "Zen Kaku Gothic New", sans-serif !important;
  font-size: 8vw;
  line-height: 1;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai h3 strong {
    font-size: 3.5vw;
  }
}
.hensai-wrap .hensai .hensai-in-wrap {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  margin: 0 1vw;
}
.hensai-wrap .hensai figure {
  width: 50%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai figure {
    width: 100%;
  }
}
.hensai-wrap .hensai figure.hensai-img-1 .img, .hensai-wrap .hensai figure.hensai-img-2 .img, .hensai-wrap .hensai figure.hensai-img-3 .img {
  height: 16vw;
  text-align: center;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  margin-bottom: 0.9vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai figure.hensai-img-1 .img, .hensai-wrap .hensai figure.hensai-img-2 .img, .hensai-wrap .hensai figure.hensai-img-3 .img {
    height: 45vw;
  }
}
.hensai-wrap .hensai figure.hensai-img-1 img, .hensai-wrap .hensai figure.hensai-img-2 img, .hensai-wrap .hensai figure.hensai-img-3 img {
  width: 15vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai figure.hensai-img-1 img, .hensai-wrap .hensai figure.hensai-img-2 img, .hensai-wrap .hensai figure.hensai-img-3 img {
    width: 45vw;
    padding-top: 7vw;
    padding-bottom: 5.5vw;
  }
}
.hensai-wrap .hensai figure.hensai-img-1 figcaption, .hensai-wrap .hensai figure.hensai-img-2 figcaption, .hensai-wrap .hensai figure.hensai-img-3 figcaption {
  color: #DD469C;
  font-size: 5vw;
  font-weight: 700;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai figure.hensai-img-1 figcaption, .hensai-wrap .hensai figure.hensai-img-2 figcaption, .hensai-wrap .hensai figure.hensai-img-3 figcaption {
    font-size: 1.38vw;
  }
}
.hensai-wrap .hensai figure.hensai-img-1 figcaption span, .hensai-wrap .hensai figure.hensai-img-2 figcaption span, .hensai-wrap .hensai figure.hensai-img-3 figcaption span {
  margin-top: 0.5vw;
  font-size: 4vw;
  display: block;
  list-style: 1.4;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai figure.hensai-img-1 figcaption span, .hensai-wrap .hensai figure.hensai-img-2 figcaption span, .hensai-wrap .hensai figure.hensai-img-3 figcaption span {
    font-size: 1.06vw;
  }
}
.hensai-wrap .hensai figure.hensai-img-2 img {
  width: 13.5vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai figure.hensai-img-2 img {
    width: 35vw;
  }
}
.hensai-wrap .hensai figure.hensai-img-3 img {
  height: 100%;
  width: auto;
}
.hensai-wrap .hensai .hensai-bottom {
  height: 8vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .hensai .hensai-bottom {
    height: auto;
    margin-top: 3.5vw;
    margin-bottom: 2vw;
  }
}
.hensai-wrap .hensai .hensai-bottom p {
  background: #363636;
  color: #fff;
  margin: 0.4vw 0;
  padding: 0 0.4vw;
  font-weight: 700;
  font-size: 4vw;
}
@media (min-width: 768px) {
  .hensai-wrap .hensai .hensai-bottom p {
    font-size: 1.2vw;
  }
}
.hensai-wrap .object-01,
.hensai-wrap .object-02 {
  position: absolute;
}
.hensai-wrap .object-01 {
  right: 2vw;
  top: -2vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .object-01 {
    top: -6vw;
  }
}
.hensai-wrap .object-01 img {
  width: 4vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .object-01 img {
    width: 11vw;
  }
}
.hensai-wrap .object-02 {
  left: 1.3vw;
  bottom: -3.2vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .object-02 {
    bottom: 0;
    top: -48vw;
    left: -5vw;
  }
}
.hensai-wrap .object-02 img {
  width: 10.5vw;
}
@media screen and (max-width: 767px) {
  .hensai-wrap .object-02 img {
    width: 22vw;
  }
}/*# sourceMappingURL=styles.css.map */