body#page-top {
  margin: 0;
  padding: 0;
  line-height: 1.55;
  color: #333;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
    "MS PGothic", sans-serif;
}

#page-top h1,
#page-top h2,
#page-top h3,
#page-top h4,
#page-top li,
#page-top dl,
#page-top dt,
#page-top dd,
#page-top p {
  margin: 0;
  padding: 0;
}

*,
::before,
::after {
  box-sizing: border-box;
}

#page-top a {
  color: #000;
  text-decoration: none;
}

#page-top a:link,
#page-top a:visited {
  color: #000;
}

#page-top ol,
#page-top ul {
  list-style: none;
  padding: 0;
}

.pc-only {
  display: block;
}
.sp-only {
  display: none;
}

/* ------------------------------ */

/* header */
.g-header {
  position: fixed;
  background: #fff;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  transition: all 0.3s;
  height: 80px;
}

.g-header .g-header__inner {
  position: relative;
  padding: 20px;
  height: 80px;
}

.g-header__body {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.g-header .logo {
  line-height: 1;
}

.g-header .logo a {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.g-header .logo .business {
  font-family: barlow, Arial, 游ゴシック体, YuGothic, yu gothic m,
    游ゴシック medium, yu gothic medium, hiragino kaku gothic pron, メイリオ,
    sans-serif;
  font-style: oblique;
  font-size: 18px;
  font-weight: 500;
  color: #1688c5;
  display: inline-block;
  vertical-align: baseline;
  margin-left: 0.75em;
  transform: translateY(8%);
}

.g-header .aside-wrapper {
  position: absolute;
  top: 15px;
  right: 50px;
}

.g-header .aside-wrapper .aside {
  display: flex;
  align-items: center;
  font-family: noto sans jp, sans-serif;
}

#page-top .g-header .aside-wrapper .aside .aside-item-1 .btn-header {
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 0.16em;
  line-height: 1;
  color: #fff;
  padding: 14px 30px;
  min-height: 47px;
}

.g-header .aside-wrapper .aside .aside-item-1 {
  display: flex;
  align-items: center;
  margin-right: 30px;
}

.g-header .aside-wrapper .aside .aside-item-1 .btn-header:not(:last-of-type) {
  margin-right: 20px;
}

.g-header .aside-wrapper .aside .aside-item-1 .btn-header-1 {
  background: #018bd1;
}

.g-header .aside-wrapper .aside .aside-item-1 .btn-header-2 {
  background: #5c5cbf;
}

.g-header .aside-wrapper .aside .aside-item-1 .btn-header-3 {
  background: #333;
}

.g-header .aside-wrapper .aside .aside-item-2 {
  display: flex;
  align-items: center;
}

.g-header .aside-wrapper .aside .aside-item-2 .icon-tel {
  margin-right: 5px;
  margin-top: 4px;
}

.g-header .aside-wrapper .aside .aside-item-2 .tel-wrapper {
  text-align: center;
}

.g-header .aside-wrapper .aside .aside-item-2 .tel {
  font-size: 30px;
  font-weight: 700;
  line-height: 1;
  color: #000;
}

.g-header .aside-wrapper .aside .aside-item-2 .tel a {
  pointer-events: none;
  color: #000;
}

.footer-fixed-nav-section {
  display: none;
}

@media screen and (max-width: 1024px) {
  .g-header .aside-wrapper {
    display: none;
  }

  .footer-fixed-nav-section.has-scroll {
    bottom: 0;
  }

  .footer-fixed-nav-section {
    display: block;
    position: fixed;
    z-index: 2;
    bottom: -50vh;
    left: 0;
    width: 100%;
    background: #fff;
    transition: bottom 0.3s;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-1 {
    display: flex;
    align-items: center;
  }

  #page-top
    .footer-fixed-nav-section
    .footer-fixed-nav
    .nav-item-1
    .btn-header {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 3.5vw;
    letter-spacing: 0.16em;
    line-height: 1;
    color: #fff;
    padding: 14px 0;
    min-height: 50px;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-1 .btn-header-1 {
    flex: 0 1 35%;
    background: #018bd1;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-1 .btn-header-2 {
    flex: 0 1 40%;
    background: #5c5cbf;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-1 .btn-header-3 {
    flex: 0 1 25%;
    background: #333;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-2 {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 5px 0;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-2 .icon-tel {
    margin-right: 5px;
    margin-top: 4px;
  }

  .footer-fixed-nav-section .footer-fixed-nav .nav-item-2 .tel-wrapper {
    text-align: center;
    font-weight: 700;
    color: #000;
    font-size: 30px;
  }
}

.main-content__body.about .section .section-title {
  font-size: 48px;
  font-weight: 700;
  text-align: center;
}

.main-content__body.about .section .section-title::after {
  display: block;
  content: "";
  width: 120px;
  height: 6px;
  background: #fff;
  margin: 30px auto 0;
}

.main-content__body.about .section .section-catch {
  font-size: 18px;
  text-align: center;
  font-weight: 700;
  position: relative;
  top: -140px;
}

#page-top #howtouse {
  margin-top: 0;
}

#howtouse .item-wrap {
  margin-top: 20px;
}

/* mv */

.main-content__header .mv {
  background: url(../images/mv.jpg) no-repeat center center/cover;
  height: 450px;
  margin-top: 80px;
  padding-bottom: 93px;
  position: relative;
  overflow: hidden;
}

.main-content__header .mv::before {
  display: block;
  content: "";
  background: url(../images/mv-bg-l.png) no-repeat bottom right/auto 93px;
  width: 100%;
  height: 93px;
  position: absolute;
  bottom: 0;
  left: -50%;
}

.main-content__header .mv::after {
  display: block;
  content: "";
  background: url(../images/mv-bg-r.png) no-repeat bottom left/auto 93px;
  width: 100%;
  height: 93px;
  position: absolute;
  bottom: 0;
  right: -50%;
}

.mv-inner {
  width: 1200px;
  height: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.mv-item {
}

#page-top .mv-item h1 {
  font-size: 48px;
  font-weight: 700;
  color: #fff;
}

.mv-item h1 span {
  display: inline-block;
  background: #0989cd;
  font-size: 54px;
  font-weight: 600;
  padding: 0 15px;
  line-height: 1.2;
}

.mv-item h1 span:first-child,
.mv-item h1 span:nth-child(3) {
  font-family: "Barlow", sans-serif;
}

.mv-item h1 span:nth-child(3),
.mv-item h1 span:nth-child(5) {
  margin-top: 15px;
}

.mv-item h1 span:nth-child(5) {
  font-size: 48px;
}

.mv-item p {
  font-size: 28px;
  font-weight: 700;
  color: #000;
}

/* problem */
.problem {
  background: #f2f2f2;
  padding-top: 55px;
  padding-bottom: 145px;
}

.problem__title {
  font-size: 40px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 40px;
}

.problem-list {
  width: 1200px;
  height: 194px;
  margin: 50px auto 0;
  display: flex;
  /* box-shadow: 0 5px 15px rgba(0,0,0,0.15); */
}

.problem-list + .problem-list {
  margin-top: 38px;
}

.problem-list__l {
  width: 600px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 40px;
  position: relative;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
  z-index: 1;
}

.problem-list__l::after {
  display: block;
  content: "";
  background: #fff;
  width: 40px;
  height: 58px;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  position: absolute;
  right: -39px;
  top: 0;
  bottom: 0;
  margin: auto 0;
}

.problem-list__l p {
  font-size: 32px;
  font-weight: 700;
}

.problem-list__l img {
  flex-shrink: 0;
  margin-right: 30px;
}

.problem-list__r {
  width: 600px;
  background: #5c5cbb;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 75px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
}

.problem-list__r p {
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.03em;
}

/* member */
.member {
  background: #f2f2f2;
  padding-bottom: 50px;
}

.member .section-title {
  font-size: 48px;
  font-weight: 700;
  text-align: center;
}

.member .section-title::after {
  display: block;
  content: "";
  width: 120px;
  height: 6px;
  background: #695191;
  margin: 30px auto 0;
}

#page-top .member .section-catch {
  font-size: 18px;
  text-align: center;
  font-weight: 700;
  margin-bottom: 10px;
}

