@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", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic",
    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;
  /*文字のぶら下げ*/
}
.cta {
  position: relative;
}
.heartbeat {
  -webkit-animation: heartbeat 1.5s ease-in-out infinite both;
  animation: heartbeat 1.5s ease-in-out infinite both;
}
@-webkit-keyframes heartbeat {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  10% {
    -webkit-transform: scale(0.91);
    transform: scale(0.91);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  17% {
    -webkit-transform: scale(0.98);
    transform: scale(0.98);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  33% {
    -webkit-transform: scale(0.87);
    transform: scale(0.87);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  45% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
}

@keyframes heartbeat {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  10% {
    -webkit-transform: scale(0.91);
    transform: scale(0.91);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  17% {
    -webkit-transform: scale(0.98);
    transform: scale(0.98);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  33% {
    -webkit-transform: scale(0.87);
    transform: scale(0.87);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  45% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
}

/* ヘッダー */
.header {
  display: flex;
  align-items: center;
  padding-right: 20px;
  margin-top: 10px;
  margin-bottom: 10px;
}

.header-logo {
  display: none;
  flex: 1px;
}

.login-btn {
  margin-top: 10px;
  max-width: 260px;
  width: 20%;
  display: block;
  margin-left: auto;
  margin-right: 0;
  background-color: #f2a93b;
  color: #ffffff;
  text-decoration: none;
  border: none;
  font-size: clamp(1.4rem, 0.219rem + 1.75vw, 2rem);
  border-radius: 40px;
  padding-inline: clamp(1.3rem, 0.389rem + 0.51vw, 2rem);
  padding-block: clamp(0.3rem, 0.389rem + 0.51vw, 1rem);
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.login-btn:hover {
  color: #f2a93b;
  background-color: #fff;
  border: 2px solid #f2a93b;
}

/* スライダー */
.loop-slider {
  width: 100%;
  overflow: hidden;
}

.loop-slider__track {
  display: flex;
  animation: loop 50s linear infinite;
}

.loop-slider__track img {
  width: 100vw;
  min-width: 1920px;
  height: auto;
  flex-shrink: 0;
}

@keyframes loop {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-1920px);
  }
}

.cta__btn-fixed {
  position: fixed;
  bottom: 5%;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  width: 33%;
  z-index: 100000;
  margin: auto;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.cta__btn-fixed.show {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0); /* 下からスライドイン */
}

.cta__btn01 {
  position: absolute;
  z-index: 9999;
  width: 33%;
  top: 75%;
  right: 0;
  left: 0;
  margin: auto;
}

.cta__btn02 {
  position: absolute;
  z-index: 9999;
  width: 33%;
  top: 76%;
  right: 0;
  left: 0;
  margin: auto;
}

.cta__btn03 {
  position: absolute;
  z-index: 9999;
  width: 33%;
  top: 84%;
  right: 0;
  left: 0;
  margin: auto;
}

.cta__btn04 {
  position: absolute;
  z-index: 9999;
  width: 33%;
  top: 66%;
  right: 0;
  left: 0;
  margin: auto;
}

.cta__btn06 {
  position: absolute;
  z-index: 9999;
  width: 37%;
  top: 68%;
  right: 0;
  left: 0;
  margin: auto;
}

#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を継承*/
}

/*-----------------タブレットサイズ-----------------------
@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%;
  }

  .header {
    padding-right: 10px;
  }

  .header-logo {
    display: block;
    flex: 1px;
  }

  .loop-slider__track img {
    min-width: 1030px;
  }

  @keyframes loop {
    from {
      transform: translateX(0);
    }
    to {
      transform: translateX(-1030px);
    }
  }

  .login-btn {
    font-size: 1.1rem;
    margin-top: 5px;
    min-width: 90px;
  }

  .cta__btn-fixed {
    width: 94%;
    top: 80%;
  }

  .cta__btn01 {
    width: 96%;
    top: 80%;
  }
  .cta__btn02 {
    width: 96%;
    top: 80%;
  }
  .cta__btn03 {
    width: 96%;
    top: 84%;
  }
  .cta__btn06 {
    width: 80%;
    top: 78%;
  }
  .cta__btn04 {
    width: 96%;
    top: 70%;
  }

  #footer {
    text-align: center;
    font-size: 0.8em;
    padding: 1em;
    margin-bottom: 150px;
  }

  #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;
  }
}

/*----------------------------------------*/
