@charset "UTF-8";
body,
div,
main,
sec,
h1,
h2,
h3,
p,
dl,
dt,
dd,
ul,
li {
  margin: 0;
  padding: 0;
}

.lp__main ul,
.lp__main li {
  list-style: none;
}

.lp__main {
  padding: 20vw 0 1px;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

@media screen and (min-width: 751px) {
  .lp__main {
    padding-top: 122px;
    max-width: 1920px;
    margin: 0 auto;
  }
}
.lp__main img {
  width: 100%;
  height: auto;
  max-width: 100%;
  display: block;
}

.lp__main a,
.lp__main a:link,
.lp__main a:visited {
  color: #698fce;
  text-decoration: underline;
}

.lp__main a:hover,
.lp__main a:active {
  color: #698fce;
  text-decoration: none;
}

.inner {
  position: relative;
  max-width: 750px;
  margin: 0 auto;
}

@media screen and (max-width: 750px) {
  .pc {
    display: none;
  }
}
@media screen and (min-width: 751px) {
  .sp {
    display: none;
  }
}
a {
  -webkit-transition: 0.1s;
  transition: 0.1s;
}

a:hover {
  opacity: 0.7;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

/* .header */
@media screen and (max-width: 750px) {
  .header {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 20vw;
    border-bottom: #dddddd solid 1px;
    z-index: 1000;
    background: #fff;
  }
  .header .inner img,
  .header .inner {
    width: 100%;
    height: auto;
  }
  .header .logo {
    width: 25.6vw;
    padding: 3vw 0 0 4vw;
  }
  .header p.btn {
    position: absolute;
    right: 4vw;
    top: 3vw;
    width: 61.067vw;
  }
}
@media screen and (min-width: 751px) {
  .header {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 121px;
    border-bottom: #dddddd solid 1px;
    z-index: 1000;
    background: #fff;
  }
  .header .inner {
    width: 100%;
    max-width: 100%;
    min-width: 800px;
  }
  .header h1 {
    font-size: 17px;
    line-height: 1;
    font-weight: bold;
    color: #000;
    padding: 54px 0 0 60px;
  }
  .header ul {
    position: absolute;
    right: 220px;
    top: 35px;
    font-size: 0;
    display: inline-block;
  }
  .header ul li {
    display: inline-block;
    font-size: 17px;
    line-height: 51px;
    vertical-align: top;
  }
  .header ul li.txt {
    margin-left: 50px;
    padding: 0 66px;
  }
  .header ul li.txt + li.txt {
    margin-left: 50px;
    padding: 0 66px;
    border-left: #b2b2b2 solid 1px;
  }
  .header ul li.btn {
    line-height: 0.1;
  }
  .header ul li.btn a {
    line-height: 51px;
    color: #fff;
    display: inline-block;
    width: 220px;
    text-align: center;
    background: #f23276;
    margin-right: 40px;
  }
  .header .logo {
    position: absolute;
    right: 60px;
    top: 20px;
    width: 120px;
  }
  .header .logo img {
    width: 100%;
    height: auto;
  }
  .header a,
  .header a:link,
  .header a:visited {
    color: #000;
    text-decoration: none;
  }
  .header a:hover,
  .header a:active {
    color: #000;
    text-decoration: underline;
  }
}
/* footer */
.common-footer {
  max-width: 750px;
  margin: 0 auto;
}

.common-footer-p-sns {
  margin-top: 8vw;
}

@media screen and (min-width: 751px) {
  .common-footer-p-sns {
    margin-top: 60px;
  }
}
.common-footer-p-sns__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0 4.8vw;
  margin: 0;
  padding: 0;
}

.mv {
  background: url(../img/mv01_bg.webp) no-repeat top center;
}
.mv .inner {
  position: relative;
}
.mv .note {
  max-width: 537px;
}
@media screen and (max-width: 750px) {
  .mv .note {
    width: 71.6%;
  }
}
.mv .note .tel_wrapper {
  padding: min(2.6666666667vw, 20px);
}

.mv_note {
  position: absolute;
  top: 60%;
  z-index: 1;
  left: 0;
  right: 0;
}

.sec01 {
  background: url(../img/sec01_bg.webp) no-repeat top center;
}

.sec02 {
  background: url(../img/sec02_bg.webp) no-repeat top center;
  position: relative;
}
.sec02 .wrap {
  -ms-grid-row: 1;
  grid-row: 1;
  -ms-grid-column: 1;
  grid-column: 1;
}
.sec02 .splide-block {
  position: absolute;
  top: min(5.3333333333vw, 40px);
  left: 0;
  right: 0;
  height: 100%;
  z-index: 2;
}

.sec03 {
  background: url(../img/sec03_bg.webp) no-repeat top center;
}

.sec04 {
  background: url(../img/sec04_bg.webp) no-repeat top center;
}

.sec05 {
  background: url(../img/sec05_bg.webp) no-repeat top center;
}

.sec06 {
  background: url(../img/sec06_bg.webp) no-repeat top center;
}

.sec07 {
  background: url(../img/sec07_bg.webp) no-repeat top center;
}

.sec08 {
  background: url(../img/sec08_bg.webp) no-repeat top center;
}

.sec09 {
  background: url(../img/sec09_bg.webp) no-repeat top center;
}

.sec10 {
  background: url(../img/sec10_bg.webp) no-repeat top center;
}

.sec11 {
  background: url(../img/sec11_bg.webp) no-repeat top center;
}

.has_video {
  position: relative;
}

.video_wrapper {
  display: block;
  aspect-ratio: 513/367;
  position: absolute;
  left: 0;
  right: 0;
  margin-inline: auto;
  top: 29px;
  max-width: 522px;
}
@media screen and (max-width: 750px) {
  .video_wrapper {
    max-width: inherit;
    width: 69.6%;
    top: 3.8666666667vw;
  }
}

video {
  width: 100% !important;
  height: 100% !important;
}

.tel_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: min(1.6vw, 12px);
     -moz-column-gap: min(1.6vw, 12px);
          column-gap: min(1.6vw, 12px);
  padding: min(4vw, 30px);
  border-bottom: 1px solid #fff;
}