#page-top .member .member-text {
  font-size: 30px;
  font-weight: 700;
  text-align: center;
  margin-top: 70px;
}

.member-merits {
  width: 1200px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin: 50px auto 0;
}

#page-top .merit-list {
  width: 380px;
  height: 140px;
  background: #018bd1;
  color: #fff;
  font-size: 30px;
  margin-bottom: 30px;
  text-align: center;
  line-height: 1.4;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.merit-list span {
  font-size: 20px;
}

/* account */
.account {
  background: #f2f2f2;
  padding-bottom: 145px;
}

.account-block {
  width: 1200px;
  margin: 0 auto;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 50px;
  margin-bottom: 75px;
  position: relative;
}

.account-block::after {
  display: block;
  content: "";
  width: 110px;
  height: 55px;
  background: #fff;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  position: absolute;
  bottom: -54px;
  left: 0;
  right: 0;
  margin: 0 auto;
}

#page-top .account-text h3 {
  font-size: 28px;
  line-height: 1.4;
  font-weight: 700;
  margin-bottom: 15px;
}

.account-text p {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.05em;
}

.account-images {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.account-head {
  font-size: 22px;
  color: #fff;
  font-weight: 700;
  line-height: 2.2;
  background: #5c5cbb;
  border-radius: 6px;
  width: 547px;
  text-align: center;
  position: relative;
  bottom: -25px;
}

#page-top .account-images ul {
  background: #d9d9ff;
  border-radius: 10px;
  width: 610px;
  height: 190px;
  padding: 40px 30px 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

#page-top .account-images ul li p {
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  margin-top: 5px;
}

