/* ------------------------------------
MOPM
styles for rank LP
added 2023/12
-------------------------------------- */
/* =============================================
  Custom Properties
============================================= */
:root {
  /* logo colors */
  --logo-gmo-blue: #005bac;
  --logo-gmo-gray: #5a5858;
  --logo-zcom-red: #d62825;
  /* common colors */
  --common-black1: #222222;
  --common-gray1: #333333;
  --common-gray2: #555555;
  --common-gray3: #888888;
  --common-gray4: #dddddd;
  /* Qplus colors */
  --qplus-orange1: #fdb33e;
  --qplus-orange2: #ff8a00;
  --qplus-green1: #f1f9f9;
  --qplus-green2: #e5f3f3;
  --qplus-green3: #6cd4d3;
  --qplus-green4: #48b9b7;
  --qplus-green5: #27a7a5;
  --qplus-green6: #218888;
  --qplus-green7: #344845;
  --qplus-green8: #d5e0e0;
  --qplus-green9: #839799;
  /* rank LP colors */
  --rankLP-green1: #36b2bd;
  --rankLP-green2: #f4fafb;
  --rankLP-green3: #e4eced;
  --rankLP-pink1: #e91e63;
  /* sns colors */
  --sns-facebook: #1778f2;
  --sns-twitter: #1da1f3;
  --sns-hatena: #00a4de;
  /* letter spacing */
  --letter-spacing-L: 0.04em;
  --letter-spacing-M: 0.02em;
  /* line height */
  --lh-def: 1.3;
  --lh-wide: 1.5;
  --lh-x-wide: 1.7;
  /* font weight: for Noto Sans */
  --notosans-regular: 400;
  --notosans-bold: 700;
}

/* ===============================================
  Font Setting
  Noto Sans: 400 (normal) / 700 (bold)
=============================================== */
@font-face {
  font-family: "Noto Sans";
  font-style: normal;
  font-weight: 400;
  src: url(../fonts/NotoSansJP-Regular.woff) format("woff");
}
@font-face {
  font-family: "Noto Sans";
  font-style: normal;
  font-weight: 700;
  src: url(../fonts/NotoSansJP-Bold.woff) format("woff");
}
/* ===============================================
  rank LP: reset / base setting
=============================================== */
body {
  color: var(--common-black1);
  font-family: "Noto Sans", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 1rem;
  line-height: 1;
  padding-bottom: 0;
  background-color: #ffffff;
  -webkit-text-size-adjust: 100%;
}
body .wrapUnder {
  background-color: #ffffff;
}

main.rank {
  padding-bottom: 0;
  position: relative;
}
main.rank img {
  vertical-align: middle;
}
main.rank .wrapUnder-content {
  max-width: 100%;
  margin: 0;
  padding-top: 0;
}
@media screen and (max-width: 1024px) {
  main.rank .wrapUnder-content {
    width: auto;
  }
}

/* ---------------------------
  header
--------------------------- */
.drawer--right.drawer-open .drawer-hamburger {
  z-index: 100000001;
}

