@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, p, blockquote, em, h5, h6, pre, abbr, address, cite, code, del, dfn, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 62.5%;
  vertical-align: baseline;
  background: transparent;
  font-family: "Montserrat", "Noto Sans JP", sans-serif;
  box-sizing: border-box;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

button {
  outline: none;
  padding: 0;
  border: 0;
  background-color: transparent;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

ul, ol, li {
  list-style: none;
}

input, textarea {
  border: none;
  outline: none;
}

img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.l-body {
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}

.main {
  padding-top: 61px;
}

.c-head {
  color: #FFF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  letter-spacing: 1.5px;
  margin-bottom: 16px;
}

.c-text {
  color: #FFF;
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.8px;
}

.card {
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: center;
  margin-top: 28px;
}
.card:nth-of-type(1) {
  margin-top: 0;
}
.card__head {
  padding: 14px 38px;
  border-radius: 10px;
  border: 2px solid;
  -o-border-image: linear-gradient(to left, rgb(255, 206, 31), rgb(255, 89, 89)) 1;
     border-image: linear-gradient(to left, rgb(255, 206, 31), rgb(255, 89, 89)) 1;
  background: #FFF;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  margin-top: -47.5px;
}
.card__head h4 {
  text-align: center;
  font-size: 24px;
  font-style: normal;
  font-weight: 900;
  line-height: 30px; /* 125% */
  background: linear-gradient(266deg, #FFCE1F 3.82%, #FF5959 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.concept {
  padding: 75px 15px 28px 15px;
  background-color: #333;
}
.concept__head p {
  color: #8C8C8C;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.concept__title h2 {
  margin-top: 25px;
  color: #FFF;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.concept__text {
  color: #F2F2F2;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 178.571% */
  letter-spacing: 0.7px;
  margin-top: 25px;
}
.concept__cta {
  margin-top: 41px;
}
.concept__cta a {
  display: block;
  width: 100%;
  height: auto;
}
.concept__cta a img {
  width: 100%;
  height: auto;
}

.contact {
  width: 100%;
  position: relative;
}
.contact__bg {
  background-image: url("../image/contact-bg-min.png");
  text-align: center;
  position: relative;
  padding: 18px 0 23px 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
  z-index: 1;
}
.contact__bg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(22, 22, 22, 0.6);
  z-index: 2;
}
.contact__inner {
  padding: 0 10px;
  position: relative;
  z-index: 3;
}
.contact__button {
  width: 252px;
  max-width: 252px !important;
  height: 61px;
  background-color: #FF6868;
  border-radius: 10px;
  display: inline-block;
  cursor: pointer;
}
.contact__button a {
  color: #fff;
  font-style: normal;
  font-weight: 400;
  font-size: 16px;
  line-height: 61px;
  text-align: center;
  display: block;
  height: 100%;
  cursor: pointer;
  display: flex;
  justify-content: space-around;
  align-items: center;
}
.contact__button a img {
  width: 15px;
  height: auto;
}
.contact__desc {
  text-align: center;
  margin: 31px auto 0;
}
.contact__desc p {
  font-style: normal;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  color: #FFFFFF;
}

.cta {
  margin: 60px auto 15px auto;
  min-width: 290px;
  max-width: 328px;
  box-sizing: border-box;
  position: relative;
  z-index: 9;
}
.cta--dual {
  margin-top: 20px;
  margin-bottom: 30px;
}
.cta--target {
  max-width: 100%;
}
.cta__inner {
  display: flex;
  justify-content: center;
  width: 100%;
}
.cta__inner > a {
  display: block;
  cursor: pointer;
  width: 100%;
  position: relative;
  box-shadow: 6px 5px 5px -5px #333;
}
.cta__btn {
  width: 100%;
  max-width: 710px;
  margin: 0 auto;
  padding: 10px 5px 5px 0;
  background-color: #FF5959;
  border-radius: 3px;
  cursor: pointer;
  position: relative;
  box-shadow: 0 5px 0 #B54949;
  transition: 0.3s;
}
.cta__btn:hover {
  transform: translateY(3px);
  text-decoration: none;
  box-shadow: 0 2px 0 #B54949;
}
.cta__btn img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.cta__btn--dual {
  padding-left: 5px;
}
.cta__btn:hover .cta__outer {
  opacity: 0.7;
}
.cta__btn:hover {
  transform: translateY(2px);
  border-bottom: none;
}
.cta__topic {
  position: absolute;
  top: -5px;
  left: -10px;
  width: 60px;
  height: auto;
  animation: fuwafuwa 1.5s infinite;
  z-index: 5;
}
.cta__topic img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.cta__outer {
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
}
.cta__outer h2 {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.16em;
  color: #FFFFFF;
}
.cta__outer h2 div {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.5;
  text-align: left;
  letter-spacing: 0.16em;
  color: #FFFFFF;
}
.cta__outer span {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.16em;
  color: #FFFFFF;
}
.cta__outer img {
  width: 11px;
  height: 11px;
  -o-object-fit: cover;
     object-fit: cover;
}
.cta__outer--dual {
  justify-content: center;
}
.cta__outer--dual h2 {
  text-align: left;
}

@keyframes fuwafuwa {
  0% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0px);
  }
}
.flow__title {
  background: url(../image/flow-bg-min.png) center top/cover no-repeat padding-box;
  padding: 51px 0 44px 0;
  text-align: center;
}
.flow__list {
  background-color: #333;
  padding: 62px 15px 94px 15px;
  counter-reset: number 0;
}
.flow__item {
  margin-top: 105px;
  position: relative;
}
.flow__item:last-of-type::after {
  display: none;
}
.flow__item::after {
  content: "";
  position: absolute;
  bottom: -56px;
  left: 50%;
  transform: translateX(-50%);
  width: 38px;
  height: 14px;
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
          clip-path: polygon(50% 100%, 0 0, 100% 0);
  background-color: #d9d9d9;
}
.flow__item:nth-of-type(1) {
  margin-top: 0;
}
.flow__thum {
  width: 90%;
  margin: 0 0 0 auto;
  position: relative;
}
.flow__thum::after {
  counter-increment: number 1;
  content: "0" counter(number) " ";
  color: #FFCE1F;
  font-family: Inter;
  font-size: 80px;
  font-style: italic;
  font-weight: 500;
  line-height: normal;
  position: absolute;
  bottom: -60px;
  left: -50px;
}
.flow__head {
  margin-top: 48px;
}
.flow__head h3 {
  color: #FFCE1F;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
.flow__desc {
  margin-top: 20px;
}
.flow__desc p {
  color: #FFF;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.flow__cta {
  margin-top: 27px;
}
.flow__cta > ul {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.flow__btn {
  margin-top: 12px;
  width: 70%;
  min-width: 240px;
  padding: 0;
}
.flow__btn:nth-of-type(1) {
  margin-top: 0;
}
.flow__btn a.cta__outer {
  padding: 15px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  border-radius: 10px;
  background-color: #ff5959;
}
.flow__btn a.cta__outer img {
  width: 30px;
  height: auto;
}
.flow__btn a.cta__outer p {
  margin-left: 14px;
  color: #FFF;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

.fv {
  width: 100%;
  height: 573px;
  position: relative;
  z-index: 2;
}
.fv__bg {
  background: url(../image/fv-bg-min.png) center top/cover no-repeat padding-box;
  height: 100%;
  position: relative;
  z-index: -2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.fv__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(28deg, rgba(0, 0, 0, 0.6) 19.54%, rgba(158, 134, 51, 0.3) 81.66%);
  z-index: -1;
}
.fv__money {
  position: absolute;
  top: 156px;
  right: 18px;
}
.fv__money::before {
  content: "";
  position: absolute;
  top: 5px;
  right: 4px;
  width: 144px;
  height: 43px;
  background-color: #FF6868;
  -webkit-clip-path: polygon(8% 0%, 100% 0%, 92% 100%, 0% 100%);
          clip-path: polygon(8% 0%, 100% 0%, 92% 100%, 0% 100%);
}
.fv__money > div {
  background-color: #fff;
  padding: 3px 19px;
  -webkit-clip-path: polygon(8% 0%, 100% 0%, 92% 100%, 0% 100%);
          clip-path: polygon(8% 0%, 100% 0%, 92% 100%, 0% 100%);
}
.fv__money span {
  font-family: DIN Alternate;
  font-size: 32px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  background: linear-gradient(94deg, #FFE794 1.23%, #F2D15E 48.75%, #DBAB00 96.26%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.fv__title {
  color: #FFF;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: bold;
  line-height: normal;
  margin-left: 15px;
}
.fv__title .u-gold {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 32px;
  font-style: normal;
  font-weight: bold;
  line-height: normal;
  position: relative;
}
.fv__title .u-gold::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-color: #333;
  width: 148px;
  height: 44px;
  z-index: -1;
}
.fv__title .u-gold > span {
  background-color: #fff;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: bold;
  line-height: normal;
}
.fv__list {
  margin-top: 34px;
  padding: 0 15px;
  display: flex;
  justify-content: space-between;
}
.fv__item {
  width: 100px;
  height: 100px;
  background-color: rgba(216, 112, 173, 0.8);
  border: 2px solid #fff;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  box-shadow: 0 3px 8px 1px rgba(255, 255, 255, 0.25);
}
.fv__item .u-gold {
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  position: relative;
}
.fv__item .u-gold--big {
  font-size: 30px;
}
.fv__item .u-gold > span {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  color: #fff;
  -webkit-text-fill-color: currentcolor;
  width: auto;
  white-space: nowrap;
}
.fv__coupon {
  margin-bottom: -18px;
  width: 267px;
  align-self: center;
}
.fv__coupon a {
  width: 100%;
  height: auto;
  display: block;
}
.fv__coupon img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

.header {
  width: 100%;
  background-color: #fff;
  padding: 8px 16px;
  position: fixed;
  z-index: 99;
  max-width: 500px;
}
.header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header__text {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  font-style: normal;
  font-weight: 400;
  line-height: 14px;
}
.header__phone {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 700;
  line-height: 14px;
}
.header__cta {
  border-radius: 10px;
  background: #FF6B6B;
  box-shadow: 2px 3px 4px 1px rgba(0, 0, 0, 0.25);
  padding: 6px 18px;
}
.header__button {
  color: #FFF;
  text-align: center;
  font-family: Tahoma;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 15px;
  letter-spacing: 0.7px;
  position: relative;
  transition: all 0.2s ease;
}

.plan {
  padding-bottom: 167px;
  background-color: #f2f2f2;
}
.plan__title {
  background-color: #333;
  text-align: center;
  padding: 41px 0 37px 0;
}
.plan__text {
  margin-top: 53px;
  text-align: center;
}
.plan__text p {
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.plan__table {
  margin-top: 71px;
  padding: 0 15px;
}

.ques__title {
  padding: 43px 0 35px 0;
  background-color: #333;
  text-align: center;
}
.ques__ques {
  position: relative;
  width: 23px;
  height: 23px;
  background-color: #fff;
  border-radius: 50%;
  z-index: 1;
}
.ques__ques::before {
  content: "Q";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-style: normal;
  font-weight: 500;
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
  color: #FFCE1F;
  z-index: 2;
}
.ques__ans {
  position: relative;
  width: 23px;
  height: 23px;
  background-color: #ffa621;
  border-radius: 50%;
  z-index: 1;
}
.ques__ans::before {
  content: "A";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-style: normal;
  font-weight: 500;
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
  color: #Fff;
  z-index: 2;
}
.ques__head h3 {
  color: #333;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
.ques__list {
  padding: 68px 15px 81px;
}

/*アコーディオン全体*/
.accordion-area {
  width: 100%;
  max-width: 870px;
  margin-top: 20px;
}
.accordion-area section {
  transition: all 0.5s ease;
}

.accordion-area li {
  margin: 15px 0;
}
.accordion-area li:first-of-type {
  margin-top: 0;
}

/*アコーディオンタイトル*/
.title {
  position: relative; /*+マークの位置基準とするためrelative指定*/
  cursor: pointer;
  font-size: 1rem;
  font-weight: normal;
  padding: 8px 10px;
  transition: all 0.5s ease;
  background-color: #333;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.title > div {
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  color: #fff;
  display: block;
  width: calc(100% - 56px);
}
.title > div .u-inline {
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  color: #fff;
}

/*アイコンの＋と×*/
.icon {
  position: relative;
  width: 23px;
  height: 23px;
  background-color: #ffa621;
  border-radius: 50%;
}

.icon::before,
.icon::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 2px;
  background-color: #fff;
  transition: all 0.5s ease;
}

.icon::before {
  top: 48%;
  left: 4px;
  transform: rotate(0deg);
}

.icon::after {
  top: 48%;
  left: 4px;
  transform: rotate(90deg);
}

/*　closeというクラスがついたら形状変化　*/
.title.close > .icon::before {
  transform: rotate(45deg);
}

.title.close > .icon::after {
  transform: rotate(-45deg);
}

.title.close {
  transition: all 0.5s ease;
}

/*アコーディオンで現れるエリア*/
.box {
  display: none; /*はじめは非表示*/
  background: #fff;
  margin: 13px 0 0 10px;
  padding-bottom: 15px;
}
.box > p {
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  color: #333333;
  margin-left: 5px;
  display: block;
  width: calc(100% - 28px);
}
.box > p .u-inline {
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  color: #333333;
}

.title.close + .box {
  display: flex;
}

.resolution {
  padding: 89px 15px 38px 15px;
}
.resolution__title {
  color: #333;
  text-align: center;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.resolution__title--yellow {
  background-color: #FFCE1F;
}
.resolution__title--red {
  color: #FF5959;
}
.resolution__img {
  width: 224px;
  height: auto;
  margin: 24px auto 0 auto;
}
.resolution__graph {
  margin-top: 56px;
}
.resolution__desc {
  margin: 92px auto 0 auto;
  background-color: #F2f2f2;
  border-radius: 10px;
  position: relative;
  padding: 27px 40px 14px 40px;
}
.resolution__desc::before {
  content: "";
  position: absolute;
  width: 36px;
  height: 36px;
  top: -18px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #FFCE1F;
  border-radius: 50%;
}
.resolution__desc > h3 {
  color: #333;
  text-align: center;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 1px;
}
.resolution__desc--red {
  color: #FFF;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 1px;
  background-color: #FF5959;
  padding-left: 3px;
}
.resolution__overlay {
  margin-top: 53px;
}
.resolution__subtitle {
  margin: 49px auto 0 auto;
  width: 95%;
  background-color: #8C8C8C;
  border-radius: 10px;
  padding: 20px 39px 13px 15px;
}
.resolution__subtitle h3 {
  color: #FFF;
  font-size: 20px;
  font-style: normal;
  font-weight: 900;
  line-height: normal;
  letter-spacing: 1px;
}
.resolution__subtitle p {
  color: #F2F2F2;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.8px;
  margin-top: 13px;
}

.strength {
  padding-bottom: 28px;
  background-color: #f2f2f2;
}
.strength__title {
  width: 100%;
  padding: 56px 16px 48px 16px;
  background-color: #333;
  text-align: center;
}
.strength__list {
  padding: 32px 15px 0 15px;
  counter-reset: number 0;
}
.strength__item {
  margin-top: 56px;
}
.strength__item a:hover {
  opacity: 0.7;
}
.strength__item:nth-of-type(1) {
  margin-top: 0;
}
.strength__item::before {
  counter-increment: number 1;
  content: "0" counter(number) " ";
  color: #8C8C8C;
  text-align: center;
  font-family: Montserrat;
  font-size: 64px;
  font-style: italic;
  font-weight: 300;
  line-height: normal;
  letter-spacing: 3.2px;
  display: block;
}
.strength__head p {
  color: #FF5959;
  font-family: Noto Sans JP;
  font-size: 16px;
  font-style: normal;
  font-weight: 350;
  line-height: 30px; /* 187.5% */
  text-align: center;
}
.strength__head h3, .strength__head small {
  color: #FFA621;
  text-align: center;
  font-size: 26px;
  font-style: normal;
  font-weight: 900;
  line-height: 40px; /* 153.846% */
}
.strength__head .small {
  font-size: 18px;
}
.strength__line {
  position: relative;
}
.strength__line::before, .strength__line::after {
  content: "";
  position: absolute;
  width: 19px;
  height: 1px;
  background-color: #8c8c8c;
  top: 2px;
  left: -18px;
  transform: rotate(65deg);
}
.strength__line::after {
  left: -24px;
  transform: rotate(65deg);
}
.strength__line--after::before, .strength__line--after::after {
  transform: rotate(-65deg);
  left: auto;
  right: -18px;
}
.strength__line--after::after {
  left: auto;
  right: -24px;
  transform: rotate(-65deg);
}
.strength__thum {
  width: 95%;
  margin: 34px 0 0 auto;
  position: relative;
}
.strength__attention {
  background-color: #fff;
  padding: 17px 12px;
  position: relative;
  margin-top: -60px;
  display: inline-block;
}
.strength__attention p {
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25% */
}
.strength__text {
  color: #333;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25%*/
  margin-top: 35px;
}
.strength__text--red {
  color: #ff5959;
}
.strength__chat {
  margin-top: 31px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.strength__ballon {
  padding: 14px;
  background-color: #fff;
  border-radius: 10px;
  position: relative;
}
.strength__ballon::after {
  position: absolute;
  content: "";
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 15px solid transparent;
  border-top: 15px solid #fff;
  width: 0;
  height: 0;
}
.strength__ballon p {
  color: #8C8C8C;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25% */
  letter-spacing: 0.8px;
}
.strength__ballon .yellow {
  color: #ffa621;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25% */
  letter-spacing: 0.8px;
}
.strength__avator {
  width: 100px;
  margin-top: 40px;
}
.strength__text-wrap {
  margin-top: 30px;
}
.strength__text-wrap p {
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 30px; /* 187.5% */
}
.strength__subtext {
  margin-top: 43px;
}
.strength__subtext p {
  color: #333;
  text-align: center;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.strength__img {
  margin-top: 48px;
}

#scroll {
  scroll-behavior: smooth;
}

.table__concentration {
  width: 100%;
}
.table__concentration > div {
  overflow-x: scroll;
}
.table__concentration table {
  min-width: 400px;
}
.table__comparison {
  width: 100%;
}
.table__comparison > div {
  overflow-x: scroll;
}
.table__comparison table {
  min-width: 729px;
}
.table__comparison tr:first-of-type > td:first-of-type {
  background-color: transparent;
}
.table__comparison tr:first-of-type th {
  border-radius: 10px 10px 0px 0px;
}
.table__comparison tr:first-of-type > th:first-of-type {
  background: linear-gradient(266deg, #FFCE1F 3.82%, #FF5959 100%);
}
.table__comparison .red {
  color: #FF5959;
}
.table__head {
  margin-top: 36px;
}
.table__head:first-of-type {
  margin-top: 0;
}
.table__head h3 {
  color: #333;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.table__head table {
  margin-top: 25px;
  width: 100%;
  border-collapse: inherit;
  border-spacing: 2px;
}
.table table, .table td, .table th {
  border: none;
  border-collapse: collapse;
}
.table td, .table th {
  padding: 9px;
  text-align: center;
  vertical-align: middle;
  color: #333;
  background-color: #fff;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}
.table th {
  background: #333;
  color: #fff;
}

.trainer {
  padding: 60px 15px 124px 15px;
}
.trainer__title {
  text-align: center;
}
.trainer .c-head, .trainer .c-text {
  color: #333;
}
.trainer__list {
  margin-top: 61px;
}
.trainer__item {
  border-radius: 20px;
  background-color: #f2f2f2;
  padding: 21px 20px 25px 20px;
  max-width: 360px;
  margin: 34px auto 0;
}
.trainer__item:nth-of-type(1) {
  margin-top: 0;
}
.trainer__img {
  width: 167px;
  height: auto;
  border-radius: 20px;
}
.trainer__avator {
  margin: -84px 0 0 auto;
  text-align: right;
}
.trainer__wrap {
  border-radius: 3px;
  background: #FFCE1F;
  padding: 2px 6px;
  display: inline-block;
}
.trainer__wrap p {
  color: #FFF;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.trainer__name {
  margin-top: 8px;
}
.trainer__name h3 {
  color: #333;
  text-align: right;
  font-size: 40px;
  font-style: normal;
  font-weight: 900;
  line-height: normal;
  text-shadow: 1px 1px 0 #fff, -1px -1px 0 #fff, -1px -1px 0 #fff, 1px 1px 0 #fff;
}
.trainer__name p {
  color: #333;
  text-align: right;
  font-family: Futura;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.trainer__desc {
  margin-top: 10px;
}
.trainer__desc p {
  color: #8C8C8C;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.trainer__possession {
  display: flex;
  align-items: center;
  margin-top: 15px;
}
.trainer__possession > p {
  margin-left: 6px;
  color: #8C8C8C;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.trouble {
  padding: 27px 15px 38px 15px;
  background-color: #F2F2F2;
  position: relative;
}
.trouble__cta {
  width: 100%;
}
.trouble__cta a {
  display: block;
  width: 100%;
  height: auto;
}
.trouble__cta a img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.trouble__bot {
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  margin-top: 55px;
  padding: 0 50px;
}
.trouble__bot p {
  margin-left: 12px;
  color: #FFA621;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.trouble__bot-icon {
  width: 58px;
  height: 58px;
}
.trouble__bot-icon img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.trouble__list {
  margin-top: 42px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.trouble__list:nth-of-type(even) {
  justify-content: flex-end;
}
.trouble__item {
  padding: 10px 20px;
  color: #333;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: bold;
  line-height: normal;
  letter-spacing: 0.8px;
  background-color: #fff;
  display: inline-block;
  position: relative;
  width: 85%;
}
.trouble__item::after {
  position: absolute;
  content: "";
  top: 100%;
  left: 30px;
  border: 15px solid transparent;
  border-top: 15px solid #fff;
  width: 0;
  height: 0;
}
.trouble__item:nth-of-type(n+2) {
  margin-top: 19px;
}
.trouble__item:nth-of-type(2n) {
  align-self: flex-end;
}
.trouble__item:nth-of-type(2n)::after {
  right: 30px;
  left: auto;
}
.trouble__arrow {
  width: 100%;
  height: 48px;
  -webkit-clip-path: polygon(50% 0, 0 100%, 100% 100%);
          clip-path: polygon(50% 0, 0 100%, 100% 100%);
  position: absolute;
  bottom: -48px;
  left: 0;
  transform: rotate(180deg);
  background-color: #F2F2F2;
}

.uniqueness__head p {
  margin-top: 44px;
  color: #333;
  text-align: center;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 30px; /* 150% */
}
.uniqueness__chat {
  display: flex;
  align-items: center;
  max-width: 380px;
  margin: 0 auto;
}
.uniqueness__chat img {
  width: 84px;
  height: 84px;
  -o-object-fit: cover;
     object-fit: cover;
}
.uniqueness__comment {
  padding: 8px 31px;
  background-color: #fff;
  position: relative;
  margin-left: 15px;
}
.uniqueness__comment p {
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 25px; /* 156.25% */
}
.uniqueness__comment::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -20px;
  transform: translateY(-50%);
  border: 10px solid transparent;
  border-right: 10px solid #fff;
}
.uniqueness__title {
  margin-top: 35px;
}
.uniqueness__title h4, .uniqueness__title .yellow, .uniqueness__title .red {
  color: #333;
  text-align: center;
  font-family: Noto Sans JP;
  font-size: 20px;
  font-style: normal;
  font-weight: 900;
  line-height: 40px; /* 200% */
}
.uniqueness__title .yellow {
  color: #ffa621;
}
.uniqueness__title .red {
  background-color: #FF5959;
  color: #FFf;
}
.uniqueness__img {
  margin: 48px auto 0 auto;
  width: 60%;
}
.uniqueness__subhead {
  margin-top: 30px;
}
.uniqueness__subhead p {
  color: #333;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 25px; /* 156.25% */
}
.uniqueness__text {
  margin-top: 20px;
}
.uniqueness__text p {
  color: #333;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 25px; /* 156.25% */
}

.voice {
  padding: 0 15px 50px 15px;
}
.voice__title {
  padding-top: 70px;
  text-align: center;
}
.voice__title .c-head, .voice__title .c-text {
  color: #333;
}
.voice__wrap {
  margin-top: 52px;
}
.voice__detail {
  display: flex;
  align-items: center;
}
.voice__detail > h3 {
  color: #333;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 25px; /* 125% */
}
.voice__detail > div {
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25% */
  margin-left: 10px;
}
.voice__period {
  margin-top: 10px;
}
.voice__period > div {
  color: #8C8C8C;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25% */
}
.voice__img {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  text-align: center;
}
.voice__img--before, .voice__img--after {
  width: 40%;
}
.voice__img--after {
  position: relative;
}
.voice__img--after span {
  background: linear-gradient(266deg, #FFCE1F 3.82%, #FF5959 100%);
}
.voice__img--after::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -45px;
  width: 19px;
  height: 23px;
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
          clip-path: polygon(0 0, 0 100%, 100% 50%);
  background-color: #d9d9d9;
}
.voice__img span {
  display: block;
  padding: 5px 25px;
  background-color: #333;
  color: #fff;
  border-radius: 0 0 10px 10px;
  text-align: center;
  font-family: Montserrat;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 25px; /* 156.25% */
  letter-spacing: 1.6px;
}
.voice__table {
  margin: 42px auto 0;
  width: 90%;
  text-align: center;
}
.voice__table table, .voice__table td, .voice__table th {
  border: none;
  border-collapse: collapse;
}
.voice__table td, .voice__table th {
  padding: 3px;
  width: 30%;
  height: 25px;
  vertical-align: middle;
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 25px; /* 156.25% */
}
.voice__table span {
  color: #FF5959;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 25px; /* 156.25% */
}
.voice__desc {
  margin-top: 50px;
}
.voice__desc p {
  color: #333;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 25px; /* 156.25% */
}

Default #graydisplay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 100% !important;
  height: 100%;
  background: rgba(0, 0, 0, 0.45);
}

#graydisplay img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  max-width: 90%;
  max-height: 90%;
  height: 90%;
}

#graydisplay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 100% !important;
  height: 100%;
  background: rgba(0, 0, 0, 0.45);
  z-index: 999;
}

#graydisplay img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  max-width: 90%;
  max-height: 90%;
  width: auto;
  height: 70%;
  -o-object-fit: cover;
     object-fit: cover;
}

.u-br::after {
  content: "\a";
  white-space: pre;
}

@media (min-width: 769px) {
  .u-br--pc::after {
    content: "\a";
    white-space: pre;
  }
}

.u-fade__left {
  transform: translateX(50px);
  opacity: 0;
}
.u-fade__left.is-active {
  transition: 1s;
  transform: translateX(0);
  opacity: 1;
}

.u-fade__left {
  transform: translateX(50px);
  opacity: 0;
}

.is-active .u-fade__left {
  transition: 1s;
  transform: translateX(0);
  opacity: 1;
}

.is-active .u-fade__left:nth-child(2) {
  transition-delay: 0.4s;
}

.is-active .u-fade__left:nth-child(3) {
  transition-delay: 0.8s;
}

.is-active .u-fade__left:nth-child(4) {
  transition-delay: 1.2s;
}

.is-active .u-fade__left:nth-child(5) {
  transition-delay: 1.6s;
}

.is-active .u-fade__left:nth-child(6) {
  transition-delay: 2s;
}

.u-fade__right {
  transform: translateX(-50px);
  opacity: 0;
}
.u-fade__right.is-active {
  transition: 1s;
  transform: translateX(0);
  opacity: 1;
}

.u-fade__right {
  transform: translateX(-50px);
  opacity: 0;
}

.is-active .u-fade__right {
  transition: 1s;
  transform: translateX(0);
  opacity: 1;
}

.is-active .u-fade__right:nth-child(2) {
  transition-delay: 0.4s;
}

.is-active .u-fade__right:nth-child(3) {
  transition-delay: 0.8s;
}

.is-active .u-fade__right:nth-child(4) {
  transition-delay: 1.2s;
}

.is-active .u-fade__right:nth-child(5) {
  transition-delay: 1.6s;
}

.is-active .u-fade__right:nth-child(6) {
  transition-delay: 2s;
}

.is-active .u-fade__right:nth-child(7) {
  transition-delay: 2.4s;
}

.is-active .u-fade__right:nth-child(8) {
  transition-delay: 2.8s;
}

.is-active .u-fade__right:nth-child(9) {
  transition-delay: 3.2s;
}

.is-active .u-fade__right:nth-child(10) {
  transition-delay: 3.6s;
}

.u-fade__up {
  transform: translateY(50px);
  opacity: 0;
}
.u-fade__up.is-active {
  transition: 0.6s;
  transform: translateY(0);
  opacity: 1;
}

.u-fade__up {
  transform: translateY(50px);
  opacity: 0;
}

.is-active .u-fade__up {
  transition: 0.6s;
  transform: translateY(0);
  opacity: 1;
}

.is-active .u-fade__up:nth-child(2) {
  transition-delay: 0.4s;
}

.is-active .u-fade__up:nth-child(3) {
  transition-delay: 0.8s;
}

.is-active .u-fade__up:nth-child(4) {
  transition-delay: 1.2s;
}

.is-active .u-fade__up:nth-child(5) {
  transition-delay: 1.6s;
}

.is-active .u-fade__up:nth-child(6) {
  transition-delay: 2s;
}

.is-active .u-fade__up:nth-child(7) {
  transition-delay: 2.4s;
}

.is-active .u-fade__up:nth-child(8) {
  transition-delay: 2.8s;
}

.is-active .u-fade__up:nth-child(9) {
  transition-delay: 3.2s;
}

.is-active .u-fade__up:nth-child(10) {
  transition-delay: 3.6s;
}

.u-gold {
  background: linear-gradient(90deg, #DBAB00 0%, #F2D15E 36.46%, #FFE794 50.72%, #F2D15E 69.79%, #DBAB00 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

.u-inline {
  display: inline-block;
}