.account-share {
  font-size: 32px;
  text-align: center;
  font-weight: 700;
}

/* recommend */

#page-top .recommend {
  position: relative;
  z-index: 1;
  background: #fff;
  padding: 70px 0;
}

#page-top .page-heading-1-wrapper {
  margin-bottom: 40px;
}

#page-top .page-heading-1 {
  font-size: 38px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
  color: #333;
}

#page-top .extra-nav {
  position: relative;
  z-index: 1;
  background: #fff;
}

#page-top .extra-nav .section-box-1 {
  display: flex;
  align-items: center;
}

#page-top .extra-nav .section-box-1 .box-item {
  flex: 0 1 50%;
  padding: 55px 0;
  height: 320px;
}

#page-top .extra-nav .section-box-1 .box-item.item-1 {
  background: url(../images/top_extra_nav_bg_1.jpg) no-repeat center
    center/cover;
}
#page-top .extra-nav .section-box-1 .box-item.item-2 {
  background: url(../images/top_extra_nav_bg_2.jpg) no-repeat center
    center/cover;
}

#page-top .extra-nav .section-box-1 .box-item .box-item-inner {
  height: 100%;
  color: #fff;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}

#page-top .extra-nav .section-box-1 .section-heading-1 {
  font-size: 30px;
  letter-spacing: 0.05em;
  text-shadow: 0 0 6px #000;
  margin-bottom: 20px;
  font-weight: 700;
}

#page-top .extra-nav .section-box-1 .section-text-1 {
  font-size: 16px;
  letter-spacing: 0.05em;
  text-shadow: 0 0 6px #000;
  margin-bottom: 20px;
  font-weight: 700;
}

#page-top .extra-nav .section-box-1 .section-more .btn-more {
  display: block;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #333;
  background: #fff;
  max-width: 300px;
  width: 240px;
  margin: auto;
  padding: 10px;
}

#page-top ul.slick-dots li {
  display: inline-block;
  margin: 0 5px;
}

#page-top #reason {
  padding-top: 110px;
}

