@charset "UTF-8";

/*
html {
  scroll-padding-top: 80px;
}
*/

.d-sm-none {
  display: none;
} 
@media print, screen and (max-width: 690px) {
  .d-sm-block {
    display: none;
  } 
  .d-sm-none {
    display: block;
  } 
}

.d-inline-block {
  display: inline-block;
}
.lp-shadow {
  box-shadow: 0px 4px 20px 2px rgba(0,0,0,0.16);
}

.sr-only {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  overflow: hidden !important;
  width: 0 !important;
  height: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  z-index: -2 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0 !important;
}

@media print, screen and (min-width: 1119.8px) {
  .pc-none {
    display: none;
  }
}

@media print, screen and (max-width: 980px) {
  .pc-only {
    display: none;
  }
}
.bg-main {
  background-color: #007AFF;
}
.bg-lmain {
  background-color: #ECF1F6;
}
.bg-white {
  background-color: #ffffff;
}
.text-main {
  color:#007AFF;
}
.bg-center {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.max-350 {
  max-width: 350px;
}
.u-fs-14 {
  font-size: 14px;
}
.u-fs-40 {
  font-size: 40px;
}
@media print, screen and (max-width: 980px) {
  .u-fs-40 {
    font-size: 34px;
  }
}
@media print, screen and (max-width: 690px) {
  .u-fs-40 {
    font-size: 28px;
  }
}
@media print, screen and (max-width: 480px) {
  .u-fs-40 {
    font-size: 24px;
  }
}

@media print, screen and (min-width: 980.8px) {
  .u-section.lp-cta, .u-section.lp-section {
    padding-top: 100px;
    padding-bottom: 100px;
  }
}

/* lp-title02 */
.lp-title02 {
  text-align: center;
  display: block;
  padding-top: 32px;
  background-image: url(../other/lp-title02-logo.svg);
  background-position: center top;
  background-repeat: no-repeat;
  margin-bottom: 50px;
}
@media print, screen and (max-width: 980px) {
  .lp-title02 {
    margin-bottom: 30px;
  }
}
/* lp-title02 end */

/* lp-title03 */
.lp-title03 {
  padding-left: 24px;
  position: relative;
}
.lp-title03::before {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 6px;
  background-color: #007AFF;
  position: absolute;
  left:0;
  top:0.7rem;
}
@media print, screen and (max-width: 690px) {
  .lp-title03 {
    padding-left: 20px;
  }
  .lp-title03::before {
    top:0.5rem;
  }
}
/* lp-title03 end */

/* header */
.l-header {
  top:0;
}
/* header end */

/* mv */
.lp-mv {
  height: 600px;
  position: relative;
  margin-top: 80px;
}
@media print, screen and (max-width: 1680px) {
  .lp-mv-bg {
    height: 600px;
  }
  .lp-mv-bg img {
    object-fit: cover;
    object-position: center;
    width: 100%;
    height: 100%;
  }
}
@media print, screen and (max-width: 980px) {
  .lp-mv {
    margin-top: 60px;
  }
}
@media print, screen and (max-width: 690px) {
  .lp-mv {
    background-color: #ECF1F6;
  }
}

.lp-mv-text {
  position: absolute;
  left:0;
  right:0;
  top:0;
  bottom:0;
  margin:auto;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
}
@media print, screen and (max-width: 1160px) {
  .lp-mv, .lp-mv-bg {
    height: 500px;
  }
  .lp-mv-text {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media print, screen and (max-width: 690px) {
  .lp-mv {
    padding-top: 30px;
  }
  .lp-mv-text {
    position: relative;
  }
  .lp-mv, .lp-mv-bg {
    height: auto;
  }
  .lp-mv-bg {
    margin-top: 30px;
  }
}

@media print, screen and (min-width: 1680.8px) {
  .lp-mv {
    height: auto;
  }
}

@media print, screen and (max-width: 1024px) {
  .lp-mv-text > div {
    max-width: 530px;
  }
}

.lp-mv-subtitle {
  font-size: 18px;
  font-weight: 500;
}
@media print, screen and (max-width: 1160px) {
  .lp-mv-subtitle {
    font-size: 16px;
    margin-bottom: 10px;
  }
}


.lp-mv h1 {
  line-height: 1.4;
  margin-bottom: 20px;
}
.lp-mv p.u-fs-14 {
  font-weight: 500;
  margin-bottom: 8px;
}

.lp-mv-btn {
  margin-top: 40px;
}
@media print, screen and (max-width: 1160px) {
  .lp-mv-btn {
    margin-top: 20px;
  }
}

/* mv end */

/* partner01 */
.lp-partner01 {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row-reverse;
  gap:20px;
  background-color: #ffffff;
  border-radius: 10px;
  padding:30px;
  border:3px solid #007AFF;
  align-items: center;
}
.lp-partner01 .left {
  width: 200px;
}
.lp-partner01 .right {
  width: calc(100% - 200px - 20px);
}

@media print, screen and (max-width: 690px) {
  .lp-partner01 {
    flex-direction: column-reverse;
    padding:20px;
  }
  .lp-partner01 .right {
    width: 100%;
  }
}
/* partner01 end */

/* partner02 */
.lp-partner02 {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row-reverse;
  gap:20px;
  background-color: #ffffff;
  border-radius: 10px;
  padding:40px;
  align-items: center;
}
.lp-partner02 .left {
  width: 245px;
}
.lp-partner02 .right {
  width: calc(100% - 245px - 20px);
}

@media print, screen and (max-width: 690px) {
  .lp-partner02 {
    flex-direction: column-reverse;
    padding:20px;
  }
  .lp-partner02 .right {
    width: 100%;
  }
}
/* partner02 end */

/* trouble */
.lp-trouble-wrap {
  display: grid;
  grid-template-columns: repeat(2, minmax(auto, 1fr));
  column-gap: 40px;
  row-gap: 40px;
}
@media print, screen and (max-width: 768px) {
  .lp-trouble-wrap {
    grid-template-columns: repeat(1, minmax(auto, 1fr));
    row-gap: 30px;
  }
}

.lp-trouble-wrap > div {
  border-radius: 10px;
  padding: 40px;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: subgrid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 0;
  width: 100%;
  position: relative;
}
@media print, screen and (max-width: 690px) {
  .lp-trouble-wrap > div {
    padding:20px;
  }
}
.lp-trouble-wrap > div h3 {
  font-size: 24px;
  order:2;
  margin-bottom: 12px;
}
@media print, screen and (max-width: 690px) {
  .lp-trouble-wrap > div h3 {
    font-size: 19px;
  }
}
.lp-trouble-wrap > div .text {
  order:3;
}
.lp-trouble-wrap > div .image {
  order:1;
  margin-bottom: 20px;
  border-radius: 10px;
  overflow:hidden;
}
/* trouble end */

/* solution */
.lp-solution {
  padding:120px 0 50px;
  color:#ffffff;
  position: relative;
}
.lp-solution::before {
  content:"";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 560px solid transparent;
  border-left: 560px solid transparent;
  border-top: 70px solid #ffffff;
  border-bottom: 0;
  position: absolute;
  left:0;
  right:0;
  margin-left: auto;
  margin-right: auto;
  top:0;
}
@media print, screen and (max-width: 1120px) {
  .lp-solution::before {
    border-right: 50vw solid transparent;
    border-left: 50vw solid transparent;
  }
}
/* solution end */

/* about */
.lp-about {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}

.lp-about .left {
  width: 48%;
}
.lp-about .right {
  width: 48%;
  border-radius: 10px;
  overflow: hidden;
}

@media print, screen and (max-width: 690px) {
  .lp-about .left {
    width: 100%;
  }
  .lp-about .right {
    width: 100%;
    margin-top: 20px;
  }
}
/* about end */

/* change */
.lp-change-wrap {
  display: grid;
  grid-template-columns: repeat(4, minmax(auto, 1fr));
  column-gap: 20px;
  row-gap: 20px;
}

@media print, screen and (max-width: 980px) {
  .lp-change-wrap {
    grid-template-columns: repeat(2, minmax(auto, 1fr));
  }
}
@media print, screen and (max-width: 690px) {
  .lp-change-wrap {
    grid-template-columns: repeat(1, minmax(auto, 1fr));
  }
}

.lp-change-wrap > div {
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: subgrid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap:0;
  width: 100%;
  position: relative;
  border-radius: 10px;
}
.lp-change-wrap > div h4 {
  text-align: center;
  background-color: #007AFF;
  padding:20px 5px;
  color:#ffffff;
  font-weight: 600;
  font-size: 20px;
  border-radius: 10px 10px 0 0;
  margin-bottom: 0;
}
.lp-change-wrap > div .row01 {
  background-color: #ffffff;
  padding:20px;
}
.lp-change-wrap > div .row01 p.subtitle {
  display: inline-block;
  margin-bottom: 10px;
  background-color: #F4F4F4;
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  color:#6C6C6C;
  padding:5px 10px;
}
.lp-change-wrap > div .icon {
  background-color: #ffffff;
  text-align: center;
  padding-bottom: 20px;
}
.lp-change-wrap > div .icon img {
  width: 80px;
  height: auto;
}
.lp-change-wrap > div .row02 {
  background-color: #E5F2FF;
  padding:20px;
  border-radius: 0 0 10px 10px;
}
.lp-change-wrap > div .row02 p.subtitle {
  display: inline-block;
  margin-bottom: 10px;
  background-color: #ffffff;
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  color:#007AFF;
  padding:5px 10px;
}
/* change end */

/* merit */
.lp-merit-wrap {
  display: flex;
  flex-wrap: wrap;
  gap:30px;
  justify-content: center;
}
.lp-merit-wrap > div {
  width: calc((100% / 3) - 20px);
  display: flex;
  flex-direction: column-reverse;
  justify-content: flex-end;
}
@media print, screen and (max-width: 690px) {
  .lp-merit-wrap > div {
    width: 100%;
  }
}

.lp-merit-wrap > div .text {
  margin-top: -25px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  position: relative;
  z-index: 2;
}
.lp-merit-wrap > div h3 {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 10px;
}
@media print, screen and (max-width: 690px) {
  .lp-merit-wrap > div h3 {
    font-size: 20px;
  }
}

.lp-merit-wrap > div p.number {
  font-size: 28px;
  font-weight: 900;
  color: #007AFF;
  margin-bottom: 10px;
}
.lp-merit-wrap > div .icon img {
  width: 160px;
  height: auto;
} 
/* merit end */

/* price */
.lp-price-wrap {
  border-radius: 10px;
  overflow: hidden;
  max-width: 650px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 40px;
}
.lp-price-wrap h3 {
  font-size: 24px;
  background-color: #007AFF;
  color: #ffffff;
  padding:20px 5px;
  margin-bottom: 20px;
}

@media print, screen and (max-width: 690px) {
  .lp-price-wrap h3 {
    font-size:19px;
  }
}

.lp-price-row {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.lp-price-row .tag {
  background-color: #34B0EA;
  color:#ffffff;
  font-size: 14px;
  font-weight: 600;
  padding:5px 10px;
  border-radius: 5px;
  margin-right: 15px;
  margin-top: 1.5rem;
}
.lp-price-row .price {
  font-size: 64px;
  font-weight: 600;
}
.lp-price-row .price .yen {
  font-size: 40px;
}
@media print, screen and (max-width: 690px) {
  .lp-price-row .tag {
    padding:2px 5px;
    margin-right: 10px;
    margin-top: 1rem;
  }
  .lp-price-row .price {
      font-size: 40px;
  }
  .lp-price-row .price .yen {
    font-size: 24px;
  }
}
/* price end */

/* flow */
.lp-flow {
  padding:20px;
}
@media print, screen and (max-width: 690px) {
  .lp-flow {
    padding:5px;
  }
}
/* flow end */

/* menu table */
.lp-table table {
  width: 100%;
}
.lp-table table th, .lp-table table td {
  border:1px solid #dddddd;
  text-align: center;
  padding:10px 3px;
}
table.tab01 th {
  background-color: #007AFF;
  color: #ffffff;
}
table.tab02 th {
  background-color: #ECF1F6;
}

.lp-table table thead tr th:first-child {
  width: 15%;
}
.lp-table table thead tr th:nth-child(2) {
  width: 17%;
}
.lp-table table thead tr th:nth-child(3) {
  width: 8%;
}
.lp-table table thead tr th:nth-child(4) {
  width: 12%;
}
.lp-table table thead tr th:nth-child(5) {
  width: 10%;
}
.lp-table table thead tr th:nth-child(6) {
  width: 28%;
}
.lp-tab-scroll-text {
  display: none;
}

@media print, screen and (max-width: 1023.8px) {
  .lp-tab-scroll {
    width: 100%;
    overflow-x: scroll;
  }
  .lp-table table {
    width: 1024px;
  }
  .lp-tab-scroll-text {
    display: block;
    font-size: 14px;
  }
}
/* menu end */

/* faq */
.lp-faq-wrap {
  display: grid;
  grid-template-columns: repeat(2, minmax(auto, 1fr));
  column-gap: 24px;
  row-gap: 48px;
}
@media print, screen and (max-width: 690px) {
  .lp-faq-wrap {
    grid-template-columns: repeat(1, minmax(auto, 1fr));
    row-gap: 30px;
  }
}

.lp-faq-wrap > div {
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: subgrid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 20px;
  width: 100%;
  padding-bottom: 40px;
  border-bottom: 1px solid #cccccc;
  position: relative;
}
.lp-faq-wrap > div::before {
  content:"";
  width: 50px;
  height: 1px;
  background-color: #007AFF;
  position: absolute;
  left:0;
  bottom:-1px;
}
@media print, screen and (max-width: 690px) {
  .lp-faq-wrap > div {
    padding-bottom: 30px;
  }
}

.lp-faq-wrap > div h3 {
  margin-bottom: 0;
  font-size: 24px;
  display: flex;
}
@media print, screen and (max-width: 980px) {
  .lp-faq-wrap > div h3 {
    font-size: 21px;
  }
}
@media print, screen and (max-width: 690px) {
  .lp-faq-wrap > div h3 {
    font-size: 18px;
  }
}

.lp-faq-wrap > div h3 .q-initial {
  font-size: 28px;
  width: 40px;
}
.lp-faq-wrap > div h3 .q-text {
  width: calc(100% - 40px);
  padding-top: 0.3rem;
}
.lp-faq-wrap > div > div {
  display: flex;
}
.lp-faq-wrap > div > div .a-initial {
  font-size: 28px;
  width: 40px;
  color:#007AFF;
  font-weight: 600; 
  width: 40px;
}
.lp-faq-wrap > div > div .a-text {
  width: calc(100% - 40px);
}

@media print, screen and (max-width: 690px) {
  .lp-faq-wrap > div h3 .q-initial,
  .lp-faq-wrap > div > div .a-initial {
    font-size: 22px;
    width: 34px;
  }
  .lp-faq-wrap > div h3 .q-text,
  .lp-faq-wrap > div > div .a-text {
    width: calc(100% - 34px);
  }
}
/* faq end */

/* cta */
.lp-cta-btn2 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap:12px;
  max-width: 100%;
  margin-left:auto;
  margin-right:auto;
}
.lp-cta-btn2 .col {
  text-align: center;
  width: 350px;
  max-width: calc(50% - 6px);
}
@media print, screen and (max-width: 690px) {
  .lp-cta-btn2 .col {
    width: 100%;
    max-width: 100%;
  }
}
.lp-cta-btn2 .col p {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 8px;
}
.lp-btn a {
  font-size: 18px;
  font-weight: 600;
  color: #ffffff;
  text-align: center;
  display: block;
  border-radius: 10px;
  border:2px solid #007AFF;
  background-color: #007AFF;
  padding:15px 0;
}
.lp-btn.btn-main a {
  background-image: url(../other/lp-cta-icon-mail.svg);
  background-repeat: no-repeat;
  background-position: center left 20px;
}
.lp-btn.btn-accent a {
  background-color: #7BE82B;
  border-color: #7BE82B;
  background-image: url(../other/lp-cta-icon-dl.svg);
  background-repeat: no-repeat;
  background-position: center left 20px;
}

@media (hover: hover) {
  .lp-btn.btn-main a:hover {
    background-color: #ffffff;
    color:#007AFF;
    background-image: url(../other/lp-cta-icon-mail-on.svg);
  }
  .lp-btn.btn-accent a:hover {
    background-color: #ffffff;
    color: #7BE82B;
    background-image: url(../other/lp-cta-icon-dl-on.svg);
  }
}
/* cta end */

/* about INES */
.lp-about .lp-shadow {
  padding:40px;
  border-radius: 10px;
}
@media print, screen and (max-width: 690px) {
  .lp-about .lp-shadow {
    padding:20px;
  }
}

.lp-about h2 {
  background-color: #007AFF;
  color:#ffffff;
  display: block;
  text-align: center;
  margin-bottom: 0;
  width: 89.2%;
  margin-left: auto;
  margin-right: auto;
  border-radius: 10px 10px 0 0;
  padding:55px 5px 25px;
  background-image: url(../other/lp-about-h2-logo.svg);
  background-repeat: no-repeat;
  background-position: center top 20px;
}
@media print, screen and (max-width: 690px) { 
  .lp-about h2 {
    font-size: min(4.2vw, 20px);
  }
}
/* about INES end */

/* footer */
.l-footer__bottom {
  background-color: #007AFF;
}
@media print, screen and (max-width: 690px) {
  .l-footer__bottom .inner {
    padding-right: 0;
  }
  .l-footer__bottom .inner small {
    font-size: min(2.5vw, 14px);
  }
}
/* footer end */