@import 'https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600;700;800&display=swap';
/* https://piccalil.li/blog/a-modern-css-reset/ */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  display: block;
  max-width: 100%;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
html {
  scroll-behavior: smooth;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  font-weight: 400;
  font-optical-sizing: auto;
  color: #000;
  background: #e5f7fe;
}
body.-sugi {
  background: #e7f3d8;
}
body.-tsuruha {
  background: #fffdde;
}
body.-whappy {
  background: #ffe1f1;
}

* {
  padding: 0;
  margin: 0;
  font-size: 16px;
  line-height: 1.3;
}

main {
  display: block;
}

ul li {
  list-style: none;
}

img {
  display: inline;
}

a {
  transition: all 0.3s ease;
}

.onlyPc {
  display: block;
}
.onlyPc.--inline {
  display: inline;
}
.onlyPc.--flex {
  display: flex;
}
@media screen and (max-width: 767px) {
  .onlyPc {
    display: none;
  }
  .onlyPc.--inline {
    display: none;
  }
  .onlyPc.--flex {
    display: none;
  }
}

.onlySp {
  display: none;
}
@media screen and (max-width: 767px) {
  .onlySp {
    display: block;
  }
  .onlySp.--inline {
    display: inline;
  }
  .onlySp.--flex {
    display: flex;
  }
}

.pcHeader__left {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  display: block;
  inline-size: calc(50% - 187.5px);
  block-size: 100vh;
}
@media screen and (max-width: 767px) {
  .pcHeader__left {
    display: none;
  }
}
.pcHeader__left::before {
  position: absolute;
  top: 205px;
  right: 0;
  width: 100%;
  max-width: 505px;
  height: 687px;
  max-height: 687px;
  content: "";
  background-repeat: no-repeat;
  background-size: 100% auto;
}
@media screen and (min-width: 1280px) {
  .pcHeader__left::before {
    width: 505px;
  }
}
.pcHeader__nav {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 27.1875vw;
  padding: 2.5vw 2.5vw 3.125vw 2.5vw;
  margin: 0 10px;
  border-radius: 16px;
}
@media screen and (min-width: 1280px) {
  .pcHeader__nav {
    max-width: 348px;
    padding: 32px 32px 40px;
  }
}
.pcHeader__leftContents {
  position: absolute;
  top: 210px;
  right: 0;
  display: flex;
  flex-direction: column;
  gap: 67px;
  align-items: flex-end;
  width: 100%;
  padding: 1.25vw 0;
  background: rgba(255, 255, 255, 0.5);
}
.pcHeader__leftContents.-tsuruha {
  background: none;
}
.pcHeader__leftContents.-tsuruha .pcHeader__nav {
  background: #fff;
}
.pcHeader__leftContents.-whappy {
  background: none;
}
.pcHeader__leftContents.-whappy .pcHeader__nav {
  background: #fff;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftContents {
    padding: 33px 34px 16px;
  }
}
@media (width <= 1280px) and (width >= 768px) {
  .pcHeader__leftContents {
    align-items: center;
  }
}
.pcHeader__leftLogo {
  position: absolute;
  top: 45px;
  right: 40px;
  width: 100%;
  max-width: 330px;
  margin-inline: auto;
}
@media (width <= 1150px) and (width >= 768px) {
  .pcHeader__leftLogo {
    width: 70%;
  }
}
.pcHeader__leftNavTitle {
  width: 5.625vw;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftNavTitle {
    width: 72px;
  }
}
.pcHeader__leftNavText {
  display: block;
  width: 22.1875vw;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftNavText {
    width: 284px;
  }
}
@media (hover: hover) {
  .pcHeader__leftNavText:hover {
    opacity: 0.5;
  }
}
.pcHeader__leftNavLink {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: auto;
  padding: 1.5625vw 0.625vw 1.40625vw;
  border-bottom: 3px dotted #1d2088;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftNavLink {
    gap: 16px;
    width: 284px;
    padding: 20px 8px 18px;
  }
}
.pcHeader__leftNavLink:hover {
  opacity: 0.5;
}
.pcHeader__leftNavLink svg {
  position: absolute;
  top: 50%;
  right: 0;
  display: flex;
  width: 1.40625vw;
  height: 1.40625vw;
  transform: translateY(-50%);
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftNavLink svg {
    position: relative;
    top: unset;
    right: unset;
    width: 18px;
    height: 18px;
    transform: unset;
  }
}
.pcHeader__leftNavLinkText {
  width: 18.28vw;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftNavLinkText {
    width: 234px;
  }
}
.pcHeader__leftIllust {
  position: absolute;
  top: -3.125vw;
  left: 1.5625vw;
  width: 7.34375vw;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftIllust {
    top: -40px;
    left: -12px;
    width: 94px;
  }
}
.pcHeader__leftIllust.-whappy {
  top: -5.46875vw;
  left: 5.859375vw;
  width: 13.59375vw;
}
@media screen and (min-width: 1280px) {
  .pcHeader__leftIllust.-whappy {
    top: -70px;
    left: 90px;
    width: 174px;
  }
}
.pcHeader__right {
  position: fixed;
  top: 0;
  right: -78px;
  z-index: 999;
  display: block;
  inline-size: calc(50% - 187.5px + 78px);
  block-size: 100vh;
}
@media screen and (max-width: 767px) {
  .pcHeader__right {
    display: none;
  }
}
.pcHeader__rightContents {
  position: absolute;
  top: 210px;
  right: 0;
  gap: 67px;
  width: 100%;
  padding: 5.3125vw 2.65625vw 5.3125vw 3.515625vw;
  background: rgba(255, 255, 255, 0.5);
}
.pcHeader__rightContents.-tsuruha {
  display: none;
}
.pcHeader__rightContents.-whappy {
  display: none;
}
@media screen and (min-width: 1280px) {
  .pcHeader__rightContents {
    padding: 68px 34px 68px 45px;
  }
}
.pcHeader__rightContents .pcHeader__rightIllust {
  width: 27.32vw;
  height: 25.31vw;
  aspect-ratio: 349.68/324;
}
@media screen and (min-width: 1280px) {
  .pcHeader__rightContents .pcHeader__rightIllust {
    width: 349.685px;
    height: 324px;
  }
}
.pcHeader__rightContents .pcHeader__rightIllust.-sugi {
  width: 19.91vw;
  height: 25vw;
  aspect-ratio: 254.84/320;
}
@media screen and (min-width: 1280px) {
  .pcHeader__rightContents .pcHeader__rightIllust.-sugi {
    width: 254.843px;
    height: 320px;
  }
}
.pcHeader__rightContents .pcHeader__rightIllust.-tsuruha {
  width: unset;
  height: unset;
}