@media screen and (max-width: 1600px) {
  #page-top .g-header .aside-wrapper {
    right: calc((50 / 1600) * 100vw);
  }
  #page-top .g-header .aside-wrapper .aside .aside-item-1 {
    margin-right: calc((30 / 1600) * 100vw);
  }
  .g-header .aside-wrapper .aside .aside-item-1 .btn-header:not(:last-of-type) {
    margin-right: calc((20 / 1600) * 100vw);
  }
  .g-header .aside-wrapper .aside .aside-item-1 .btn-header {
    font-size: 1vw;
    padding: 14px calc((30 / 1600) * 100vw);
  }
  .g-header .aside-wrapper .aside .aside-item-2 .tel {
    font-size: calc((30 / 1600) * 100vw);
    margin-right: calc((5 / 1600) * 100vw);
    margin-top: calc((4 / 1600) * 100vw);
  }
  .g-header .aside-wrapper .aside .aside-item-2 .tel img {
    width: calc((37 / 1600) * 100vw);
  }
}

@media only screen and (max-width: 599px) {
  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }

  .g-header .g-header__inner {
    padding: 12px;
  }

  .g-header .logo a img {
    width: 185px;
  }

  .g-header .logo .business {
    font-size: 15px;
    margin-left: 0.75em;
  }

  /* mv */
  .main-content__header .mv {
    background: url(../images/mv-sp.jpg) no-repeat top center/cover;
    height: 90vw;
    margin-top: 54px;
    padding-top: 110px;
    padding-left: 5vw;
    padding-right: 5vw;
    position: relative;
  }

  .main-content__header .mv::before {
    display: block;
    content: "";
    background: url(../images/mv-bg-l.png) no-repeat bottom right/auto
      calc((93 / 750) * 100vw);
    width: 100%;
    height: calc((93 / 750) * 100vw);
    position: absolute;
    bottom: 0;
    left: -50%;
  }

  .main-content__header .mv::after {
    display: block;
    content: "";
    background: url(../images/mv-bg-r.png) no-repeat bottom left/auto
      calc((93 / 750) * 100vw);
    width: 100%;
    height: calc((93 / 750) * 100vw);
    position: absolute;
    bottom: 0;
    right: -50%;
  }

  .mv-inner {
    justify-content: flex-start;
  }

  #page-top .mv-item h1 {
    font-size: calc((54 / 750) * 100vw);
    font-weight: 700;
    color: #fff;
    margin-bottom: calc((40 / 750) * 100vw);
    line-height: 1;
  }

  .mv-item h1 span {
    display: inline-block;
    background: #0989cd;
    font-size: calc((70 / 750) * 100vw);
    font-weight: 600;
    padding: 0.2em;
    line-height: 1;
  }

  .mv-item h1 span:first-child,
  .mv-item h1 span:nth-child(3) {
    font-family: "Barlow", sans-serif;
  }

  .mv-item h1 span:nth-child(3),
  .mv-item h1 span:nth-child(5) {
    margin-top: calc((20 / 750) * 100vw);
  }

  .mv-item h1 span:nth-child(5) {
    font-size: calc((60 / 750) * 100vw);
  }

  .mv-item p {
    font-size: calc((38 / 750) * 100vw);
    font-weight: 700;
    color: #fff;
    text-shadow: 0 0 6px #000;
  }

  /* problem */
  .problem {
    background: #f2f2f2;
    padding-top: calc((55 / 750) * 100vw);
    padding-bottom: calc((145 / 750) * 100vw);
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .problem__title {
    font-size: calc((40 / 750) * 100vw);
    font-weight: 700;
    text-align: center;
  }

  .problem-list {
    width: 100%;
    height: auto;
    margin: 10vw auto 0;
    display: flex;
    flex-direction: column;
  }

  .problem-list + .problem-list {
    margin-top: calc((38 / 750) * 100vw);
  }

  .problem-list__l {
    width: 100%;
    height: 30vw;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 5vw;
    position: relative;
  }

  .problem-list__l::after {
    display: block;
    content: "";
    background: #fff;
    width: calc((58 / 750) * 100vw);
    height: calc((40 / 750) * 100vw);
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    position: absolute;
    right: 0;
    left: 0;
    top: unset;
    bottom: calc((-39 / 750) * 100vw);
    margin: 0 auto;
  }

  .problem-list__l p {
    font-size: calc((32 / 750) * 100vw);
    font-weight: 700;
  }

  .problem-list__l img {
    width: 25vw;
    flex-shrink: 0;
    margin-right: calc((30 / 750) * 100vw);
  }

  .problem-list__r {
    width: 100%;
    height: auto;
    background: #5c5cbb;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 1em;
    padding-top: calc((50 / 750) * 100vw);
  }

  .problem-list__r p {
    color: #fff;
    font-size: calc((28 / 750) * 100vw);
    font-weight: 700;
    line-height: 1.8;
    letter-spacing: 0.03em;
  }

  /* member */
  .member {
    background: #f2f2f2;
    padding: 0 5vw calc((50 / 750) * 100vw);
  }

  .member .section-title {
    font-size: calc((48 / 750) * 100vw);
    font-weight: 700;
    text-align: center;
  }

  .member .section-title::after {
    display: block;
    content: "";
    width: calc((120 / 750) * 100vw);
    height: calc((6 / 750) * 100vw);
    background: #695191;
    margin: calc((30 / 750) * 100vw) auto 0;
  }

  #page-top .member .section-catch {
    font-size: calc((24 / 750) * 100vw);
    text-align: center;
    font-weight: 700;
    margin-bottom: 10px;
  }

  #page-top .member .member-text {
    font-size: calc((30 / 750) * 100vw);
    font-weight: 700;
    text-align: center;
    margin-top: calc((70 / 750) * 100vw);
  }

  .member-merits {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: calc((50 / 750) * 100vw) auto 0;
  }

  #page-top .merit-list {
    width: 48%;
    height: 22vw;
    background: #018bd1;
    color: #fff;
    font-size: calc((32 / 750) * 100vw);
    margin-bottom: calc((30 / 750) * 100vw);
    padding: 0.5em;
    text-align: center;
    line-height: 1.5;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
  }

  .merit-list span {
    font-size: calc((26 / 750) * 100vw);
  }

  /* account */
  .account {
    background: #f2f2f2;
    padding: 0 5vw calc((145 / 750) * 100vw);
  }

  .account-block {
    width: 100%;
    margin: 0 auto;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: column;
    padding: 10vw 5vw;
    margin-bottom: calc((75 / 750) * 100vw);
    position: relative;
  }

  .account-block::after {
    display: block;
    content: "";
    width: calc((110 / 750) * 100vw);
    height: calc((55 / 750) * 100vw);
    background: #fff;
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    position: absolute;
    bottom: calc((-54 / 750) * 100vw);
    left: 0;
    right: 0;
    margin: 0 auto;
  }

  #page-top .account-text h3 {
    font-size: calc((34 / 750) * 100vw);
    line-height: 1.4;
    font-weight: 700;
    text-align: center;
    margin-bottom: calc((15 / 750) * 100vw);
  }

  .account-text p {
    font-size: calc((28 / 750) * 100vw);
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.05em;
  }

  .account-images {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    margin-top: 5vw;
  }

  .account-head {
    font-size: calc((28 / 750) * 100vw);
    color: #fff;
    font-weight: 700;
    line-height: 2.2;
    background: #5c5cbb;
    border-radius: 6px;
    width: 80%;
    text-align: center;
    position: relative;
    bottom: calc((-28 / 750) * 100vw);
  }

  #page-top .account-images ul {
    background: #d9d9ff;
    border-radius: 10px;
    width: 100%;
    height: auto;
    padding: 8vw 3vw 3vw;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
  }

  #page-top .account-images ul li {
    width: 20vw;
    margin: 2vw;
  }

  #page-top .account-images ul li img {
    width: 100%;
    height: auto;
  }

  #page-top .account-images ul li p {
    font-size: calc((20 / 750) * 100vw);
    font-weight: 700;
    text-align: center;
    margin-top: 5px;
  }

  .account-share {
    font-size: calc((32 / 750) * 100vw);
    text-align: center;
    font-weight: 700;
  }

  .main-content__body.about .section .section-title {
    font-size: calc((48 / 750) * 100vw);
    font-weight: 700;
    text-align: center;
  }

  .main-content__body.about .section .section-title::after {
    display: block;
    content: "";
    width: calc((120 / 750) * 100vw);
    height: calc((6 / 750) * 100vw);
    background: #fff;
    margin: calc((30 / 750) * 100vw) auto 0;
  }

  .main-content__body.about .section .section-catch {
    font-size: calc((24 / 750) * 100vw);
    text-align: center;
    font-weight: 700;
    position: relative;
    top: calc((-160 / 750) * 100vw);
  }

  #howtouse .item-wrap {
    margin-top: 20px;
  }

  #page-top #reason {
    padding-top: 0;
  }

  /* recommend */
  #page-top .recommend {
    position: relative;
    z-index: 1;
    background: #fff;
    padding: calc((70 / 750) * 100vw) 0;
  }

  #page-top .page-heading-1-wrapper {
    margin-bottom: 40px;
  }

  #page-top .page-heading-1 {
    font-size: calc((38 / 750) * 100vw);
    font-weight: 700;
    letter-spacing: 0.05em;
    text-align: center;
    color: #333;
  }

  #page-top .extra-nav .section-box-1 {
    flex-direction: column;
  }

  #page-top .extra-nav .section-box-1 .box-item {
    width: 100%;
    padding: 10vw 5vw;
    height: auto;
  }

  #page-top .extra-nav .section-box-1 .section-heading-1 {
    font-size: calc((38 / 750) * 100vw);
    margin-bottom: calc((20 / 750) * 100vw);
  }

  #page-top .extra-nav .section-box-1 .section-text-1 {
    font-size: calc((28 / 750) * 100vw);
    margin-bottom: calc((30 / 750) * 100vw);
  }

  #page-top .extra-nav .section-box-1 .section-more .btn-more {
    display: block;
    font-size: calc((28 / 750) * 100vw);
    width: 70vw;
    margin: auto;
    padding: 3vw;
  }
}

