@charset "UTF-8";
/*===========================================================================*/
/*  function  */
/*===========================================================================*/
/*===========================================================================*/
/*  common  */
/*===========================================================================*/
/*===========================================================================*/
/*  mixin  */
/*===========================================================================*/
html {
  font-family: "Noto Sans JP", sans-serif;
  color: #464343;
  font-feature-settings: "halt" on;
  font-size: 62.5%;
}

body {
  min-width: 375px;
}

main {
  position: relative;
  overflow: hidden;
  padding-top: 100px;
}
@media (max-width: 900px) {
  main {
    padding-top: 56px;
  }
}

span {
  display: inline-block;
}

picture {
  display: block;
}

figure img,
picture img {
  width: 100%;
}

img {
  height: auto;
  object-fit: contain;
}

a {
  display: inline-block;
}

@media screen and (min-width: 901px) {
  .hover-normal {
    transition: opacity 0.5s 0s cubic-bezier(0.44, 0.14, 0.09, 1.02);
  }
  .hover-normal:hover {
    opacity: 0.7;
  }
  .hover-underline {
    transition: all 0.5s 0s cubic-bezier(0.44, 0.14, 0.09, 1.02);
  }
  .hover-underline:hover {
    text-decoration: underline;
    opacity: 0.7;
  }
}
.pc-only {
  display: block;
}

.br-pc-only {
  display: inline-block;
}

.sp-only {
  display: none;
}

.br-sp-only {
  display: none;
}

@media screen and (max-width: 900px) {
  .pc-only {
    display: none;
  }
  .br-pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }
  .br-sp-only {
    display: inline-block;
  }
}
.text-center {
  text-align: center;
}

/*===========================================================================*/
/*  utility  */
/*===========================================================================*/
.u-en {
  font-family: "Inter", sans-serif;
}

.u-en2 {
  font-family: "Outfit", sans-serif;
}

/*===========================================================================*/
/*  component, color  */
/*===========================================================================*/
/* layout */
.l-wrapper {
  padding-left: 4.5rem;
  padding-right: 4.5rem;
}

.l-inner {
  margin: 0 auto;
  max-width: 1100px;
}

@media screen and (max-width: 900px) {
  .l-wrapper {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .l-inner {
    max-width: 500px;
  }
}
/*===========================================================================*/
/*  header  */
/*===========================================================================*/
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-right: 30px;
  z-index: 10000;
  width: 100%;
  position: fixed;
}
.header.is-transparent {
  background-color: rgba(255, 255, 255, 0.7);
}
.header__logo {
  width: 275px;
  height: auto;
}
.header__logo img {
  width: 100%;
}
.header__link {
  display: inline-block;
  color: #fff;
  padding: 9px 60px 10px 50px;
  border-radius: 40px;
  text-decoration: none;
  position: relative;
  background-image: url(../images/icon_arrow-white.svg);
  background-color: #2864f0;
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 14px 12px;
}
.header__link span {
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 0.9px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 900px) {
  .header {
    padding: 2px 20px 3px 7px;
  }
  .header__logo {
    width: 140px;
    height: auto;
  }
  .header__link {
    display: inline-block;
    color: #fff;
    padding: 4px 35px 8px 20px;
    background-image: url(../images/icon_arrow-white.svg);
    background-position: right 15px center;
    background-size: 12px 10px;
  }
  .header__link span {
    color: #fff;
    font-size: 1.2rem;
    letter-spacing: 0.6px;
  }
}
/*===========================================================================*/
/*  mv  */
/*===========================================================================*/
.mv {
  padding-top: 30px;
  padding-bottom: 132px;
}
.mv__inner {
  max-width: 1160px;
  margin: 0 auto;
}
.mv__head {
  font-size: 5.6296rem;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 2.815px;
  border-bottom: 1px dashed #72849f;
  display: inline-block;
  position: relative;
  margin-bottom: 40px;
}
.mv__head::before {
  content: "";
  width: 134px;
  height: 134px;
  background: url(../images/mv_bird.png) no-repeat center center/contain;
  position: absolute;
  bottom: 29px;
  right: -122px;
}
.mv__head span {
  display: inline;
}
.mv__head span.mv__head__sub {
  display: block;
  line-height: 1;
  border: none;
}
.mv__head sup {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 1.1px;
}
.mv__head--sm {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 1.2px;
}
.mv__head--md {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 1.4px;
}
.mv__head--lg {
  color: #2864f0;
  font-size: 6.9807rem;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 3.49px;
}
.mv__content {
  display: flex;
  justify-content: space-between;
  gap: 4.224137931%;
  align-items: flex-start;
}
.mv__content__account {
  width: 43.1896551724%;
}
.mv__share {
  width: 136px;
  height: 169px;
  position: absolute;
  bottom: -35px;
  right: -60px;
  z-index: 10;
}
.mv .video-container {
  position: relative;
  width: 100%;
  max-width: 595px;
  line-height: 0;
}
.mv video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mv .video__wrapper {
  background-color: #fff;
  border-radius: 6.61px;
  border: 13.22px solid #fff;
  box-shadow: 0px 0px 0px 1.652px rgba(0, 0, 0, 0.2), 0px 0px 3.305px 0px rgba(0, 0, 0, 0.08), 0px 3.305px 9.915px 0px rgba(0, 0, 0, 0.1);
}
.mv .video-overlay {
  position: absolute;
  inset: 0;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10;
}
.mv .video-overlay img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
}
.mv .play-button {
  width: 60px;
  height: 60px;
  background: white;
  clip-path: polygon(30% 20%, 30% 80%, 80% 50%);
}
.mv__cloud > * {
  position: absolute;
  z-index: -1;
  overflow: hidden;
}
.mv__cloud1 {
  width: 338px;
  top: 135px;
  right: calc(50% + 490px);
}
.mv__cloud2 {
  width: 88px;
  top: 515px;
  right: calc(50% + 608px);
}
.mv__cloud3 {
  width: 126px;
  top: 721px;
  right: calc(50% + 644px);
}
.mv__cloud4 {
  width: 88px;
  top: 120px;
  left: calc(50% + 154px);
}
.mv__cloud5 {
  width: 149px;
  top: 180px;
  left: calc(50% + 475px);
}
.mv__cloud6 {
  width: 785px;
  top: 375px;
  left: calc(50% + 110px);
}
.mv__annotaion {
  font-size: 12px;
  font-weight: 400;
  line-height: 1.35;
  letter-spacing: 0.6px;
  max-width: 408px;
  margin: 0 auto;
}
.mv .lp-direct-sign-up-section {
  width: 43.1896551724%;
}
.mv .su_floating_container {
  border: none;
  width: auto;
  max-width: 501px;
  width: 100%;
  padding: 0;
  margin: 5px auto 27px;
}
.mv .floatingEmailSubmitBtn {
  background-color: #fa6414;
  border-color: #fa6414;
  max-width: 100%;
}
.mv .sign_up_notice {
  max-width: 408px;
  margin: 12px auto;
  justify-content: left;
}
.mv .su-google {
  width: 100%;
}