/* ===============================================
  rank LP: local navigation
=============================================== */
.rank-lnav {
  background-image: linear-gradient(-225deg, #35b1bc 0%, #4596fb 100%);
  box-shadow: 0 5px 5px 0 rgba(51, 51, 51, 0.2) inset;
  color: #ffffff;
}

.rank-lnav__inner {
  max-width: 1024px;
  height: 64px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 2rem;
  box-sizing: content-box;
}
@media screen and (max-width: 1024px) {
  .rank-lnav__inner {
    padding: 0 2vw 0 3vw;
  }
}
@media screen and (max-width: 768px) {
  .rank-lnav__inner {
    display: block;
    height: auto;
    padding: 2.6vw 0 1.6vw 0;
  }
}
@media screen and (max-width: 425px) {
  .rank-lnav__inner {
    padding-top: 3vw;
    padding-bottom: 4vw;
  }
}

/* ---------------------------
  contents title
--------------------------- */
.rank-lnav__title {
  position: relative;
}
@media screen and (max-width: 768px) {
  .rank-lnav__title {
    display: table;
    margin: 0 auto;
    padding-right: 3vw;
  }
}
.rank-lnav__title::before {
  content: "";
  display: block;
  width: 35px;
  padding-top: 22px;
  overflow: hidden;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background-image: url(../images/rank/icon_crown.svg);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 100% auto;
}
@media screen and (max-width: 768px) {
  .rank-lnav__title::before {
    width: 5vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-lnav__title::before {
    width: 7vw;
  }
}
.rank-lnav__title span {
  display: block;
  font-size: 2rem;
  line-height: 1.3;
  letter-spacing: 0.06em;
  padding-left: calc(35px + 0.6em);
}
@media screen and (max-width: 1024px) {
  .rank-lnav__title span {
    font-size: 2.4vw;
  }
}
@media screen and (max-width: 768px) {
  .rank-lnav__title span {
    font-size: 3.4vw;
    padding-left: calc(5vw + 1.6vw);
  }
}
@media screen and (max-width: 425px) {
  .rank-lnav__title span {
    font-size: 4.8vw;
    padding-left: calc(7vw + 2.6vw);
  }
}

/* ---------------------------
  local navigation
--------------------------- */
@media screen and (max-width: 768px) {
  .rank-lnav nav {
    margin-top: 1vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-lnav nav {
    margin-top: 3vw;
  }
}
.rank-lnav ul {
  display: flex;
}
@media screen and (max-width: 768px) {
  .rank-lnav ul {
    justify-content: center;
  }
}
@media screen and (max-width: 425px) {
  .rank-lnav ul {
    flex-wrap: wrap;
  }
}
.rank-lnav li {
  font-size: 1.6rem;
  line-height: 1;
}
@media screen and (max-width: 1024px) {
  .rank-lnav li {
    font-size: 1.6vw;
  }
}
@media screen and (max-width: 768px) {
  .rank-lnav li {
    font-size: 2.4vw;
  }
}
@media screen and (max-width: 600px) {
  .rank-lnav li {
    font-size: 2.8vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-lnav li {
    flex: 0 1 50%;
    font-size: 3.4vw;
    padding: 0 1.6vw;
    text-align: center;
  }
  .rank-lnav li:nth-child(n+3) {
    margin-top: 1.6vw;
  }
}
.rank-lnav li a {
  display: inline-block;
  padding: 0 1.6rem;
  color: #ffffff;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .rank-lnav li a {
    padding: 0.6vw 1.6vw;
  }
}
@media screen and (max-width: 768px) {
  .rank-lnav li a {
    padding: 1vw 1.6vw;
  }
}
@media screen and (max-width: 600px) {
  .rank-lnav li a {
    padding: 1vw;
  }
}
.rank-lnav li a span {
  display: inline-block;
  padding: 0.4rem 0;
  border-bottom: 1px solid transparent;
  transition: 0.3s;
}
@media screen and (max-width: 425px) {
  .rank-lnav li a span {
    padding: 0;
    border-bottom: none;
    transition: none;
  }
}
.rank-lnav li a:hover span {
  border-color: #ffffff;
}

/* ===============================================
  rank LP: component
=============================================== */
/* ---------------------------
  heading
--------------------------- */
.rank .c-heading {
  display: flex;
  align-items: center;
  padding-bottom: 0.6em;
  border-bottom: 1px solid var(--common-black1);
}
.rank .c-heading__label {
  margin-right: 0.8em;
  padding: 0.1em 0.6em;
  background-color: var(--rankLP-pink1);
  font-size: 1.4rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-wide);
  letter-spacing: var(--letter-spacing-L);
  color: #ffffff;
}
.rank .c-heading__title {
  font-size: 2rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-def);
  color: var(--common-black1);
}

/* ---------------------------
  lead
--------------------------- */
.rank .c-lead {
  margin-top: 1.6rem;
  font-size: 1.6rem;
  line-height: var(--lh-x-wide);
}

/* ---------------------------
  pic
--------------------------- */
.rank .c-pic {
  margin-top: 2.4rem;
  text-align: center;
}

/* ---------------------------
  button
--------------------------- */
.rank .c-btn__round a {
  display: table;
  margin: 0 auto;
  line-height: var(--lh-def);
  border-radius: 100vh;
  border-width: 1px;
  border-style: solid;
  text-decoration: none;
  text-align: center;
  transition: 0.3s;
}
@media screen and (max-width: 425px) {
  .rank .c-btn__round a {
    display: block;
  }
}

/* default
--------------------------- */
.rank .c-btn__def a {
  background-color: #ffffff;
  padding: 1.2rem 3rem;
  font-size: 1.8rem;
  color: var(--common-gray1);
  border-color: var(--common-gray1);
}
@media screen and (max-width: 425px) {
  .rank .c-btn__def a {
    font-size: 1.6rem;
  }
}
.rank .c-btn__def a:hover {
  color: var(--common-gray3);
  border-color: var(--common-gray3);
}

/* CTA
--------------------------- */
.rank .c-btn__cta a {
  display: block;
  max-width: 460px;
  background-color: var(--rankLP-pink1);
  border-color: var(--rankLP-pink1);
  padding: 1.8rem 3rem;
  font-size: 1.8rem;
  color: #ffffff;
  font-weight: var(--notosans-bold);
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.08);
}
@media screen and (max-width: 500px) {
  .rank .c-btn__cta a {
    padding: 3vw;
    font-size: 4.4vw;
  }
}
@media screen and (max-width: 425px) {
  .rank .c-btn__cta a {
    max-width: 100%;
    font-size: 4.8vw;
  }
}
.rank .c-btn__cta a:hover {
  background-color: #f06292;
  border-color: #f06292;
  box-shadow: none;
}
.rank .c-btn__cta br {
  display: none;
}
@media screen and (max-width: 500px) {
  .rank .c-btn__cta br {
    display: block;
  }
}

