@charset "UTF-8";

/* Page: Plan */
.page-plan {
  padding: clamp(4rem, 3.648rem + 1.5vw, 5rem) clamp(1.5rem, 0.268rem + 5.26vw, 5rem);

  .page-plan__inner {
    width: 100%;
    max-width: 80rem;
    margin-inline: auto;
  }

  .page-plan__first-section {
    .page-plan__first-section__main-text {
      font-size: clamp(1.25rem, 0.986rem + 1.13vw, 2rem);
      font-weight: bold;
      color: var(--foreground-enhanced);
      text-align: center;
      line-height: 1.5;
      max-width: 36ch;
      margin-inline: auto;
    }

    .page-plan__first-section__sub-text {
      font-size: clamp(0.875rem, 0.831rem + 0.19vw, 1rem);
      margin-top: clamp(1.5rem, 1.324rem + 0.75vw, 2rem);
      line-height: 1.8;

      @media (min-width: 568px) {
        text-align: center;
        max-width: 70ch;
        margin-inline: auto;

        span {
          display: inline-block;
        }
      }
    }

    .page-plan__first-section__campaign {
      margin-top: clamp(2rem, 1.648rem + 1.5vw, 3rem);
    }
  }

  .page-plan__joining {
    padding-top: clamp(3rem, 2.824rem + 0.75vw, 3.5rem);

    .page-plan__joining__joining-costs {
      margin-top: clamp(1.5rem, 1.148rem + 1.5vw, 2.5rem);
    }
  }

  .page-plan__plan-option {
    padding-top: clamp(3rem, 2.648rem + 1.5vw, 4rem);

    .page-plan__plan-option__content {
      margin-top: clamp(1.5rem, 1.148rem + 1.5vw, 2.5rem);
    }
  }

  .page-plan__equipment {
    padding-top: clamp(3rem, 2.648rem + 1.5vw, 4rem);

    .page-plan__equipment__content {
      margin-top: clamp(1.5rem, 1.148rem + 1.5vw, 2.5rem);
    }
  }

  .page-plan__other-info {
    padding-top: clamp(3.5rem, 3.324rem + 0.75vw, 4rem);
    max-width: calc(1040 / 16 * 1rem);
    margin-inline: auto;
    display: grid;
    gap: clamp(2rem, 1.824rem + 0.75vw, 2.5rem);

    .page-plan__other-info__item {
      h3 {
        background-color: var(--primary);
        color: var(--primary-foreground);
        padding: calc(16 / 16 * 1rem) calc(24 / 16 * 1rem);
        font-weight: 500;
        font-size: clamp(0.875rem, 0.831rem + 0.19vw, 1rem);
      }

      ul {
        padding: calc(24 / 16 * 1rem);
        padding-left: calc((24 / 16 * 1rem) + 1em);
        background-color: var(--secondary);
        line-height: 1.8;
        font-size: calc(14 / 16 * 1rem);
        color: var(--primary);

        li {
          list-style: disc;
          list-style-color: var(--primary);

          &:not(:first-child) {
            margin-top: calc(16 / 16 * 1rem);
          }

          span {
            color: var(--foreground);
          }
        }
      }

      a {
        text-decoration: underline;

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;
          }
        }
      }
    }
  }
}