.footer {
  position: relative;
  z-index: 999;
  width: 375px;
  margin: 0 auto;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .footer {
    width: 100%;
  }
}

.campaignPagetop {
  position: fixed;
  right: 30px;
  bottom: 30px;
  display: flex;
  visibility: hidden;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  aspect-ratio: 1/1;
  background: #fff;
  border: 4px solid #ef4a9b;
  border-radius: 50px;
  box-shadow: 0 4px 4px 0 rgba(0, 64, 152, 0.2);
  opacity: 0;
  transition: all 200ms;
}
.campaignPagetop:hover {
  background: #fff1f8;
}
@media screen and (max-width: 767px) {
  .campaignPagetop {
    right: 13px;
    bottom: 15px;
    width: 55px;
    height: 55px;
    padding: unset;
  }
}
.campaignPagetop.-whappy {
  border-color: #e5007f;
}
.campaignPagetop--show {
  visibility: visible;
  opacity: 1;
}
.campaignPagetop__item {
  display: block;
  inline-size: unset;
  width: 45px;
}
@media screen and (max-width: 767px) {
  .campaignPagetop__item {
    width: 25px;
  }
}

.credit {
  padding-top: 40px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  text-align: center;
}

.cvBtn {
  position: relative;
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 72px;
  padding-bottom: 3px;
  font-size: 24px;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.02em;
  text-decoration: none;
  cursor: pointer;
  background-color: #e95377;
  border-radius: 40px;
  box-shadow: 0 5px 5px 0 rgba(157, 25, 57, 0.251);
}
@media (hover: hover) {
  .cvBtn:hover {
    background-color: #e6e6e6;
  }
}
@media screen and (max-width: 767px) {
  .cvBtn {
    width: 100%;
    height: 64px;
    font-size: 18px;
  }
}
.cvBtn::after {
  position: absolute;
  top: 50%;
  right: 32px;
  display: block;
  width: 20px;
  height: 20px;
  content: "";
  background-image: url("../images/arrow-cvBtn.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  transform: translateY(-50%);
}
@media (hover: hover) {
  .cvBtn:hover {
    background-color: #e6e6e6;
  }
}
.cvBtn--blue {
  font-size: 18px;
  background-color: #004098;
  box-shadow: 0 5px 5px 0 rgba(64, 87, 119, 0.251);
}
@media (hover: hover) {
  .cvBtn--blue:hover {
    background-color: #356bb6;
  }
}
.cvBtn.-inner-btn {
  position: relative;
  display: block;
  width: 100%;
  max-width: 440px;
  height: 56px;
  padding-bottom: 3px;
  margin-inline: auto;
  margin-top: 24px;
  margin-bottom: 24px;
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%; /* 18px */
  color: #1d2088;
  text-align: center;
  cursor: pointer;
  background-color: #fff;
  border: 3px solid #1d2088;
  border-radius: 100px;
  box-shadow: 0 5px 5px 0 rgba(94, 94, 94, 0.3);
  transition: all 0.3s ease;
}
.cvBtn.-inner-btn:hover {
  background: #eff0fc;
}
.cvBtn.-inner-btn::after {
  position: absolute;
  top: 50%;
  right: 30px;
  display: block;
  width: 20px;
  height: 20px;
  content: "";
  background: url("../images/arrow-right-black.webp") no-repeat center/contain;
  background-repeat: no-repeat;
  background-size: 100% auto;
  transform: translateY(-50%) rotate(90deg);
}

.pagelink {
  display: flex;
  gap: 4px;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.4285714286;
  color: #000;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.pagelink::after {
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background-image: url("../images/arrow-down.svg");
  background-repeat: no-repeat;
  background-size: 100% auto;
}
@media (hover: hover) {
  .pagelink:hover {
    text-decoration: none;
  }
}

.staticContent {
  font-size: 14px;
  line-height: 1.6;
  word-break: break-all;
  white-space: pre-line;
}
.staticContent__link {
  font-size: 14px;
  line-height: 1.8333333333;
}

.mainContents {
  width: 375px;
  margin: 0 auto;
  background: #fff;
  background-image: url("../images/pcbg.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .mainContents {
    width: 100%;
  }
}

.mv {
  position: relative;
  width: 100%;
}
.mv__headItem {
  display: flex;
  align-items: center;
  align-self: stretch;
  width: 100%;
  padding: 12px 265px 12px 20px;
}
.mv__inner {
  margin-bottom: 20px;
}
.mv__inner--kenshin {
  background-color: #d9f4ff;
}
.mv__inner--mccm {
  background-color: #fffdd4;
}
.mv__note {
  display: block;
  width: 100%;
  padding: 10px 10px 0;
  margin-inline: auto;
}
.mv__note--mccm {
  padding-top: 4px;
}
.mv__linkWrapper {
  padding: 10px 15px 16px;
}
.mv__link {
  height: 64px;
  font-size: 18px;
  font-weight: 700;
}
.mv__link::after {
  transform: rotate(90deg) translateX(-10px);
}
@media (hover: hover) {
  .mv__link--mccm:hover {
    background-color: #bf3a5a;
  }
}

.guideAnnounce {
  margin: 0 16px 32px;
  font-style: normal;
  line-height: 1;
  background-color: #fff;
  border: solid 3px #f00;
}
.guideAnnounce__description {
  padding: 20px;
  font-size: 14px;
  line-height: 1.2;
}
.guideAnnounce__strong {
  display: inline-block;
  margin-bottom: 1rem;
  font-size: 16px;
  color: #f00;
  text-align: center;
}

.lidea {
  max-width: 870px;
  margin-inline: auto;
  background-color: #fff571;
}
.lidea__login {
  padding: 0 20px 40px;
  background-color: #14a467;
}
@media screen and (max-width: 767px) {
  .lidea__login {
    padding: 0vw 5.3333333333vw 10.6666666667vw;
  }
}
.lidea__login-inner {
  display: flex;
  flex-direction: column;
  gap: 30px;
  align-items: center;
  padding: 28px 20px 30px;
  background: #fff;
  border-radius: 12px 12px 0 0;
}
.lidea__head {
  width: 235px;
  height: 39px;
}
.lidea__lideaTitle {
  width: 270px;
  height: 80px;
}
.lidea__more {
  background: #14a467;
  border-radius: 0 0 12px 12px;
}
.lidea__more-inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  padding: 32px 20px;
  background: #f4faf8;
  border-radius: 0 0 12px 12px;
}