@media screen and (max-width: 900px) {
  .mv {
    padding: 20px 20px 24px;
  }
  .mv__inner {
    max-width: 500px;
    margin: 0 auto;
  }
  .mv__border {
    border-bottom: 1px dashed #72849f;
  }
  .mv__head {
    font-size: 3.8rem;
    line-height: 1.4;
    letter-spacing: 1.9px;
    margin-bottom: 39px;
  }
  .mv__head::before {
    content: "";
    width: 102px;
    height: 102px;
    background: url(../images/mv_bird.png) no-repeat center center/contain;
    position: absolute;
    top: 10px;
    bottom: auto;
    right: -20px;
  }
  .mv__head sup {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.742px;
  }
  .mv__head--sm {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.8px;
  }
  .mv__head--md {
    font-size: 1.9rem;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.95px;
  }
  .mv__head--lg {
    color: #2864f0;
    font-size: 4.6rem;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 2.35px;
  }
  .mv__share {
    width: 70px;
    bottom: -96px;
    right: -10px;
  }
  .mv__cloud > * {
    position: absolute;
    z-index: -1;
    overflow: hidden;
  }
  .mv__cloud1 {
    width: 113px;
    top: 60px;
    right: calc(50% + 72px);
  }
  .mv__cloud2 {
    width: 71px;
    top: 270px;
    right: calc(50% + 127px);
  }
  .mv__cloud3 {
    display: none;
  }
  .mv__cloud4 {
    width: 42px;
    top: 85px;
    left: calc(50% + 80px);
  }
  .mv__cloud5 {
    width: 60px;
    top: 220px;
    left: calc(50% + 137px);
  }
  .mv__cloud6 {
    width: 371px;
    top: 490px;
    left: calc(50% - 76px);
  }
  .mv__button.solution__button a {
    padding: 21px 54px 23px 27px;
  }
  .mv__button.solution__button a::before {
    content: "機能充実！" !important;
    width: auto;
  }
  .mv__annotation {
    font-size: 1rem;
    line-height: 1.35;
    letter-spacing: 0.5px;
    text-align: center;
    margin-top: 20px;
  }
  .mv .video__wrapper {
    border: 6.796px solid #fff;
    box-shadow: 0px 0px 0px 0.85px rgba(0, 0, 0, 0.2), 0px 0px 1.699px 0px rgba(0, 0, 0, 0.08), 0px 1.699px 5.097px 0px rgba(0, 0, 0, 0.1);
  }
}
/*===========================================================================*/
/*  reason  */
/*===========================================================================*/
.reason {
  padding-top: 0px;
  padding-bottom: 106px;
}
.reason__head {
  position: relative;
  z-index: 2;
  color: #2864f0;
  text-align: center;
  font-feature-settings: "palt" on, "liga" off;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 1.7px;
  padding: 8px 30px 9px 103px;
  border-radius: 10px;
  border: 1px solid #2864f0;
  background: #fff;
  z-index: 5;
}
.reason__head__wrapper {
  margin-left: auto;
  margin-right: auto;
  width: fit-content;
  position: relative;
  overflow: visible;
  padding-top: 10px;
}
.reason__head__wrapper img {
  width: 99px;
  height: 93px;
  position: absolute;
  left: 0;
  bottom: 1px;
  z-index: 20;
}
.reason .shadow-layer {
  content: "";
  position: absolute;
  left: 5px;
  bottom: -5px;
  width: 762px;
  height: 78px;
  border: 1px solid #2864f0;
  background: #ebf3ff;
  border-radius: 10px;
  z-index: 1;
}
.reason__items {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-top: 65px;
  position: relative;
}
.reason__items::before {
  content: "";
  width: 231px;
  height: 330px;
  background: url(../images/reason_decoration_l.svg) no-repeat center center/contain;
  position: absolute;
  right: calc(50% + 444px);
  bottom: 63px;
}
.reason__items::after {
  content: "";
  width: 233px;
  height: 335px;
  background: url(../images/reason_decoration_r.svg) no-repeat center center/contain;
  position: absolute;
  left: calc(50% + 448px);
  bottom: 32px;
}
.reason__item:nth-child(1) {
  width: 28.3636363636%;
}
.reason__item:nth-child(1) .reason__img {
  width: 100%;
  margin: 0 auto 46px;
}
.reason__item:nth-child(2) {
  padding-right: 2.2727272727%;
  padding-left: 2.2727272727%;
  border-right: 1px dashed #bebebe;
  border-left: 1px dashed #bebebe;
  width: 30.7272727273%;
  margin-left: 5.0909090909%;
  margin-right: 5.0909090909%;
}
.reason__item:nth-child(2) .reason__img {
  width: 100%;
  margin: 0 auto 25px;
  border-radius: 4px;
}
.reason__item:nth-child(3) {
  width: 23.0909090909%;
}
.reason__item:nth-child(3) .reason__img {
  width: 190px;
  margin: 0 auto 22px;
}
.reason__title {
  color: #2864f0;
  font-feature-settings: "palt" on, "liga" off;
  font-family: Inter;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 1.8px;
  margin-bottom: 14px;
  text-align: center;
}
.reason__title--sm {
  font-size: 2rem;
  display: block;
  margin-bottom: 9px;
}
.reason__title sup {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 1.1px;
  vertical-align: sub;
}
.reason__description {
  color: #2864f0;
  text-align: center;
  font-feature-settings: "palt" on, "liga" off;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.6px;
}

