html {
  font-size: 10px;
}

body {
  color: #072334;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", "YuGothic", "Meiryo", sans-serif;
  line-height: 1;
}

img {
  display: block;
  width: 100%;
  height: auto;
}

a {
  transition: opacity 0.3s ease;
}

a:hover {
  opacity: 0.8;
}

main,
.site-footer {
  max-width: 525px;
  margin: 0 auto;
}

.lp-section {
  position: relative;
}

.cta_wrap {
  position: absolute;
  left: 50%;
  width: 90%;
  transform: translateX(-50%);
}

.cta_btn {
  display: block;
}

.dokidoki {
  animation: dokidoki 1s ease 0s infinite alternate;
  transform-origin: center;
}

@keyframes dokidoki {
  from {
    transform: scale(0.95);
  }
  to {
    transform: scale(1);
  }
}

.cta_sec01 {
  top: 82.24%;
}

.cta_sec06 {
  top: 44.12%;
}

.cta_sec07_01 {
  top: 34.91%;
}

.cta_sec07_02 {
  top: 96.68%;
}

.site-footer {
  padding: 28px 20px;
  background: #06184a;
  color: #fff;
  text-align: center;
}

.legal-page + .site-footer {
  max-width: 760px;
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 18px;
}

.footer-nav a {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.6;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.footer-copy {
  margin-top: 18px;
  font-size: 1.1rem;
  line-height: 1.5;
  opacity: 0.75;
}

.legal-page {
  max-width: 760px;
  padding: 40px 20px 56px;
  color: #222;
  line-height: 1.9;
  background: #fff;
}

.legal-page h1 {
  margin-bottom: 28px;
  color: #06184a;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.4;
}

.legal-page h2,
.legal-list dt {
  margin-top: 28px;
  margin-bottom: 8px;
  color: #06184a;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
}

.legal-page p,
.legal-page li,
.legal-list dd {
  font-size: 1.5rem;
  line-height: 1.9;
}

.legal-page ul {
  padding-left: 1.2em;
}

.legal-page li {
  list-style: disc;
}

.legal-back {
  margin-bottom: 24px;
}

.legal-back a {
  color: #06184a;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-date {
  margin-top: 32px;
}

@media (max-width: 525px) {
  .site-footer {
    padding: 7.5vw 5vw;
  }

  .footer-nav {
    flex-direction: column;
    gap: 2.5vw;
  }

  .footer-nav a {
    font-size: 3.2vw;
  }

  .footer-copy {
    font-size: 3vw;
  }

  .legal-page {
    padding: 9vw 5vw 12vw;
  }

  .legal-page h1 {
    font-size: 6vw;
  }

  .legal-page h2,
  .legal-list dt {
    font-size: 4.4vw;
  }

  .legal-page p,
  .legal-page li,
  .legal-list dd {
    font-size: 3.7vw;
  }
}