.aniFadeIn {
  opacity: 0;
  transition: opacity 2s, transform 2s;
}

.aniFadeIn.doAniFadeIn {
  opacity: 1;
  transform: translate(0) !important;
}

#page-top #business-totop .smoothScroll .icon-arrow {
  color: #fff;
}

#page-top .rb2019---update {
  padding: 0.5em;
}

.manga-image {
  width: 1200px;
  margin: 70px auto;
}

.manga-image .manga-inner > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#page-top .manga-image .manga-inner .manga-note {
  font-size: 10px;
  line-height: 1.6;
  margin-top: 30px;
}

#page-top .register-btn {
  width: 400px;
  height: 70px;
  border-radius: 40px;
  background: url(../images/btn-icon.png) no-repeat center right 20px/15px auto;
  background-color: #000;
  color: #fff !important;
  font-size: 20px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 50px auto 0;
}

@media only screen and (max-width: 599px) {
  .manga-image {
    width: 100%;
    margin: 8vw auto 0;
  }

  .manga-image .manga-inner > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: column-reverse;
  }

  .manga-image .manga-inner > div img {
    width: 100%;
    height: auto;
  }

  .manga-image .manga-inner > div img + img {
    margin-bottom: 3vw;
  }

  #page-top .manga-image .manga-inner .manga-note {
    font-size: 4.5vw;
    line-height: 1.6;
    margin-top: 3vw;
    transform: scale(0.5);
    transform-origin: left top;
    width: 200%;
    height: 35vw;
  }

  #page-top .register-btn {
    width: 70vw;
    height: 12vw;
    border-radius: 40px;
    background: url(../images/btn-icon.png) no-repeat center right 20px/2.6vw
      auto;
    background-color: #000;
    color: #fff !important;
    font-size: 3.2vw;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 6vw auto 0;
  }
}