@media screen and (max-width: 900px) {
  .reason {
    padding-top: 45px;
    padding-bottom: 60px;
  }
  .reason__head {
    font-size: 2.2rem;
    line-height: 1.3;
    letter-spacing: 1.1px;
    padding: 9px 30px 11px 83px;
  }
  .reason__head__wrapper img {
    width: 79px;
    height: 75px;
    left: 5px;
    bottom: 0;
  }
  .reason .shadow-layer {
    width: 332px;
    height: 78px;
  }
  .reason__items {
    margin-top: 34px;
    flex-direction: column;
    align-items: center;
  }
  .reason__items::before {
    content: "";
    width: 43px;
    height: 375px;
    background: url(../images/reason_decoration_l_sp.svg) no-repeat center center/contain;
    position: absolute;
    left: -22px;
    right: auto;
    bottom: 20px;
  }
  .reason__items::after {
    content: "";
    width: 56px;
    height: 395px;
    background: url(../images/reason_decoration_r_sp.svg) no-repeat center center/contain;
    position: absolute;
    right: -16px;
    left: auto;
    bottom: 10px;
  }
  .reason__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 3.5820895522%;
  }
  .reason__item:nth-child(1) {
    width: 100%;
  }
  .reason__item:nth-child(1) .reason__img {
    width: 48.0597014925%;
    margin-bottom: 0;
  }
  .reason__item:nth-child(2) {
    width: 100%;
    padding-top: 15px;
    padding-bottom: 15px;
    border: none;
    border-top: 1px dashed #bebebe;
    border-bottom: 1px dashed #bebebe;
    margin-top: 30px;
    margin-bottom: 15px;
  }
  .reason__item:nth-child(2) .reason__img {
    width: 48.0597014925%;
    margin-bottom: 0;
  }
  .reason__item:nth-child(3) {
    width: 100%;
    padding-bottom: 15px;
    border-bottom: 1px dashed #bebebe;
  }
  .reason__item:nth-child(3) .reason__img {
    width: 31.6417910448%;
    margin-bottom: 0;
  }
  .reason__content {
    width: 48.3582089552%;
  }
  .reason__title {
    font-size: 2.2rem;
    line-height: 1;
    letter-spacing: 1px;
    margin-bottom: 10px;
  }
  .reason__title--sm {
    font-size: 1.4rem;
    letter-spacing: 0.7px;
    margin-bottom: 6px;
  }
  .reason__title sup {
    font-size: 1rem;
  }
  .reason__description {
    font-size: 1rem;
    line-height: 1.4;
    letter-spacing: 0.5px;
  }
}
/*===========================================================================*/
/*  table  */
/*===========================================================================*/
.plan {
  background-color: #ebf3ff;
}
.plan__inner {
  padding: 80px 0 100px;
}
@media (max-width: 900px) {
  .plan__inner {
    padding: 60px 0;
  }
}
.plan__title {
  margin-bottom: 50px;
  text-align: center;
}
@media (max-width: 900px) {
  .plan__title {
    margin-bottom: 30px;
  }
}
.plan__title h2 {
  color: #2864f0;
  font-size: 5.2rem;
  font-weight: 700;
  margin-bottom: 15px;
}
@media (max-width: 900px) {
  .plan__title h2 {
    font-size: 2.8rem;
    margin-bottom: 0;
  }
}
.plan__title h2 .num {
  font-size: 7.2rem;
  font-weight: 500;
}
@media (max-width: 900px) {
  .plan__title h2 .num {
    font-size: 5rem;
  }
}
.plan__title p {
  background-color: #2864f0;
  color: #fff;
  font-size: 2.8rem;
  font-weight: 700;
  margin: 0 auto 8px;
  padding: 8px 0;
  width: 254px;
  border-radius: 4px;
}
@media (max-width: 900px) {
  .plan__title p {
    font-size: 1.8rem;
    margin: 0 auto;
    width: 186px;
    line-height: 1;
  }
}
.plan__title img {
  width: 284px;
}
@media (max-width: 900px) {
  .plan__title img {
    width: 172px;
  }
}
.plan__subtitle {
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.7;
  margin-bottom: 20px;
  text-align: center;
}
@media (max-width: 900px) {
  .plan__subtitle {
    font-size: 2.2rem;
    margin-bottom: 15px;
  }
}
.plan__contents--inner {
  position: relative;
  height: 632px;
  transition: all 0.4s;
  overflow: hidden;
}
@media (max-width: 900px) {
  .plan__contents--inner {
    height: 806px;
  }
}
.plan__contents--inner::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  width: 100%;
  height: 75px;
  transition: all 0.4s;
  background: linear-gradient(rgba(235, 243, 255, 0) 0%, rgba(235, 243, 255, 0.8) 50%, #ebf3ff 100%);
}
.plan__contents--inner.is-open::before {
  display: none;
}
.plan__contents--button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  width: 426px;
  padding: 23px 0;
  background-color: #fff;
  color: #464343;
  font-size: 2rem;
  font-weight: 700;
  border: 1px solid #464343;
  margin-top: 40px;
  text-align: center;
  border-radius: 6px;
  cursor: pointer;
  z-index: 1;
  transition: all 0.4s;
}
@media (max-width: 900px) {
  .plan__contents--button {
    padding: 18px 0;
    font-size: 1.5rem;
    margin-top: 30px;
    width: 335px;
  }
}
.plan__contents--button::before, .plan__contents--button::after {
  content: "";
  position: absolute;
  background-color: #333;
  top: 50%;
  left: 24px;
  transform: translate(-50%, -50%);
  transition: all 0.4s ease;
}
@media (max-width: 900px) {
  .plan__contents--button::before, .plan__contents--button::after {
    left: 45px;
  }
}
.plan__contents--button::before {
  width: 16px;
  height: 3px;
}
@media (max-width: 900px) {
  .plan__contents--button::before {
    width: 12px;
    height: 2px;
  }
}
.plan__contents--button::after {
  width: 3px;
  height: 16px;
}
@media (max-width: 900px) {
  .plan__contents--button::after {
    width: 2px;
    height: 12px;
  }
}
.plan__contents--button.is-open::after {
  height: 0;
}
.plan__table {
  border-collapse: collapse;
  margin-bottom: 50px;
  width: 100%;
}
@media (max-width: 900px) {
  .plan__table {
    margin-bottom: 30px;
  }
}
.plan__table:last-of-type {
  margin-bottom: 10px;
}
.plan__table th,
.plan__table td {
  border: 1px solid #cecece;
  text-align: center;
}
.plan__table .empty {
  border: none;
}
.plan__table .blue {
  color: #2864f0;
}
.plan__table .plan__table--header {
  border-top: 8px solid #cecece;
  width: 25.64%;
}
@media (max-width: 900px) {
  .plan__table .plan__table--header {
    border-top: 6px solid #cecece;
    width: 33.33%;
  }
}
.plan__table .plan__table--header:not(.empty) {
  background-color: #fff;
}
.plan__table .plan__table--header.withButton {
  padding: 12px 0;
  border-top: none;
}
.plan__table .plan__table--header.popular {
  position: relative;
  border-top: 8px solid #2864f0;
}
.plan__table .plan__table--header.popular .baloon {
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #ffdb70;
  border-radius: 4px;
  max-width: 216px;
  width: 100%;
}
@media (max-width: 900px) {
  .plan__table .plan__table--header.popular .baloon {
    max-width: none;
    width: 128px;
  }
}
.plan__table .plan__table--header.popular .baloon__inner {
  position: relative;
  display: inline-block;
  text-align: center;
  padding: 7px 0;
}
.plan__table .plan__table--header.popular .baloon__inner::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 8px 6px 0 6px;
  border-color: #ffdb70 transparent transparent;
  translate: -50% 100%;
}
.plan__table .plan__table--header.popular .baloon__inner p {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  margin: 0;
}
@media (max-width: 900px) {
  .plan__table .plan__table--header.popular .baloon__inner p {
    font-size: 1rem;
  }
}
.plan__table--header {
  padding: 28px 8px;
}
@media (max-width: 900px) {
  .plan__table--header {
    padding: 25px 5px;
  }
}
.plan__table--header p {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.8;
}
@media (max-width: 900px) {
  .plan__table--header p {
    font-size: 1.6rem;
  }
}
.plan__table--header span {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 10px;
}
@media (max-width: 900px) {
  .plan__table--header span {
    font-size: 1rem;
    margin-top: 4px;
  }
}
.plan__table--header .button {
  display: block;
  background-color: #2864f0;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
  margin: 20px auto 0;
  padding: 6px 0;
  border-radius: 4px;
  max-width: 232px;
}
@media (max-width: 900px) {
  .plan__table--header .button {
    margin: 0 auto;
  }
}
.plan__table--body td {
  background-color: #fff;
  height: 82px;
  vertical-align: middle;
}
@media (max-width: 900px) {
  .plan__table--body td {
    height: 56px;
  }
}
.plan__table--body .feature {
  background-color: #f7f5f5;
  font-size: 1.8rem;
  font-weight: 700;
  padding-left: 25px;
  text-align: left;
}
@media (max-width: 900px) {
  .plan__table--body .feature {
    font-size: 1.6rem;
    padding: 0;
    text-align: center;
  }
}
.plan__table--body .price {
  height: 251px;
}
.plan__table--body .price--inner {
  display: flex;
  align-items: center;
}
.plan__table--body .price--detail {
  padding-right: 16px;
}
.plan__table--body .price--detail span {
  display: block;
  color: #aaa7a7;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 6px;
}
.plan__table--body .price--term {
  font-size: 1.4rem;
  flex: 1;
}
.plan__table--body .price--term .yearly,
.plan__table--body .price--term .monthly {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  padding: 0 12px;
}
.plan__table--body .price--term .yearly {
  height: 165px;
  border-bottom: 1px solid #cecece;
  border-left: 1px solid #cecece;
}
.plan__table--body .price--term .monthly {
  height: 86px;
  border-left: 1px solid #cecece;
}
.plan__table--body .yearly-plan {
  height: 165px;
}
@media (max-width: 900px) {
  .plan__table--body .yearly-plan {
    height: 111px;
  }
}
.plan__table--body .yearly-plan .first,
.plan__table--body .yearly-plan .second,
.plan__table--body .yearly-plan .third {
  display: block;
}
.plan__table--body .yearly-plan .first {
  font-size: 2rem;
  font-weight: 700;
}
@media (max-width: 900px) {
  .plan__table--body .yearly-plan .first {
    font-size: 1.2rem;
  }
}
.plan__table--body .yearly-plan .first .amount {
  font-size: 4.2rem;
  font-weight: 500;
}
@media (max-width: 900px) {
  .plan__table--body .yearly-plan .first .amount {
    font-size: 2.2rem;
  }
}
.plan__table--body .yearly-plan .second {
  font-size: 1.4rem;
  line-height: 1.5;
}
@media (max-width: 900px) {
  .plan__table--body .yearly-plan .second {
    font-size: 1.2rem;
  }
}
.plan__table--body .yearly-plan .third {
  font-size: 1.4rem;
  font-weight: 700;
}
@media (max-width: 900px) {
  .plan__table--body .yearly-plan .third {
    font-size: 1.2rem;
    margin-top: 8px;
  }
}
.plan__table--body .yearly-plan .third .amount {
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.5;
  margin-top: 5px;
}
@media (max-width: 900px) {
  .plan__table--body .yearly-plan .third .amount {
    font-size: 1.8rem;
    margin-top: 0;
  }
}
.plan__table--body .yearly-plan .third .text {
  font-size: 2rem;
}
.plan__table--body .monthly-plan {
  height: 86px;
  font-size: 1.6rem;
  font-weight: 700;
}
@media (max-width: 900px) {
  .plan__table--body .monthly-plan {
    height: 56px;
    font-size: 1.2rem;
  }
}
.plan__table--body .monthly-plan .amount {
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.7;
}
@media (max-width: 900px) {
  .plan__table--body .monthly-plan .amount {
    font-size: 2.2rem;
  }
}
.plan__table--body .bg-yellow {
  background-color: #fff0d2;
}
@media (max-width: 900px) {
  .plan__table--body .multiple-lines {
    padding: 8px 0;
    vertical-align: top;
  }
}
@media (max-width: 900px) {
  .plan__table--body .multiple-lines .sub {
    margin-top: 6px;
  }
}
.plan__table--body .text {
  font-size: 2.2rem;
  font-weight: 700;
}
@media (max-width: 900px) {
  .plan__table--body .text {
    font-size: 1.6rem;
  }
}
.plan__table--body .sub {
  display: block;
  font-size: 1.4rem;
  line-height: 1.5;
}
@media (max-width: 900px) {
  .plan__table--body .sub {
    font-size: 1rem;
  }
}
.plan__table--body .bold {
  font-weight: 700;
}
@media (min-width: 901px) {
  .plan__table--body .higher td {
    height: 140px;
    padding-top: 8px;
    vertical-align: top;
  }
}
@media (min-width: 901px) {
  .plan__table--body .higher .feature {
    padding-top: 28px;
  }
}
@media (min-width: 901px) {
  .plan__table--body .higher .sub {
    line-height: 1.5;
    margin-top: 8px;
  }
}
.plan__table--body .circle,
.plan__table--body .polygon,
.plan__table--body .cross {
  width: 42px;
  height: 42px;
  margin: 0 auto;
  background-size: 42px;
  background-repeat: no-repeat;
}
@media (max-width: 900px) {
  .plan__table--body .circle,
  .plan__table--body .polygon,
  .plan__table--body .cross {
    width: 31px;
    height: 31px;
    background-size: 31px;
  }
}
.plan__table--body .circle {
  background-image: url(../images/circle.png);
}
.plan__table--body .polygon {
  background-image: url(../images/polygon.png);
}
.plan__table--body .cross {
  background-image: url(../images/cross.png);
}

