@charset "utf-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP&display=swap");

:root {
  --color-black: #231815;
  --color-white: #ffffff;
  --color-gray: #f8f8f8;
  --color-theme: #00a9c9;
}

/* ======================================================================
/* html
====================================================================== */
html {
  overflow-y: scroll;
  overflow-x: hidden;
  scroll-behavior: smooth;
  scroll-padding-top: 120px;
}

/* ======================================================================
/* body
====================================================================== */
body {
  inline-size: 100%;
  block-size: auto;
  font-size: 16px;
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans";
  font-weight: 400;
  line-height: 1.5;
  color: var(--color-black);
  word-break: break-all;
  letter-spacing: 1px;
}

@media screen and (width <=768px) {
  body {
    font-size: 14px;
  }
}

/* ======================================================================
/* ul ol
====================================================================== */
ul,
ol {
  margin: 0;
  padding: 0;

  & li {
    list-style-type: none;
  }
}

/* ======================================================================
/* img
====================================================================== */
img {
  display: block;
  margin: 0 auto;
  max-inline-size: 100%;
  vertical-align: bottom;
}

/* ======================================================================
/* inner
====================================================================== */
.inner {
  max-inline-size: 1080px;
  margin: 0 auto;
}

@media screen and (width <=768px) {
  .inner {
    inline-size: 100%;
    block-size: auto;
    padding-inline: 15px;
  }
}

/* ======================================================================
/* #secFv
====================================================================== */
#secFv {
  position: relative;
  inline-size: 100%;
  block-size: auto;

  & img {
    inline-size: 100%;
  }
}

/* ======================================================================
/* #secLead
====================================================================== */
#secLead {
  inline-size: 100%;
  padding-block: 75px 0;

  & .questionList {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 30px;

    & li {
      inline-size: calc(100% / 4 - 23px);
    }
  }
}

@media screen and (width <=768px) {
  #secLead {
    inline-size: 100%;
    padding-block: 40px 0;

    & .questionList {
      flex-direction: row;
      flex-wrap: nowrap;
      overflow-x: scroll;
      padding-block-end: 10px;

      & li {
        inline-size: 80%;
        flex-shrink: 0;
      }
    }
  }
}

/* ======================================================================
/* #secResult
====================================================================== */
#secResult {
  inline-size: 100%;
  padding-block: 75px 0;

  & .resultList {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 60px 30px;

    & li {
      inline-size: calc(100% / 2 - 15px);

      & img {
        inline-size: auto;
        block-size: 432px;
        object-fit: cover;
      }

      & p {
        margin-block-start: 15px;
      }
    }
  }
}

@media screen and (width <=768px) {
  #secResult {
    inline-size: 100%;
    padding-block: 40px 0;

    & .resultList {
      flex-direction: row;
      flex-wrap: nowrap;
      overflow-x: scroll;
      padding-block-end: 10px;

      & li {
        inline-size: 80%;
        flex-shrink: 0;

        & img {
          inline-size: 100%;
          block-size: auto;
        }

        & p {
          margin-block-start: 15px;
        }
      }
    }
  }
}

/* ======================================================================
/* #secClose
====================================================================== */
#secClose {
  inline-size: 100%;
  padding-block: 75px 0;

  & .closeList {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 30px;

    & li {
      inline-size: calc(100% / 2 - 15px);

      & img {
        inline-size: auto;
        block-size: 370px;
        object-fit: cover;
      }

      & p {
        margin-block-start: 15px;
      }
    }
  }
}

@media screen and (width <=768px) {
  #secClose {
    inline-size: 100%;
    padding-block: 40px 0;

    & .closeList {
      flex-direction: row;
      flex-wrap: nowrap;
      overflow-x: scroll;
      padding-block-end: 10px;

      & li {
        inline-size: 80%;
        flex-shrink: 0;

        & img {
          inline-size: 100%;
          block-size: auto;
        }

        & p {
          margin-block-start: 15px;
        }
      }
    }
  }
}

/* ======================================================================
/* #secStore
====================================================================== */
#secStore {
  inline-size: 100%;
  padding-block: 75px;

  & .infoList {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 30px;

    & li {
      inline-size: calc(100% / 2 - 15px);

      & iframe {
        inline-size: 100%;
        block-size: 400px;
        aspect-ratio: 16 / 9;
      }
    }
  }
}

@media screen and (width <=768px) {
  #secStore {
    padding-block: 40px 0;

    & .infoList {
      flex-direction: column;

      & li {
        inline-size: 100%;
      }
    }
  }
}

/* =================================================
/* floating
================================================= */
.floating {
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 9999;
  inline-size: 150px;
  block-size: auto;

  & .is-close {
    position: absolute;
    top: 10px;
    left: 10px;
    inline-size: 25px;
    height: auto;
    cursor: pointer;
  }
}

@media screen and (width <=768px) {
  .floating {
    inline-size: 75px;
    right: 0;
    bottom: 50px;
    transform: translate(0, 0);

    & .is-close {
      position: absolute;
      top: 0;
      left: 0;
      inline-size: 20px;
    }
  }
}

/* =================================================
/* top
================================================= */
.top {
  position: fixed;
  bottom: 15px;
  right: 100px;

  & img {
    inline-size: 32px;
    block-size: 32px;
  }
}

@media screen and (width <=768px) {
  .top {
    position: fixed;
    bottom: 15px;
    right: 50px;
  }
}

/* =================================================
/* footer
================================================= */
footer {
  padding: 40px;
  display: grid;
  place-items: center;
  background: var(--color-gray);
}