.mark_tel {
  display: inline-block;
  width: min(6.4vw, 48px);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 750px) {
  .mark_tel {
    width: 6vw;
  }
}

.-night {
  margin-top: min(38.6666666667vw, 290px);
}
.-night .splide__pagination__page {
  background-color: #81b8e6;
}
.-night .splide__pagination__page.is-active {
  background-color: #fff;
}

.splide__arrow {
  background-color: transparent;
  width: 55px;
  height: 55px;
  opacity: 1;
  top: 55%;
}
@media screen and (max-width: 750px) {
  .splide__arrow {
    width: 8vw;
    height: 8vw;
  }
}
@media (any-hover: hover) {
  .splide__arrow:hover {
    opacity: 0.6;
  }
}

.splide__arrow--prev {
  left: calc(50% - 240px);
}
@media screen and (max-width: 750px) {
  .splide__arrow--prev {
    left: calc(50% - 33vw);
  }
}

.splide__arrow--next {
  right: calc(50% - 240px);
}
@media screen and (max-width: 750px) {
  .splide__arrow--next {
    right: calc(50% - 33vw);
  }
}

.splide__arrow--prev svg {
  display: none;
}

.splide__pagination {
  bottom: -2.5em;
  -webkit-column-gap: 0.5em;
     -moz-column-gap: 0.5em;
          column-gap: 0.5em;
}
@media screen and (max-width: 750px) {
  .splide__pagination {
    bottom: -1.5em;
    -webkit-column-gap: 0.2em;
       -moz-column-gap: 0.2em;
            column-gap: 0.2em;
  }
}

.splide__pagination__page {
  opacity: 1;
  width: 12px;
  height: 12px;
  background-color: #e5d3ba;
}
@media screen and (max-width: 750px) {
  .splide__pagination__page {
    width: 8px;
    height: 8px;
  }
}