/*===========================================================================*/
/*  solution  */
/*===========================================================================*/
.solution {
  padding-top: 100px;
  padding-bottom: 104px;
}
.solution__wrapper {
  text-align: center;
}
.solution__head {
  color: #2864f0;
  text-align: center;
  font-size: 4.2rem;
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: 2.1px;
  padding-left: 50px;
  padding-right: 35px;
  position: relative;
  display: inline-block;
  margin-bottom: 47px;
}
.solution__head::before {
  content: "";
  width: 32px;
  height: 56px;
  background: url(../images/solution_decoration_l.svg) no-repeat center center/contain;
  position: absolute;
  left: 0;
  bottom: 0;
}
.solution__head::after {
  content: "";
  width: 32px;
  height: 56px;
  background: url(../images/solution_decoration_r.svg) no-repeat center center/contain;
  position: absolute;
  right: 0;
  bottom: 0;
}
.solution__items {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 2.2727272727%;
}
.solution__item {
  width: 31.8181818182%;
}
.solution__item:nth-child(1) .solution__img {
  width: 100%;
}
.solution__item:nth-child(1) .solution__detail {
  padding-bottom: 0;
}
.solution__item:nth-child(2) .solution__img {
  width: 71.935483871%;
}
.solution__item:nth-child(2) .solution__detail {
  padding-bottom: 23px;
}
.solution__item:nth-child(2) .solution__title {
  margin-bottom: 11px;
}
.solution__item:nth-child(3) .solution__img {
  width: 64.5161290323%;
}
.solution__item:nth-child(3) .solution__detail {
  padding-bottom: 40px;
}
.solution__item:nth-child(3) .solution__title {
  margin-bottom: 21px;
}
.solution__img {
  margin: 0 auto;
}
.solution__icon {
  width: 92px;
  height: 90px;
  margin-bottom: 1px;
  margin: 0 auto;
}
.solution__text {
  font-feature-settings: "palt" on, "liga" off;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 1.4px;
  margin-bottom: 43px;
  background-image: linear-gradient(to top, #ffdb70 50%, transparent 50%);
  background-repeat: no-repeat;
  background-size: 100% 0.5em;
  background-position: 0px 78%;
  display: inline-block;
}
.solution__content {
  background-color: #ebf3ff;
  border-radius: 14px;
  padding: 20px;
  position: relative;
}
.solution__content__num {
  position: absolute;
  left: 42%;
  transform: translateX(-50%);
  top: -38px;
  width: 155px;
  height: 85px;
}
.solution__detail {
  border-radius: 10px;
  background: #fff;
  padding: 25px 0 0 0;
  margin-bottom: 15px;
  position: relative;
  z-index: 0;
}
.solution__title {
  color: #2864f0;
  text-align: center;
  font-feature-settings: "palt" on, "liga" off;
  font-size: 2.8rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 1.4px;
  margin-bottom: 3px;
}
.solution__title span {
  color: #464343;
  text-align: center;
  font-size: 1.8rem;
  line-height: 1.8;
  letter-spacing: 0.9px;
  display: block;
}
.solution__description {
  font-feature-settings: "palt" on, "liga" off;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.8px;
}
.solution__button {
  margin-top: 73px;
  text-align: center;
}
.solution__button a {
  padding: 26px 94px 30px 63px;
  background-color: #fa6414;
  border-radius: 158px;
  background-image: url(../images/icon_arrow-white.svg);
  background-repeat: no-repeat;
  background-position: right 34px center;
  background-size: 20px 19px;
  position: relative;
}
.solution__button a span {
  color: #fff;
  text-align: center;
  font-feature-settings: "palt" on;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 1.3px;
}
.solution__button a::before {
  content: "機能充実！";
  background-color: #fff;
  color: #464343;
  text-align: center;
  font-feature-settings: "palt" on;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.4px;
  border-radius: 5.287px;
  background: #ffdb70;
  padding: 3px 15px 3px 16px;
  position: absolute;
  top: -33px;
  left: 50%;
  transform: translateX(-50%);
}
.solution__button a::after {
  content: "";
  position: absolute;
  left: -20px;
  width: 0;
  height: 0;
  background-color: #ffdb70;
  width: 16px;
  height: 11px;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
}

@media screen and (max-width: 900px) {
  .solution {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .solution__head {
    font-size: 2.4rem;
    line-height: 1.4;
    letter-spacing: 1.2px;
    padding-left: 26px;
    padding-right: 26px;
    margin-bottom: 22px;
  }
  .solution__head::before, .solution__head::after {
    width: 16px;
    height: 28px;
  }
  .solution__items {
    flex-direction: column;
    gap: 30px;
  }
  .solution__item {
    width: 100%;
  }
  .solution__item:nth-child(1) .solution__detail {
    padding: 20px 0 26px;
  }
  .solution__item:nth-child(2) .solution__detail {
    padding: 20px 0 20px;
  }
  .solution__item:nth-child(3) .solution__detail {
    padding: 20px 0 20px;
  }
  .solution__icon {
    width: 64px;
    height: 62px;
    margin-bottom: 2px;
  }
  .solution__text {
    font-size: 2.2rem;
    letter-spacing: 1.1px;
    margin-bottom: 29px;
    background-size: 100% 0.7em;
  }
  .solution__content {
    padding: 15px;
  }
  .solution__content__num {
    width: 102px;
    height: 63px;
    left: 45.7%;
    top: -27px;
  }
  .solution__detail {
    margin-bottom: 10px;
  }
  .solution__title {
    font-size: 2.2rem;
    letter-spacing: 1.1px;
    margin-bottom: 0;
  }
  .solution__title span {
    font-size: 1.6rem;
    letter-spacing: 0.8px;
  }
  .solution__description {
    font-size: 1.5rem;
    line-height: 1.5;
    letter-spacing: 0.75px;
  }
  .solution__button {
    margin-top: 41px;
    text-align: center;
  }
  .solution__button a {
    padding: 21px 74px 23px 47px;
    border-radius: 120px;
    background-position: right 25px center;
    background-size: 16px 15px;
  }
  .solution__button a span {
    font-size: 1.8rem;
  }
  .solution__button a::before {
    content: "機能充実！こんなに使えて月額980円～";
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.24px;
    border-radius: 4px;
    padding: 1px 7px 4px 8px;
    top: -11px;
    width: 73%;
  }
  .solution__button a::after {
    top: 5px;
  }
}
/*===========================================================================*/
/*  about  */
/*===========================================================================*/
.about {
  padding-top: 96px;
  padding-bottom: 100px;
  background-color: #ebf3ff;
}
.about__head {
  color: #2864f0;
  text-align: center;
  font-size: 4.2rem;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 1.26px;
  background-color: #ebf3ff;
}
.about__inner {
  background: url(../images/about_img.png) no-repeat center center/contain;
  height: 934px;
  width: 100%;
  max-width: 966px;
  margin: 0 auto;
  background-position-y: -90px;
  background-position-x: center;
}
.about__bg {
  width: 100%;
  height: 612px;
}
.about__achievements {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding-bottom: 36px;
  background-color: #ebf3ff;
}
.about__achievement {
  position: relative;
  padding-left: 46px;
  padding-right: 36px;
  color: #2864f0;
  text-align: center;
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 1.14px;
}
.about__achievement--sm {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.599px;
  display: block;
  margin-bottom: 6px;
}
.about__achievement sup {
  text-align: center;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.42px;
  vertical-align: middle;
}
.about__achievement::before {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 41px;
  height: 72px;
  background: url(../images/about_decoration_l.svg) no-repeat center center/contain;
}
.about__achievement::after {
  content: "";
  position: absolute;
  bottom: -6px;
  right: 0;
  width: 41px;
  height: 72px;
  background: url(../images/about_decoration_r.svg) no-repeat center center/contain;
}
.about__description {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 1.44px;
  padding-bottom: 25px;
  background-color: #ebf3ff;
}
.about__annotation {
  text-align: center;
  font-size: 1.2rem;
  line-height: 1.66;
  letter-spacing: 0.42px;
  background-color: #ebf3ff;
}

@media screen and (max-width: 900px) {
  .about {
    padding-top: 60px;
    padding-bottom: 60px;
    position: relative;
  }
  .about__head {
    font-size: 2.4rem;
    line-height: 1.55;
    letter-spacing: 0.72px;
  }
  .about__inner {
    margin: 0;
    height: 100%;
    width: 444px;
    background: url(../images/about_img_sp.png) no-repeat center center/contain;
    background-position-y: -32px;
    background-position-x: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
  .about__bg {
    height: 294px;
  }
  .about__achievements {
    gap: 7px;
    padding-bottom: 25px;
  }
  .about__achievement {
    font-size: 1.7632rem;
    letter-spacing: 0.529px;
    padding-left: 21px;
    padding-right: 16px;
  }
  .about__achievement::before, .about__achievement::after {
    width: 20px;
    height: 34px;
    bottom: -2px;
  }
  .about__achievement--sm {
    font-size: 0.9262rem;
    letter-spacing: 0.278px;
    margin-bottom: 3px;
  }
  .about__achievement sup {
    font-size: 0.6496rem;
    font-weight: 600;
    letter-spacing: 0.195px;
  }
  .about__description {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 1.28px;
    padding: 0 0 15px;
  }
  .about__annotation {
    font-size: 1rem;
    line-height: 1.66;
    letter-spacing: 0.35px;
    padding: 0 20px;
    text-align: left;
    width: calc(100% - 60px);
    margin: 0 auto;
  }
}
/*===========================================================================*/
/*  question  */
/*===========================================================================*/
.question {
  padding-top: 100px;
  padding-bottom: 100px;
}
.question__head {
  text-align: center;
  font-size: 4.2rem;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 1.26px;
  margin-bottom: 35px;
}
.question__items {
  max-width: 830px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.question__detail {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.41;
  letter-spacing: 0.7px;
  padding: 26px 0 26px 31px;
  background-color: #ebf3ff;
  border-radius: 10px;
}
.question__detail span {
  color: #2864f0;
  font-size: 2rem;
  margin-right: 15px;
}
.question__answer {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.66;
  letter-spacing: 0.56px;
  position: relative;
  padding-left: 36px;
}
.question__answer__box {
  padding: 18px 0 18px 37px;
}
.question__answer::before {
  content: "A";
  color: #fa6414;
  text-align: center;
  font-family: Inter;
  font-size: 2rem;
  font-weight: 700;
  line-height: 141%; /* 28.2px */
  letter-spacing: 0.7px;
  position: absolute;
  left: 0;
  top: 0;
  width: 15px;
  height: 28px;
}
.question__answer a {
  color: #2864f0;
}

@media screen and (max-width: 900px) {
  .question {
    padding-top: 60px;
    padding-bottom: 34px;
  }
  .question__inner {
    max-width: 500px;
    margin: 0 auto;
  }
  .question__head {
    font-size: 2.4rem;
    letter-spacing: 0.72px;
    margin-bottom: 25px;
  }
  .question__items {
    max-width: 100%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .question__detail {
    font-size: 1.6rem;
    letter-spacing: 0.56px;
    padding: 14px 7px 15px 15px;
    border-radius: 6px;
    display: flex;
  }
  .question__detail.white-nowrap {
    white-space: nowrap;
  }
  .question__detail span {
    font-size: 1.6rem;
    margin-right: 7px;
    font-weight: 700;
  }
  .question__answer {
    font-size: 1.4rem;
    letter-spacing: 0.49px;
    position: relative;
    padding-left: 22px;
  }
  .question__answer__box {
    padding: 10px 0 0 21px;
  }
  .question__answer::before {
    content: "A";
    color: #fa6414;
    text-align: center;
    font-family: Inter;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 141%; /* 28.2px */
    letter-spacing: 0.7px;
    position: absolute;
    left: 0;
    top: 0;
    width: 15px;
    height: 28px;
  }
  .question__answer a {
    color: #2864f0;
    display: inline;
  }
}
/*===========================================================================*/
/*  sticky button  */
/*===========================================================================*/
.sticky__container {
  position: fixed;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  z-index: 100;
}
@media (min-width: 901px) {
  .sticky__container {
    display: none;
  }
}
.sticky__container.is-show {
  opacity: 1;
  visibility: visible;
}
.sticky__button {
  margin-top: 0;
}