/* ---------------------------
  text link
--------------------------- */
.rank .c-txt__link {
  color: var(--qplus-green6);
  border-bottom: 1px dashed var(--qplus-green6);
  transition: 0.3s;
  text-decoration: none;
}
.rank .c-txt__link:hover {
  border-color: transparent;
}

/* ---------------------------
  list
--------------------------- */
/* dot
--------------------------- */
.rank .c-list__dot li {
  padding-left: 1.2em;
  font-size: 1.6rem;
  line-height: var(--lh-x-wide);
  position: relative;
}
.rank .c-list__dot li::before {
  content: " \2022";
  display: block;
  width: 1.2em;
  text-align: center;
  position: absolute;
  left: 0;
  top: 0;
}
.rank .c-list__dot li:nth-child(n+2) {
  margin-top: 0.6em;
}

/* ---------------------------
  accodion
--------------------------- */
.rank .c-accodion {
  margin-top: 2.4rem;
  border: 1px solid var(--common-gray4);
  border-radius: 8px;
  transition: all 0.5s;
  background-color: #ffffff;
}
.rank .c-accodion.is-active, .rank .c-accodion:hover {
  background-color: #ffffff;
  border-color: #ffffff;
}
.rank .c-accodion dt {
  padding: 1.2rem 2.4rem;
  cursor: pointer;
  font-size: 1.8rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-wide);
  color: var(--common-black1);
}
@media screen and (max-width: 425px) {
  .rank .c-accodion dt {
    padding: 1rem 1.8rem;
    font-size: 1.6rem;
  }
}
.rank .c-accodion dd {
  display: none;
  color: var(--common-black1);
  font-size: 1.6rem;
  line-height: var(--lh-x-wide);
  padding-right: 6rem;
}
@media screen and (max-width: 425px) {
  .rank .c-accodion dd {
    font-size: 1.4rem;
    padding-left: 2rem;
    padding-right: 4rem;
  }
}
.rank .c-accodion dd strong {
  font-weight: var(--notosans-bold);
}
.rank .c-accodion__txt {
  margin-top: 1.6rem;
}
.rank .c-accodion__txt:first-child {
  margin-top: 0;
}

/* ---------------------------
  catch
--------------------------- */
.rank .c-catch {
  display: table;
  margin: 0 auto;
  padding: 0.8rem 3.2rem;
  border-top-width: 1px;
  border-bottom-width: 1px;
  border-style: solid;
  border-color: var(--rankLP-pink1);
  background-color: #fff7fa;
}
@media screen and (max-width: 425px) {
  .rank .c-catch {
    display: block;
    padding: 0.6rem 1.6rem;
  }
}
.rank .c-catch span {
  display: inline-block;
  font-size: 1.6rem;
  color: var(--rankLP-pink1);
}
@media screen and (max-width: 768px) {
  .rank .c-catch span {
    font-size: 2.6vw;
  }
}
@media screen and (max-width: 425px) {
  .rank .c-catch span {
    display: block;
    font-size: 3.4vw;
    line-height: var(--lh-wide);
  }
}
.rank .c-catch span:nth-child(2) {
  margin-left: 0.6em;
  padding-left: 0.6em;
  border-left: 1px solid var(--rankLP-pink1);
}
@media screen and (max-width: 425px) {
  .rank .c-catch span:nth-child(2) {
    margin-left: 0;
    padding-left: 0;
    border-left: none;
  }
}
.rank .c-catch br {
  display: none;
}
@media screen and (max-width: 425px) {
  .rank .c-catch br {
    display: block;
  }
}