.splide__pagination__page.is-active {
  -webkit-transform: scale(1) !important;
          transform: scale(1) !important;
  background-color: #eaa354;
}

.splide:not(.is-overflow) .splide__pagination {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}

.splide__pagination {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

/* 全スライドの初期値 */
.splide__slide {
  opacity: 0.6;
}

/* 現在のスライド（中央）だけ */
.splide__slide.is-active {
  opacity: 1;
}

.splide__track {
  max-width: 1340px;
  margin-inline: auto;
}

.splide__slide {
  width: 425px !important; /* 固定幅 */
}
@media screen and (max-width: 750px) {
  .splide__slide {
    width: 56.6666666667% !important;
  }
}

.tel {
  font-size: min(2.4vw, 18px);
}
.tel strong {
  color: #575757;
}
.tel a {
  text-decoration: none !important;
  color: currentColor !important;
}

@media (min-width: 768px) {
  a[href*="tel:"] {
    text-decoration: none;
    cursor: default;
    pointer-events: none;
  }
}
.cta {
  background-color: #92dbce;
  padding-bottom: min(10.2666666667vw, 77px);
  color: #828282;
}

.cta .inner {
  padding-inline: min(5.3333333333vw, 40px);
}

.cta_inner {
  background-color: #fff;
  padding: min(1.3333333333vw, 10px);
}

.cta_frame {
  border: 1px solid #92dbce;
  background-color: #fff;
  padding-bottom: min(6.6666666667vw, 50px);
}

.note {
  color: #828282;
  background-color: #f2f2f2;
  max-width: 586px;
  margin-inline: auto;
  width: 88.7878787879%;
}
.note .txt_wrapper {
  padding: min(2.2666666667vw, 17px);
}
.note .txt_wrapper p {
  font-size: min(2.4vw, 18px);
}
.note ul {
  margin-bottom: 1em;
}
@media screen and (max-width: 750px) {
  .note ul {
    margin-bottom: 0.5em;
  }
}
.note li {
  font-size: min(2.4vw, 18px);
  line-height: 1.3333333333;
  text-indent: -0.9em;
  padding-left: 1.1em;
}

.btn_wrapper {
  width: min(77.3333333333vw, 580px);
  padding-bottom: min(4vw, 30px);
  margin-inline: auto;
}
.btn_wrapper a {
  display: block;
}
.btn_wrapper.-large {
  width: min(90.6666666667vw, 680px);
}
.btn_wrapper img {
  -webkit-filter: drop-shadow(10px 10px 10px rgba(210, 18, 68, 0.4));
          filter: drop-shadow(10px 10px 10px rgba(210, 18, 68, 0.4));
  will-change: filter;
}
@media screen and (max-width: 750px) {
  .btn_wrapper img {
    -webkit-filter: drop-shadow(5px 5px 5px rgba(210, 18, 68, 0.4));
            filter: drop-shadow(5px 5px 5px rgba(210, 18, 68, 0.4));
  }
}

.common-footer-p-sns__list li {
  list-style: none;
  line-height: 1;
}

@media screen and (min-width: 751px) {
  .common-footer-p-sns__list {
    gap: 0 36px;
  }
}
.common-footer-p-sns__list img {
  width: 9.4vw;
  height: auto;
}

@media screen and (min-width: 751px) {
  .common-footer-p-sns__list img {
    width: 71px;
    height: auto;
  }
}
.common-footer-p-bottom-link__list {
  padding: 0;
  margin: 0;
}

.common-footer-p-bottom-link {
  margin-top: 8vw;
}

.common-footer-p-bottom-link li {
  list-style: none;
  text-align: center;
  line-height: 1;
}

@media screen and (min-width: 751px) {
  .common-footer-p-bottom-link {
    margin-top: 60px;
  }
}
.common-footer-p-bottom-link__list li + li {
  margin-top: 3.2vw;
}

@media screen and (min-width: 751px) {
  .common-footer-p-bottom-link__list li + li {
    margin-top: 24px;
  }
}
.common-footer-p-bottom-link__list a {
  font-size: 12px;
  font-weight: 400;
  color: #000;
  text-decoration: underline;
  font-family: Roboto, -apple-system, Helvetica Neue, Helvetica, Arial, sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
}

@media screen and (min-width: 751px) {
  .common-footer-p-bottom-link__list a {
    font-size: 24px;
  }
}
.common-footer-p-jdma {
  margin-top: 9vw;
}

@media screen and (min-width: 751px) {
  .common-footer-p-jdma {
    margin-top: 68px;
  }
}
.common-footer-p-jdma__inner {
  padding-left: 10px;
  width: 90%;
  margin: 0 auto;
}

@media screen and (min-width: 751px) {
  .common-footer-p-jdma__inner {
    padding-left: 20px;
  }
}
.common-footer-p-jdma img {
  width: 56vw;
}

@media screen and (min-width: 751px) {
  .common-footer-p-jdma img {
    width: 421px;
  }
}
.common-footer-l-footer {
  background-color: #007da5;
  padding: 6.9vw 0;
  margin-top: 2vw;
}

@media screen and (min-width: 751px) {
  .common-footer-l-footer {
    padding: 52px 0;
    margin-top: 15px;
  }
}
.common-footer-l-footer__inner {
  width: 90%;
  margin: 0 auto;
  font-size: 10px;
  line-height: 1.5;
  text-align: center;
  color: #fff;
  font-family: Roboto, -apple-system, Helvetica Neue, Helvetica, Arial, sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
}

@media screen and (min-width: 751px) {
  .common-footer-l-footer__inner {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.common-footer-l-footer__copyright {
  border-top: solid 1px #fff;
  padding-top: 12px;
  margin-top: 18px;
  display: inline-block;
  font-family: Roboto, -apple-system, Helvetica Neue, Helvetica, Arial, sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
}

/* .sec12 */
.sec12 .inner {
  padding: 0 4.6666666667%;
  color: #828282;
  font-size: 2.4vw;
  line-height: 3.7333333333vw;
  letter-spacing: 0.075em;
}

.sec12 .inner::after {
  content: "";
  display: inline-block;
  padding-bottom: 6.6666666667%;
}

.sec12 h2 {
  color: #575757;
  font-size: 4.6666666667vw;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: bold;
  padding: 10.6666666667% 0 4%;
  margin-bottom: 4%;
  border-bottom: #ababab solid 2px;
}

.sec12 h3 {
  color: #828282;
  font-size: 3.7333333333vw;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: bold;
  margin: 4% 0 2.4%;
}

.sec12 dl {
  margin: 2.4% 0 3.3333333333%;
}

.sec12 dl dt {
  color: #92dbce;
  font-size: 2.6666666667vw;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: bold;
  margin: 0 0 1.3333333333%;
}

@media screen and (min-width: 751px) {
  .sec12 .inner {
    font-size: 18px;
    line-height: 28px;
    letter-spacing: 0.075em;
  }
  .sec12 h2 {
    color: #575757;
    font-size: 35px;
    line-height: 1;
    letter-spacing: 0.1em;
    font-weight: bold;
    padding: 10.6666666667% 0 4%;
    margin-bottom: 4%;
    border-bottom: #ababab solid 2px;
  }
  .sec12 h3 {
    color: #828282;
    font-size: 28px;
    line-height: 1;
    letter-spacing: 0.1em;
    font-weight: bold;
    margin: 4% 0 2.4%;
  }
  .sec12 dl {
    margin: 2.4% 0 3.3333333333%;
  }
  .sec12 dl dt {
    color: #92dbce;
    font-size: 20px;
    line-height: 1;
    letter-spacing: 0.1em;
    font-weight: bold;
    margin: 0 0 1.3333333333%;
  }
}