.lideaCpBtn {
  width: 194px;
  height: 40px;
}

.lideaAction {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.lideaAction__item {
  display: flex;
  flex-direction: column;
  gap: 30px;
  width: 100%;
  max-width: 438px;
  padding: 0;
}
.lideaAction__item-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
.lideaAction__head {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%; /* 16px */
  color: #202020;
  text-align: center;
}
.lideaAction__btn {
  margin-top: 16px;
}

.lideaUnlogin {
  width: 100%;
  padding: 2px 0 0;
}
.lideaUnlogin__head {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%; /* 16px */
  color: #14a467;
  text-align: center;
}
.lideaUnlogin__desc {
  margin-top: 12px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px; /* 153.846% */
  color: var(--cb-black, #202020);
  text-align: center;
}
.lideaUnlogin__form {
  max-width: 600px;
  margin: 20px auto 0;
}
.lideaUnlogin__subHead {
  margin-top: 20px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  color: #dc0035;
  text-align: center;
}
.lideaUnlogin__caution {
  max-width: 315px;
  margin-inline: auto;
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.5714285714;
}
@media screen and (max-width: 767px) {
  .lideaUnlogin__caution {
    max-width: 900px;
  }
}

.authForm__email {
  width: 100%;
  height: 48px;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  background-color: #fff;
  border: 1px solid #848484;
  border-radius: 4px;
}
.authForm__email:focus, .authForm__email:focus-visible {
  outline: none;
  border: 2px solid #1d2088;
}
.authForm__btn {
  position: relative;
  display: block;
  width: 100%;
  max-width: 440px;
  height: 56px;
  padding-bottom: 3px;
  margin-inline: auto;
  margin-top: 24px;
  margin-bottom: 4px;
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%; /* 18px */
  color: #1d2088;
  text-align: center;
  cursor: pointer;
  background-color: #fff;
  border: 3px solid #1d2088;
  border-radius: 100px;
  box-shadow: 0 5px 5px 0 rgba(94, 94, 94, 0.3);
}
.authForm__btn:hover {
  background: #eff0fc;
}
.authForm__btn::after {
  position: absolute;
  top: 50%;
  right: 30px;
  display: block;
  width: 20px;
  height: 20px;
  content: "";
  background: url("../images/arrow-right-black.webp") no-repeat center/contain;
  background-repeat: no-repeat;
  background-size: 100% auto;
  transform: translateY(-50%);
}
.authForm__inner-text {
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 20px; /* 166.667% */
  color: #202020;
}

.lideaCpBnr {
  display: block;
  width: 100%;
  max-width: 900px;
  margin-inline: auto;
}
.lideaCpBnr__item {
  display: block;
  width: 100%;
}
@media (hover: hover) {
  .lideaCpBnr:hover {
    opacity: 0.7;
  }
}

.campaignApply {
  padding: 40px 20px 24px;
  background-color: #14a467;
}
@media screen and (max-width: 767px) {
  .campaignApply {
    padding: 10.6666666667vw 5.3333333333vw 6.4vw;
  }
}
.campaignApply__inner {
  margin-inline: auto;
}
.campaignApply__head {
  width: 218px;
  margin-inline: auto;
}
.campaignApply__headItem {
  display: block;
  width: 100%;
}
.campaignApply__caution {
  margin-top: 20px;
}

.applyCaution {
  padding: 24px 12px 24px 16px;
  background-color: #fff;
  border-radius: 12px;
}
.applyCaution__inner {
  height: 130px;
  padding-right: 8px;
  overflow-y: auto;
}
.applyCaution__inner::-webkit-scrollbar {
  flex-shrink: 0;
  width: 12px;
  height: 34px;
}
.applyCaution__inner::-webkit-scrollbar-track {
  background-color: transparent;
}
.applyCaution__inner::-webkit-scrollbar-thumb {
  height: 34px;
  background: #d9d9d9;
  border-radius: 6px;
}
.applyCaution__inner {
  /* stylelint-disable-next-line */
}
@-moz-document url-prefix() {
  .applyCaution__inner {
    scrollbar-color: #d9d9d9 transparent;
    scrollbar-width: thin;
  }
}
.applyCaution__head {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  color: #202020;
  text-align: center;
}
.applyCaution__body {
  margin-top: 23px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 20px; /* 142.857% */
  color: #202020;
}

.dottedWrapper {
  padding: 40px 20px;
}
@media screen and (max-width: 767px) {
  .dottedWrapper {
    padding: 10.6666666667vw 5.3333333333vw;
  }
}

.faq-kireikirei_lion_welcia_2603__inner {
  width: auto;
  max-width: 870px;
  margin-inline: auto;
}
.faq-kireikirei_lion_welcia_2603__head {
  font-size: 34px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.01em;
}
.faq-kireikirei_lion_welcia_2603__headItem {
  width: 218px;
}
@media screen and (max-width: 767px) {
  .faq-kireikirei_lion_welcia_2603__headItem {
    width: 58.1333333333vw;
    margin-inline: auto;
  }
}
.faq-kireikirei_lion_welcia_2603__cassettes {
  margin-top: 24px;
}
.faq-kireikirei_lion_welcia_2603__buttonWrapper {
  position: relative;
  margin-top: 16px;
}
.faq-kireikirei_lion_welcia_2603__button {
  height: 64px;
}
.faq-kireikirei_lion_welcia_2603__button--close.cvBtn::after {
  transform: rotate(270deg) translateX(40%);
}

.faqCassettes__question {
  position: relative;
  display: flex;
  gap: 12px;
  align-items: center;
  width: 100%;
  padding: 16px 42px 16px 16px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  cursor: pointer;
  list-style: none;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .faqCassettes__question {
    gap: 2.1333333333vw;
    padding: 4.2666666667vw 11.2vw 4.2666666667vw 4.2666666667vw;
    font-size: 4vw;
    border-radius: 2.1333333333vw;
  }
}
.faqCassettes__question::-webkit-details-marker {
  display: none;
}
.faqCassettes__question input {
  display: none;
}
.faqCassettes__question::before {
  display: block;
  flex-shrink: 0;
  width: 32px;
  height: 33px;
  content: "";
  background-image: url("../images/faq-q.svg");
  background-repeat: no-repeat;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .faqCassettes__question::before {
    width: 8.5333333333vw;
    height: 8.5333333333vw;
  }
}
.faqCassettes__question::after {
  position: absolute;
  top: 50%;
  right: 16px;
  display: block;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  content: "";
  background-image: url("../images/faq-plus.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% auto;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .faqCassettes__question::after {
    right: 4.2666666667vw;
    width: 5.3333333333vw;
    height: 5.3333333333vw;
  }
}
@media (hover: hover) {
  .faqCassettes__question:hover {
    opacity: 0.7;
  }
}
.faqCassettes__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  border: 1px solid #14a467;
  border-radius: 12px;
}
.faqCassettes__item:not(:first-child) {
  margin-top: 16px;
}
.faqCassettes__item--more {
  margin-top: 16px;
}
.faqCassettes__item[open] .faqCassettes__question::after {
  background-image: url("../images/faq-minus.svg");
}
.faqCassettes__answer {
  position: relative;
  display: flex;
  gap: 12px;
  align-items: center;
  width: 100%;
  padding: 16px 42px 16px 16px;
  margin-inline: auto;
  margin-top: 1px;
}
@media screen and (max-width: 767px) {
  .faqCassettes__answer {
    gap: 2.1333333333vw;
    padding: 4.2666666667vw 11.2vw 4.2666666667vw 4.2666666667vw;
  }
}
.faqCassettes__answer::before {
  display: block;
  flex-shrink: 0;
  width: 32px;
  height: 33px;
  content: "";
  background-image: url("../images/faq-ans.svg");
  background-repeat: no-repeat;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .faqCassettes__answer::before {
    width: 8.5333333333vw;
    height: 8.5333333333vw;
  }
}
.faqCassettes__answer {
  /* custom 90% top border */
}
.faqCassettes__answer::after {
  position: absolute;
  top: 0;
  left: 50%;
  width: 90%;
  content: "";
  border-top: 1px dotted #14a467;
  transform: translateX(-50%);
}
.faqCassettes__fragment {
  font-size: 14px;
  line-height: 1.5714285714;
  word-break: break-word;
}
@media screen and (max-width: 767px) {
  .faqCassettes__fragment {
    font-size: 3.7333333333vw;
  }
}
.faqCassettes__hidden {
  display: none;
}

.applyRule {
  padding: 40px 20px;
  background: #14a467;
}
@media screen and (max-width: 767px) {
  .applyRule {
    padding: 10.6666666667vw 5.3333333333vw;
  }
}
.applyRule--mccm {
  padding-bottom: 50px;
}
.applyRule__headItem {
  display: block;
  width: 218px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .applyRule__headItem {
    width: 58.1333333333vw;
  }
}
.applyRule__body {
  padding: 24px 12px 24px 20px;
  margin-inline: auto;
  margin-top: 23px;
  background-color: #fff;
  border-radius: 12px;
}
.applyRule__rule {
  height: 200px;
  padding-right: 8px;
  overflow-y: auto;
}
.applyRule__rule::-webkit-scrollbar {
  inline-size: 6px;
}
.applyRule__rule::-webkit-scrollbar-track {
  background-color: transparent;
}
.applyRule__rule::-webkit-scrollbar-thumb {
  background-color: #d9d9d9;
  border-radius: 40px;
}
.applyRule__rule {
  /* stylelint-disable-next-line */
}
@-moz-document url-prefix() {
  .applyRule__rule {
    scrollbar-color: #d9d9d9 transparent;
    scrollbar-width: thin;
  }
}
.applyRule__ruleItem {
  padding-right: 8px;
  font-size: 14px;
  line-height: 1.5714285714;
}
.applyRule__ruleItem + .applyRule__ruleItem {
  margin-top: 30px;
}
.applyRule__notesSup {
  font-size: 9px;
  vertical-align: top;
}
.applyRule__btn-area {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: 20px;
}
.applyRule__brand {
  width: 138px;
}

.campaignChance {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  padding: 56px 20px 40px;
  background: #ffe5f2;
}
@media screen and (max-width: 767px) {
  .campaignChance {
    padding: 14.9333333333vw 5.3333333333vw 10.6666666667vw;
  }
}
.campaignChance.-whappy {
  background: #bbeaff;
}
.campaignChance__step01 {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  width: 100%;
  padding: 32px 20px;
  background: #fff;
  border: 4px solid #ef4a9b;
  border-radius: 20px;
  box-shadow: 4px 4px 0 0 #1d2088;
}
.campaignChance__step01.-whappy {
  border: 4px solid #1d2088;
}
.campaignChance__Plus-icon.-whappy {
  width: 40px;
  height: auto;
}
.campaignChance__step01-top {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  align-self: stretch;
}
.campaignChance__step01-top .campTitle-text {
  flex-shrink: 0;
  align-self: stretch;
}
.campaignChance__step01-top .campTop-text {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.campaignChance__step01-top-text {
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  font-feature-settings: "palt" on;
  line-height: 22px; /* 137.5% */
  color: #ef4a9b;
  text-align: center;
}
.campaignChance__step01-top-text .xl {
  font-size: 22px;
  font-style: normal;
  font-weight: 700;
  font-feature-settings: "palt" on;
  line-height: 22px; /* 100% */
  color: #ef4a9b;
  text-align: center;
  letter-spacing: -1.1px;
  -webkit-text-stroke-width: 0.2px;
  -webkit-text-stroke-color: #ef4a9b;
}
.campaignChance__step01-top-text .sm {
  font-size: 13px;
  font-style: normal;
  font-weight: 600;
  font-feature-settings: "palt" on;
  line-height: 22px; /* 169.231% */
  color: #ef4a9b;
  text-align: center;
}
.campaignChance__point {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
  align-self: stretch;
}
.campaignChance__point li {
  display: flex;
  gap: 2px;
  align-items: flex-start;
  align-self: stretch;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 18px */
  color: #202020;
}
.campaignChance__point li span {
  text-decoration-line: underline;
  text-decoration-thickness: auto;
  text-decoration-style: solid;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
  text-underline-offset: auto;
}
.campaignChance__point a {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 18px */
  color: #202020;
}
.campaignChance__step02 {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  width: 100%;
  padding: 32px 20px 24px;
  background: #fff;
  border: 4px solid #00af6c;
  border-radius: 20px;
  box-shadow: 4px 4px 0 0 #1d2088;
}
.campaignChance__step02.-sugi {
  border: 4px solid #00afef;
}
.campaignChance__step02.-tsuruha {
  border: 4px solid #00afef;
}
.campaignChance__step02.-whappy {
  padding: 40px 20px 24px;
  border: 4px solid #1d2088;
}
.campaignChance__whappyContent {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  width: 100%;
}
.campaignChance__whappyContent.-gap-16 {
  gap: 16px;
}
.campaignChance__chanceBadge {
  position: absolute;
  top: -36px;
  left: 0;
  width: 73px;
  height: auto;
}
.campaignChance__chanceBadge-pink {
  position: absolute;
  top: -36px;
  left: 0;
  width: 73px;
  height: auto;
}
.campaignChance__mama {
  position: absolute;
  top: -44px;
  right: -8px;
  width: auto;
  height: 103px;
}
.campaignChance__chanceContentsBanner {
  width: 100%;
}

.campDotLine,
.campBrands {
  width: 100%;
}

.campaign-time {
  display: flex;
  justify-content: center;
  padding: 50px 20px 40px;
  background: #1d2088;
}
@media screen and (max-width: 767px) {
  .campaign-time {
    padding: 13.3333333333vw 5.3333333333vw 10.6666666667vw;
  }
}
.campaign-time.-sugi {
  background: #00a550;
}
.campaign-time__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 246px;
  padding: 0 20px 32px;
  background: #fff;
  border-radius: 20px;
}
.campaign-time__top-area {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  transform: translateY(-33px);
}
.campaign-time__title-img {
  width: 225px;
  height: auto;
}
.campaign-time__schedule-img {
  width: 100%;
  height: auto;
}
.campaign-time__btn-area {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: center;
  width: 100%;
}

.main-btn {
  position: relative;
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 56px;
  text-decoration: none;
  background: #fff100;
  border: 4px solid #1d2088;
  border-radius: 100px;
  box-shadow: 0 5px 5px 0 rgba(94, 94, 94, 0.3);
}
.main-btn:hover {
  background: #e9dc00;
  box-shadow: 0 5px 5px 0 rgba(94, 94, 94, 0.3);
}
.main-btn.-brand {
  height: 64px;
  padding: 10px 70px;
  background: #fff;
  border: 2px solid #363e96;
  border-radius: 32px;
}
.main-btn.-brand:hover {
  background: #eff0fc;
}
.main-btn.-brand::after {
  right: 20px;
  background: url("../images/open_in_new.webp") no-repeat center/contain;
}
.main-btn span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%; /* 18px */
  color: #1d2088;
  text-align: center;
}
.main-btn::after {
  position: absolute;
  top: 50%;
  right: 24px;
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background: url("../images/arrow-right-black.webp") no-repeat center/contain;
  transform: translateY(-50%);
}