/* ===============================================
  rank LP: frame layout
=============================================== */
/* ---------------------------
  section
--------------------------- */
.rank section {
  padding-top: 5.6rem;
  background-color: var(--rankLP-green2);
}

/* ---------------------------
  section inner
--------------------------- */
.rank .section-inner {
  max-width: 750px;
  margin: 0 auto;
  padding-left: 3rem;
  padding-right: 3rem;
  box-sizing: content-box;
}
@media screen and (max-width: 960px) {
  .rank .section-inner {
    padding-left: 3vw;
    padding-right: 3vw;
  }
}
@media screen and (max-width: 768px) {
  .rank .section-inner {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}

/* ===============================================
  rank LP: about
=============================================== */
.rank .rank-about {
  padding-top: 0;
}

/* ---------------------------
  introduction
--------------------------- */
.rank-introduction {
  padding-top: 3.2rem;
  background-color: #ffffff;
}
.rank-introduction .section-inner {
  text-align: center;
}
.rank-introduction .c-catch {
  margin-bottom: 2.4rem;
}

/* title
--------------------------- */
.rank-introduction__title {
  margin-top: 1rem;
  font-size: 4rem;
  font-weight: var(--notosans-bold);
  letter-spacing: var(--letter-spacing-L);
}
@media screen and (max-width: 768px) {
  .rank-introduction__title {
    font-size: 5vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-introduction__title {
    font-size: 7.6vw;
  }
}

/* lead
--------------------------- */
.rank-introduction__lead {
  margin-top: 1.6rem;
  font-size: 2rem;
  line-height: var(--lh-x-wide);
}
@media screen and (max-width: 768px) {
  .rank-introduction__lead {
    font-size: 3vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-introduction__lead {
    font-size: 1.6rem;
  }
  .rank-introduction__lead br {
    display: none;
  }
}
.rank-introduction__lead strong {
  color: var(--rankLP-pink1);
}

/* ---------------------------
  feature
--------------------------- */
.rank-feature {
  background-color: var(--rankLP-green1);
  padding: 4rem 0;
}
.rank-feature .section-inner {
  text-align: center;
}
.rank-feature .c-catch {
  margin-bottom: 1.6rem;
}

/* title
--------------------------- */
.rank-feature__title {
  font-size: 2.4rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-def);
  color: #ffffff;
}
@media screen and (max-width: 425px) {
  .rank-feature__title {
    font-size: 5.6vw;
  }
}
.rank-feature__title br {
  display: none;
}
@media screen and (max-width: 768px) {
  .rank-feature__title br {
    display: block;
  }
}

/* detail
--------------------------- */
.rank-feature__detail {
  display: flex;
  justify-content: center;
  margin: 2.4rem 0;
}
@media screen and (max-width: 425px) {
  .rank-feature__detail {
    display: block;
  }
}
.rank-feature__detail li {
  flex: 0 1 346px;
  margin: 0 1.2rem;
  padding: 1.6rem;
  background-color: #ffffff;
  border: 4px solid #b7e3e7;
}
@media screen and (max-width: 800px) {
  .rank-feature__detail li {
    flex: 0 1 50%;
    white-space: nowrap;
  }
}
@media screen and (max-width: 425px) {
  .rank-feature__detail li {
    margin: 0;
  }
  .rank-feature__detail li:nth-child(n+2) {
    margin-top: 1.6rem;
  }
}

/* title */
.rank-feature__detail .detail-title {
  font-size: 2rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-def);
}
@media screen and (max-width: 800px) {
  .rank-feature__detail .detail-title {
    font-size: 2.8vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-feature__detail .detail-title {
    font-size: 4.6vw;
  }
}
.rank-feature__detail .detail-title img {
  margin-right: 0.4em;
  position: relative;
  top: -0.2em;
}

/* information */
.rank-feature__detail .detail-info {
  font-size: 2rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-def);
}
@media screen and (max-width: 800px) {
  .rank-feature__detail .detail-info {
    font-size: 2.8vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-feature__detail .detail-info {
    font-size: 4.6vw;
  }
}
.rank-feature__detail .detail-info span {
  display: block;
}
.rank-feature__detail .detail-info span + span {
  margin-top: 0.2em;
}
.rank-feature__detail .detail-info strong {
  font-size: 3.2rem;
  color: var(--rankLP-pink1);
}
@media screen and (max-width: 800px) {
  .rank-feature__detail .detail-info strong {
    font-size: 3.4vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-feature__detail .detail-info strong {
    font-size: 6vw;
  }
}
.rank-feature__detail .detail-info em {
  font-size: 4rem;
  padding: 0 3px;
}
@media screen and (max-width: 800px) {
  .rank-feature__detail .detail-info em {
    font-size: 5vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-feature__detail .detail-info em {
    font-size: 7vw;
  }
}
.rank-feature__detail .detail-info small {
  font-size: 2.4rem;
}
@media screen and (max-width: 800px) {
  .rank-feature__detail .detail-info small {
    font-size: 3vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-feature__detail .detail-info small {
    font-size: 5.2vw;
  }
}

/* ===============================================
  rank LP: howto
=============================================== */
.rank-howto__step {
  margin-top: 2.4rem;
  display: flex;
  justify-content: center;
  counter-reset: step-num;
}
@media screen and (max-width: 425px) {
  .rank-howto__step {
    display: block;
  }
}
.rank-howto__step li {
  flex: 0 1 220px;
  padding: 1.6rem 1.6rem 2.4rem 1.6rem;
  background-color: #ffffff;
  border: 1px solid var(--rankLP-green3);
  border-radius: 8px;
  text-align: center;
}
.rank-howto__step li:nth-child(n+2) {
  margin-left: 2.4rem;
}
@media screen and (max-width: 425px) {
  .rank-howto__step li:nth-child(n+2) {
    margin-left: 0;
    margin-top: 2.4rem;
  }
}
.rank-howto__step li::before {
  counter-increment: step-num;
  content: counter(step-num);
  display: block;
  width: 28px;
  height: 28px;
  margin: 0 auto;
  background-color: var(--rankLP-green1);
  border-radius: 100%;
  font-size: 18px;
  font-weight: var(--notosans-bold);
  color: #ffffff;
  line-height: var(--lh-wide);
}
@media screen and (max-width: 768px) {
  .rank-howto__step li::before {
    width: 26px;
    height: 26px;
    font-size: 16px;
  }
}
.rank-howto__step .step-lead {
  margin-top: 0.8rem;
  font-size: 1.6rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-def);
}
@media screen and (max-width: 768px) {
  .rank-howto__step .step-lead {
    font-size: 2.2vw;
  }
}
@media screen and (max-width: 425px) {
  .rank-howto__step .step-lead {
    font-size: 1.6rem;
  }
}
.rank-howto__step .c-pic {
  margin-top: 1.6rem;
}
.rank-howto__step .step-link {
  margin-top: 1.6rem;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .rank-howto__step .step-link {
    font-size: 2vw;
    line-height: var(--lh-wide);
  }
}
@media screen and (max-width: 425px) {
  .rank-howto__step .step-link {
    font-size: 1.6rem;
  }
}
.rank-howto__step .step-link a {
  color: var(--rankLP-pink1);
  border-color: var(--rankLP-pink1);
}
.rank-howto__step .step-link br {
  display: none;
}
@media screen and (max-width: 768px) {
  .rank-howto__step .step-link br {
    display: block;
  }
}
@media screen and (max-width: 425px) {
  .rank-howto__step .step-link br {
    display: none;
  }
}

/* ---------------------------
  balloon
--------------------------- */
.rank-howto__balloon {
  max-width: 660px;
  margin: 2.4rem auto 0 auto;
  background-color: #ffffff;
  border: 1px solid var(--common-black1);
  box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.08);
  position: relative;
}
.rank-howto__balloon::before, .rank-howto__balloon::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  border-right: 10px solid transparent;
  border-bottom: solid 20px var(--common-black1);
  border-left: 10px solid transparent;
}
.rank-howto__balloon::before {
  bottom: 100%;
}
.rank-howto__balloon::after {
  bottom: calc(100% - 2px);
  border-bottom: solid 20px #ffffff;
}
.rank-howto__balloon .balloon-inner {
  padding: 1.6rem 2.4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .rank-howto__balloon .balloon-inner {
    padding: 2.4rem;
    display: block;
  }
}
.rank-howto__balloon .balloon-detail {
  flex: 0 1 calc((220 / 610) * 100%);
}
.rank-howto__balloon .balloon-lead {
  border-left: 4px solid var(--rankLP-pink1);
  padding-left: 0.8em;
  font-size: 1.6rem;
  font-weight: var(--notosans-bold);
  line-height: var(--lh-def);
  color: var(--rankLP-pink1);
}
@media screen and (max-width: 768px) {
  .rank-howto__balloon .balloon-lead {
    font-size: 2.4vw;
  }
}
@media screen and (max-width: 600px) {
  .rank-howto__balloon .balloon-lead {
    font-size: 1.6rem;
  }
}
.rank-howto__balloon .balloon-txt {
  margin-top: 0.8rem;
  font-size: 1.4rem;
  line-height: var(--lh-x-wide);
}
.rank-howto__balloon .balloon-txt em,
.rank-howto__balloon .balloon-txt strong {
  font-weight: var(--notosans-bold);
}
.rank-howto__balloon .balloon-txt strong {
  color: var(--rankLP-pink1);
}
.rank-howto__balloon .c-pic {
  margin-top: 0;
  flex: 0 1 calc((374 / 610) * 100%);
}
@media screen and (max-width: 600px) {
  .rank-howto__balloon .c-pic {
    margin-top: 1.6rem;
  }
}

/* ===============================================
  rank LP: term
=============================================== */
.rank-term {
  padding-bottom: 5.6rem;
}
.rank-term .c-btn__round {
  margin-top: 2.4rem;
}

/* ---------------------------
  pic
--------------------------- */
.rank-term__pic {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 425px) {
  .rank-term__pic {
    display: block;
  }
}
.rank-term__pic li:nth-child(n+2) {
  padding-left: 2.4rem;
}
@media screen and (max-width: 425px) {
  .rank-term__pic li:nth-child(n+2) {
    padding-left: 0;
    margin-top: 2.4rem;
  }
}

/* ===============================================
  rank LP: notice
=============================================== */
section.rank-notice {
  background-color: #ffffff;
}

.rank-notice .section-inner {
  max-width: 880px;
}
.rank-notice .c-list__dot {
  margin-top: 2rem;
}

/* ===============================================
  rank LP: faq
=============================================== */
section.rank-faq {
  background-color: #ffffff;
  padding-bottom: 5.6rem;
}

.rank-faq .section-inner {
  max-width: 880px;
}

/* ---------------------------
  accodion
--------------------------- */
.rank-faq .c-accodion dd {
  padding-left: 4.8rem;
}
@media screen and (max-width: 425px) {
  .rank-faq .c-accodion dd {
    padding-left: 3rem;
  }
}
.rank-faq .c-accodion.is-active, .rank-faq .c-accodion:hover {
  border-color: var(--rankLP-green2);
  background-color: var(--rankLP-green2);
}

/* question
--------------------------- */
.rank-faq .faq-question {
  display: block;
  position: relative;
  padding-left: 3rem;
}
.rank-faq .faq-question::before {
  content: "Q";
  display: block;
  font-size: 2rem;
  color: var(--rankLP-green1);
  font-weight: var(--notosans-bold);
  position: absolute;
  left: 0;
  top: -0.1em;
}

/* answer
--------------------------- */
.rank-faq .faq-answer {
  padding-bottom: 2rem;
  padding-left: 2.4rem;
  position: relative;
}
.rank-faq .faq-answer::after {
  display: block;
  content: "A";
  font-size: 1.6rem;
  font-weight: var(--notosans-bold);
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 425px) {
  .rank-faq .faq-answer::after {
    top: -0.1em;
  }
}

/* ---------------------------
  button
--------------------------- */
.rank-faq .c-btn__round {
  margin-top: 2.4rem;
}
.rank-faq .c-btn__round a {
  display: block;
  max-width: 274px;
}
@media screen and (max-width: 425px) {
  .rank-faq .c-btn__round a {
    max-width: 100%;
  }
}