body {
  margin: 0;
  padding: 0;
  background: #fff;
  font-family: sans-serif;
}

.image-wrapper {
  max-width: 750px;
  margin: 0 auto;
}

.img-block {
  position: relative;
  width: 100%;
}

.img-block > img:not(.btn-overlay) {
  width: 100%;
  height: auto;
  display: block;
}

@keyframes bounce {
  0%, 100% {
    transform: translateX(-50%) scale(1);
  }
  50% {
    transform: translateX(-50%) translateY(-5px) scale(1);
  }
}

.btn-overlay {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) scale(1);
  width: 93%;
  height: auto;
  z-index: 1;
  animation: bounce 2s infinite ease-in-out;
  transition: transform 0.3s ease;
}

.btn-overlay:hover {
  opacity: 0.8;
}

.img-1 .btn-overlay {
  bottom: 5%;
}

.img-10 .btn-overlay {
  bottom: 6%;
}

.img-12 .btn-overlay {
  bottom: 3%;
}

.site-footer {
  text-align: center;
  font-size: 14px;
  background-color: #f8f8f8;
  color: #555;
}

.footer-inner {
  max-width: 90%;
  margin: 0 auto;
  padding: 20px 0 10px;
}

.footer-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.footer-links a {
  color: #333;
  text-decoration: none;
}

.footer-links a:hover {
  text-decoration: underline;
}

@media screen and (min-width: 768px) {
  .footer-links {
    flex-direction: row;
    justify-content: center;
  }
}

.copyright-area {
  background-color: #333;
  color: #fff;
  padding: 10px 0;
  font-size: 12px;
}


    .privacy-wrapper {
      max-width: 750px;
      margin: 0 auto;
      padding: 20px;
      font-size: 16px;
      line-height: 1.8;
    }

    .privacy-wrapper h1 {
      font-size: 24px;
      margin-bottom: 1.5em;
      text-align: center;
    }

    .privacy-wrapper h2 {
      font-size: 18px;
      margin-top: 2em;
      margin-bottom: 0.5em;
    }

    .privacy-wrapper ul {
      padding-left: 1.2em;
    }

    .privacy-wrapper li {
      list-style: disc;
    }


    .tokushoho-wrapper {
      max-width: 750px;
      margin: 0 auto;
      padding: 20px;
      font-size: 16px;
      line-height: 1.8;
    }

    .tokushoho-wrapper h1 {
      font-size: 24px;
      margin-bottom: 1.5em;
      text-align: center;
    }

    .tokushoho-wrapper table {
      width: 100%;
      border-collapse: collapse;
    }

    .tokushoho-wrapper th,
    .tokushoho-wrapper td {
      border: 1px solid #ccc;
      padding: 8px;
      vertical-align: top;
      text-align: left;
    }

    .tokushoho-wrapper th {
      width: 30%;
      background-color: #f8f8f8;
    }