.anchor-btn {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  text-decoration: none;
}
.anchor-btn.-gap08 {
  gap: 8px;
}
.anchor-btn span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 100%;
  color: #202020;
  text-align: center;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
}
.anchor-btn img {
  width: 18px;
  height: 18px;
}
.anchor-btn:hover span {
  text-decoration: none;
}

.inner-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 130%; /* 15.6px */
  color: #202020;
}

.products-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  align-self: stretch;
  padding: 40px 20px;
  background: #fff;
}
.products-area__contents {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
  align-self: stretch;
  padding: 32px 16px;
  background: #ecf9ff;
  border-top: 4px solid #479ee3;
  border-right: 4px solid #479ee3;
  border-left: 4px solid #479ee3;
  border-radius: 20px 20px 0 0;
}
.products-area__contents.-whappy {
  border: 4px solid #479ee3;
  border-radius: 20px;
}
.products-area__company {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  align-self: stretch;
  padding: 32px 20px;
  background: #fff;
  border-right: 4px solid #479ee3;
  border-bottom: 4px solid #479ee3;
  border-left: 4px solid #479ee3;
  border-radius: 0 0 32px 32px;
}
.products-area__company-title {
  width: 80px;
}
.products-area__product-title-img {
  width: 217px;
}
.products-area__contents-top-area {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  align-self: stretch;
}
.products-area__caution-text-area {
  display: flex;
  gap: 2px;
  align-items: flex-start;
  padding-top: 6px;
}
.products-area__caution-text-area .inner-text {
  font-size: 11px;
  font-weight: 300;
}
.products-area__contents-caution {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: center;
  align-self: stretch;
  justify-content: center;
}
.products-area__product-btn {
  position: relative;
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 56px;
  padding: 11px 44px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 100%; /* 18px */
  color: #fff;
  text-align: center;
  text-decoration: none;
  background: #479ee3;
  border-radius: 30px;
}
.products-area__product-btn::after {
  position: absolute;
  top: 19px;
  right: 19px;
  width: 18px;
  height: 18px;
  content: "";
  background: url("../images/white-link-icon.webp") no-repeat center/contain;
}
.products-area__product-btn:hover {
  background: #2686d2;
}
.products-area__productsimage {
  padding: 12px 0;
}

