@charset "utf-8";

/* ---------------------------------------------------
 * base
/* ---------------------------------------------------*/

html {
  font-size: 62.5%;
  /*適宜変更お願いします*/
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  text-align: center !important;
  font-size: 10px;
  font-family: "Noto Sans JP", YuGothic, "Yu Gothic", "ヒラギノ角ゴシック", "Hiragino Sans",
    sans-serif;
  color: #000000;
  line-height: 1.75;
  width: 100%;
  background-color: #fff;
  font-weight: 400;
  /*適宜変更お願いします*/
  font-feature-settings: "palt" 1;
  /*自動カーニング*/
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: #000;
}

a:hover {
  /*opacity: 0.8;*/
  text-decoration: none;
}

p {
  text-align: justify;
  hanging-punctuation: allow-end;
  /*文字のぶら下げ*/
}

#footer {
  text-align: center;
}

/* ---------------------------------------------------
 * common（PC　min-width: 1023px）
/* ---------------------------------------------------*/
.wrap {
  width: 100%;
}

.container {
  position: relative;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.container img {
  width: 100%;
}

.-pc {
  display: block;
}

.-sp {
  display: none;
}

*,
*::before,
*::after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
  /*親要素のbox-sizingを継承*/
}

.cta {
  position: fixed;
  top: 90%;
  left: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 600px) {
  .cta {
    top: 93%;
  }
}

.cta-link {
  position: relative;
  overflow: hidden;
  height: 100%;
  display: block;
}

.cta-img {
  width: 100%;
  max-width: 300px;
  min-width: 300px;
}


/* キラキラエフェクト */
.cta-link::before {
  content: "";
  position: absolute;
  top: -50%;
  left: -100%;
  width: 50%;
  height: 200%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.1),
    rgba(255, 255, 255, 0.6),
    rgba(255, 255, 255, 0.1),
    transparent
  );
  transform: skewX(-25deg);
  animation: sparkle 5s infinite;
  pointer-events: none;
  z-index: 1;
}

@keyframes sparkle {
  0% {
    left: -100%;
  }
  20% {
    left: 150%;
  }
  100% {
    left: 150%;
  }
}

@keyframes poyon {
  0% {
    transform: scale(1, 1) translate(0%, 0%);
  }
  15% {
    transform: scale(0.95, 0.95) translate(0%, 0%);
  }
  30% {
    transform: scale(1.05, 1.05) translate(0%, 0%);
  }
  50% {
    transform: scale(0.95, 0.95) translate(0%, 0%);
  }
  70% {
    transform: scale(1.05, 1.05) translate(0%, 0%);
  }
  100% {
    transform: scale(1, 1) translate(0%, 0%);
  }
}

/*-----------------タブレットサイズ-----------------------
@media (min-width: 600px) and (max-width: 1023px) {
    body {
        font-size: 3.2rem;
    }
    .-pc {
        display: none;
    }
    .-sp {
        display: block;
    }
    .wrap {
        max-width: 100%;
        width: 100%;
    }
}
----------------------------------------*/

/*-----------------スマホサイズ-----------------------*/

@media screen and (max-width: 600px) {
  .-pc {
    display: none;
  }

  .-sp {
    display: block;
  }

  body {
    font-size: 4.2vw;
  }

  .wrap {
    max-width: 100%;
    width: 100%;
  }

  #footer {
    text-align: center;
    font-size: 0.8em;
    padding: 1em;
    margin-bottom: 100px;
  }

  #footer a {
    color: #000000;
  }

  section#section-01,
  section#section-02,
  section#section-03,
  section#section-04,
  section#section-05,
  section#section-06,
  section#section-07,
  section#section-08,
  section#section-09,
  section#section-10,
  section#section-11,
  section#section-12,
  section#section-13,
  section#section-14,
  section#section-15,
  section#section-16,
  section#section-17,
  section#section-18,
  section#section-19,
  section#section-20,
  section#section-21,
  section#section-22,
  section#section-23,
  section#section-24,
  section#section-25,
  section#section-26,
  section#section-27,
  section#section-28,
  section#section-29,
  section#section-30,
  section#section-31,
  section#section-32,
  section#section-33,
  section#section-34,
  section#section-35,
  section#section-36,
  section#section-37,
  section#section-38,
  section#section-39,
  section#section-40,
  section#section-41,
  section#section-42,
  section#section-43,
  section#section-44,
  section#section-45,
  section#section-46,
  section#section-47,
  section#section-48,
  section#section-49,
  section#section-50 {
    background: none !important;
  }
}

/*----------------------------------------*/
