:root {
  /* font */
  --font-family-jp: "Noto Sans JP", sans-serif;
  --font-family-en: "MuseoModerno", sans-serif;

  /* color */
  --accent-color: #FFD400;
  --font-color-base: #000;
}

html {
  scroll-padding-top: 96px;
}

body {
  @media (768px <= width) {
    min-width: 992px;
  }
}

/* overwrite */
.button.button--primary:link,
.button.button--primary:visited {
  color: var(--white);
}

.navbar__menu-item:link,
.navbar__menu-item:visited,
.navbar__submenu-item:link,
.navbar__submenu-item:visited,
.navbar__section__menu-item:link,
.navbar__section__menu-item:visited {
  color: var(--gray-200);
}

.layout_main {
  font-family: var(--font-family-jp);
  font-size: var(--font-size-md);
  font-weight: 400;
  background: #fff;
  color: var(--font-color-base);
  line-height: 2;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: antialiased;
  text-size-adjust: 100%;
  font-feature-settings: 'halt' on;
}

@media (width < 768px) {
  .layout_main {
    font-size: var(--font-size-sm);
  }
}

@media ( 768px < width) {
  section {
    font-size: var(--font-size-md);
  }

  .only_sp {
    display: none;
  }
}

.rich-menu {
 & a {
  &:link {
    color: inherit;
  }
 }
}

.lp-inner {
  max-width: 75rem;
  margin: 0 auto;
  @media (width < 768px) {
    margin: 0 1.5rem;
  }
}

.lp-section {
  padding: 6rem 1rem 0;
}