.methods-area {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  align-self: stretch;
  justify-content: center;
  padding: 40px 20px;
}
@media screen and (max-width: 767px) {
  .methods-area {
    padding: 10.6666666667vw 5.3333333333vw;
  }
}
.methods-area__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding-bottom: 48px;
  background: #fff;
  border: 2px solid #14a467;
  border-radius: 20px;
}
.methods-area__title-area {
  display: flex;
  align-items: center;
  align-self: stretch;
  justify-content: center;
  padding: 16px 0;
  background: #14a467;
  border-radius: 17px 17px 0 0;
}
.methods-area__method-title {
  width: 96px;
}
.methods-area__inner-content {
  display: flex;
  flex-direction: column;
  gap: 40px;
  align-items: center;
  padding: 40px 20px 0;
}
.methods-area__steps {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: center;
  width: 100%;
}
.methods-area__step-inner-title {
  width: 209px;
}
.methods-area__list {
  width: 100%;
  padding-left: 1.02em;
  list-style: disc;
}
.methods-area__list li {
  padding-bottom: 4px;
  list-style-type: disc;
}
.methods-area__list li::marker {
  font-size: 10px;
}
.methods-area__steps-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
}
.methods-area__steps-content-top {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}
.methods-area__Line {
  width: 100%;
}

.top-bg {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}
.top-bg.-whappy {
  max-width: 1600px;
}
.top-bg__img {
  display: block;
  width: 100%;
  height: auto;
  margin: auto;
}