.lp-layout {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

em {
  color: var(--colors-primary-600);
  font-style: normal;
  font-weight: bold;
}

/* hero */
.hero {
  background-image: url("/lp/fixed-price-plan/assets/images/background-hero.png");
  background-size: cover;

  .section__container {
    header {
      text-align: center;

      p {
        font-size: var(--font-size-2xl);
      }

      .section__heading {
        margin-top: var(--size-3xs);
        font-size: var(--font-size-5xl);
        font-weight: bold;

        @media (width < 768px) {
          margin-top: var(--size-lg);
        }
      }

      .section__copy {
        margin-top: var(--size-2xl);
        font-size: var(--font-size-md);
      }

      @media (width < 768px) {
        h1 {
          line-height: 1.2;
        }
      }
    }
  }
}

.section__header {
  padding-block-end: var(--size-4xl);
}

.section__subheader {
  border-block-start: var(--border-size-thin) solid var(--gray-200);
  padding-block-start: var(--size-md);
  margin-block-start: var(--size-md);

  [class^="heading"] {
    display: flex;
    align-items: center;
    column-gap: var(--size-3xs);
  }
}

.section__heading {
  color: var(--gray-800);
  font-size: clamp(var(--font-size-2xl), 2vw + var(--font-size-lg), var(--font-size-5xl));
  padding-block-end: var(--size-md);
}

.section__copy {
  color: var(--gray-600);
  font-size: var(--font-size-xl);

  @media (width < 768px) {
    font-size: var(--font-size-lg);
  }
}

/* ページ内リンク */
.page-anchor {
  display: inline-flex;
  padding: var(--size-xl);
  border: 1px solid var(--gray-200);
  border-radius: var(--size-3xs);
  background-color: var(--white);

  li.page-anchor__item {
    list-style-type: none;

    &:first-of-type::before {
      content: none;
    }

    &::before {
      content: "";
      border-right: 1px solid var(--gray-200);
    }

    a {
      color: var(--gray-900);
      display: inline-flex;
      align-items: center;
      padding: 0 var(--size-2xl);

      &::after {
        content: '';
        display: block;
        width: var(--size-xl);
        height: var(--size-xl);
        background-color: var(--bland-color);
        mask-image: url("/assets/images/global/icons/arrow-down.svg");
        mask-repeat: no-repeat;
        mask-size: cover;
        margin-left: var(--size-3xs);
      }
    }
  }

  @media (768px <=width) {
    li.page-anchor__item a {
      position: relative;
      z-index: 0;
      text-decoration: none;
      color: var(--gray-900);
      transition: color 0.18s ease;
    }

    li.page-anchor__item a::before {
      content: "";
      position: absolute;
      inset: -8px 10px;
      border-radius: 4px;
      background: var(--gray-100);
      opacity: 0;
      transform: scale(0.98);
      transition: opacity 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
      z-index: -1;
      pointer-events: none;
    }

    li.page-anchor__item a:hover,
    li.page-anchor__item a:focus-visible {
      color: var(--gray-900);
      text-decoration: none;
    }

    li.page-anchor__item a:hover::before,
    li.page-anchor__item a:focus-visible::before {
      opacity: 1;
      transform: scale(1);
    }

    li.page-anchor__item a:hover *,
    li.page-anchor__item a:focus-visible * {
      text-decoration: none;
    }
  }

  @media (width < 768px) {
    display: grid;
    grid-template-columns: repeat(2, 1fr);

    li.page-anchor__item {
      &:nth-child(odd):before {
        content: none;
      }

      a {
        width: 100%;
        justify-content: center;
        padding: var(--size-4xs) var(--size-2xl);
      }
    }
  }

  @media (width < 576px) {
    grid-template-columns: repeat(1, 1fr);

    li.page-anchor__item {
      border-bottom: 1px solid var(--gray-200);
      padding: var(--size-md) 0;

      &:first-child {
        padding:  0 0 var(--size-md);
      }

      &:last-child {
        border-bottom: none;
        padding: var(--size-md) 0 0;
      }

      &::before {
        content: none;
      }

      a {
        display: flex;
        justify-content: space-between;
        padding: var(--size-4xs);
      }
    }
  }
}

/* partner solution*/
.partner_solution {
  background-color: var(--section-background-color);
  position: relative;

  .section__container {
    h2 {
      margin-bottom: var(--size-10xl);
      line-height: 1.4;
      position: relative;

      span {
        display: block;
        font-size: var(--font-size-2xl);
      }

      @media (width < 768px) {
        font-size: var(--font-size-2xl);

        span {
          font-size: var(--font-size-xl);
        }
      }
    }

    .app-list {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: var(--size-2xl);

      @media (width < 768px) {
        grid-template-columns: 1fr;
      }

      .application {
        box-shadow: 0 4px 8px -2px rgba(32, 32, 36, 0.04);
        display: grid;
        background-color: var(--white);
        grid-template-columns: 1fr;
        grid-template-rows: auto 1fr;
        height: 100%;
        border-radius: var(--size-3xs);
        overflow: hidden;

        .application-logo {
          display: flex;
          width: 100%;
          max-width: 320px;
          margin: auto;
          padding: var(--size-4xl);
          justify-content: center;

          img {
            width: 100%;
          }
        }

        .application-body {
          display: flex;
          flex-direction: column;
          align-items: flex-start;
          justify-content: flex-end;          
          gap: var(--size-2xs);
          padding: var(--size-2xl);
          background: var(--white);
          line-height: var(--scale-2xl);

          .app-name {
            font-size: var(--font-size-xl);
            font-weight: bold;
          }

          .app-provider {
            min-height: 42px;
            font-size: var(--font-size-sm);
          }

          .last-update {
            font-size: var(--font-size-sm);
          }

          .start-link {
            display: flex;
            width: 100%;
            margin-top: var(--size-xs);
            gap: var(--size-xs);
            flex-direction: column;

            .button {
              width: 100%;
              justify-content: center;
              font-size: var(--font-size-lg);
              font-weight: bold;
            }
          }
        }
      }
    }
  }


  .precautions {
    margin-top: var(--size-10xl);

    strong {
      font-weight: bold;
    }

    li {
      font-size: var(--font-size-sm);

      > ol li {
        margin: var(--size-5xs) 0;
        margin-left: var(--size-3xs);
        padding-left: var(--size-xl);
        text-indent: calc(var(--size-xl) * -1.4);
        line-height: 1.6;
      }
    }
  }
}




/* =========================================================
 コラムではじめる／動画ではじめる
========================================================= */
.guide-start {
  margin-top: var(--size-xl);
  --grid-gap: var(--size-xl);

  @media (width < 768px) {
    --grid-gap: var(--size-md);
  }


  .guide-start__sub {
    margin: var(--size-xs) 0 var(--size-xl);
    font-size: var(--font-size-xl);
    font-weight: 600;
    color: var(--gray-900);
  }

  .guide-start__cards {
    list-style: none;
    display: grid;
    gap: var(--size-2xl);
    grid-template-columns: repeat(4, 1fr);
    padding: 0;
    margin: 0;

    @media (width < 960px) {
      grid-template-columns: repeat(2, 1fr);
    }

    @media (width < 768px) {
      grid-template-columns: 1fr;
    }

    .guide-start__card {
      background: var(--gray-100);
      border-radius: 8px;
      padding: var(--size-xl);
      display: grid;
      gap: var(--size-sm);
      min-height: 396px;
      position: relative;

      @media (width < 768px) {
        min-height: 320px;
        gap: var(--size-md);
      }

      &:nth-child(-n + 3) {
        &::after {
          content: "";
          position: absolute;
          top: 50%;
          right: -16px;
          transform: translateY(-50%);
          width: 0;
          height: 0;
          border-left: 16px solid var(--gray-100);
          border-top: 16px solid transparent;
          border-bottom: 16px solid transparent;

          @media (width < 768px) {
            content: none;
          }
        }

        @media (width < 768px) {
          &:not(:last-child)::after {
            content: "";
            position: absolute;
            left: 50%;
            bottom: -16px;
            top: auto;
            right: auto;
            transform: translateX(-50%);
            width: 0;
            height: 0;
            border-top: 18px solid var(--gray-100);
            border-left: 16px solid transparent;
            border-right: 16px solid transparent;
            border-bottom: 0;
            z-index: 2;
            pointer-events: none;
          }
        }
      }


      .guide-start__num {
        font-size: var(--size-5xl);
        line-height: 1;
        font-weight: 400;
        color: color-mix(in srgb, var(--gray-900) 18%, transparent);
      }

      .guide-start__title {
        font-size: var(--font-size-2xl);
        font-weight: 600;
        color: var(--gray-900);
        line-height: 1.25;
        margin: 0;
      }

      .guide-start__text {
        color: var(--gray-600);
        margin: 0;
      }
    }
  }

  .guide-start__link {
    margin-top: auto;
    width: fit-content;
  }

  .layout_card.guide-start {
    grid-template-columns: 1fr 1fr;

    @media (width < 768px) {
      grid-template-columns: 1fr;
    }

    .guide-start__item {
      .guide-start__link-title {
        font-size: var(--font-size-2xl);
        font-weight: 600;
        color: var(--gray-900);
        line-height: 1.25;

        @media (width < 768px) {
          font-size: var(--font-size-xl);
        }
      }
    }
  }
}

#guide {
  @media (width < 768px) {
    padding-top: var(--size-xl);

  }

  .layout_card.guide-start {
    .link.link--read-more::after {
      mask-image: url(/assets/images/pages/guide/outmovie-icon.svg);
      mask-repeat: no-repeat;
      mask-size: contain;
      mask-position: center;
      width: 18px;
      height: 18px;
      margin-left: 0.35em;
      background-color: var(--link-color);
      position: relative;
      top: -0.05em;
    }

    .guide-start__link-image {
      position: relative;
      display: block;

      &::before {
        content: "";
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 80px;
        height: 80px;
        border-radius: 50%;
        background: rgba(0, 0, 0, 0.5);
        pointer-events: none;
        z-index: 1;

        @media (width < 768px) {
          width: var(--size-7xl);
          height: var(--size-7xl);
        }
      }

      &::after {
        content: "";
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(calc(-50% + -7px), -50%);
        width: 84px;
        height: 84px;
        background: #fff;
        pointer-events: none;
        z-index: 2;
        mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 6.2c0-.55.6-.9 1.1-.6l10.2 5.9c.5.3.5 1 0 1.3l-10.2 5.9c-.5.3-1.1-.05-1.1-.6V6.2z'/%3E%3C/svg%3E");
        mask-repeat: no-repeat;
        mask-position: center;
        mask-size: contain;

        @media (width < 768px) {
          width: var(--size-7xl);
          height: var(--size-7xl);
          transform: translate(calc(-50% - var(--size-4xs)), -50%);
        }
      }
    }

    @media (width < 768px) {
      .guide-start__link-text {
        gap: var(--size-md);
        padding: var(--size-xl);
      }
    }
  }
}


/* 共通フッター（globalfooter.html） の調整用 */
.globalfooter {
    & a:link {
        color: #F1F1F1;
    }
}

.footer-service__link:link {
  color: var(--bland-color);
}
