@charset "UTF-8";

/* ユーティリティー */
body {
  color: #000000;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
  font-size: min(3.75vw, 18px);
  font-weight: 500;
  line-height: 1.75;
  -webkit-text-size-adjust: 100%;
  /* font-feature-settings: "palt"; */
}
main {
  overflow-x: hidden;
}
.page {
  width: 94%;
  max-width: 1000px;
  margin: 0 auto;
}

img {
  width: 100%;
  height: auto;
}
a {
  color: #000000;
  text-decoration: none;
}

a.sptel {
  cursor: default;
  pointer-events: none;
}

.sp {
  display: none;
}

img[src*="_sp"] {
  display: none;
}

.flex {
  display: flex;
  flex-wrap: wrap;
}

.fadeIn {
  opacity: 0;
  transition: opacity 4s;
}

.fadeIn.show {
  opacity: 1;
}
.inv_mov {
  opacity: 0;
  transition: opacity 1s, transform 1s;
}

.tl_yb {
  transform: translate(0, 60px);
}

.tl_yt {
  transform: translate(0, -60px);
}

.tl_xl {
  transform: translate(-60px, 0);
}

.tl_xr {
  transform: translate(60px, 0);
}

.tl_rol {
  transform: rotate(-10deg);
}

.tl_ror {
  transform: rotate(10deg);
}
.tl_xt {
  transform: rotateX(180deg);
}
.tl_yt {
  transform: rotateY(180deg);
}

.mov,
.on {
  opacity: 1;
  transform: translate(0, 0) rotate(0deg);
  transition: opacity 1s, transform 1s;
}

.mov.delay100 {
  transition-delay: 100ms;
}

.mov.delay200 {
  transition-delay: 200ms;
}

.mov.delay300 {
  transition-delay: 300ms;
}

.mov.delay400 {
  transition-delay: 400ms;
}

.mov.delay500 {
  transition-delay: 500ms;
}
.mov.delay600 {
  transition-delay: 600ms;
}
.mov.delay700 {
  transition-delay: 700ms;
}

/* -------------------------------------
404 Not found
------------------------------------- */
.notfound {
  text-align: center;
  padding: 100px 0 200px;
}
.notfound .page {
  padding-left: 0;
}

.notfound .ttl {
  text-align: center;
  font-size: min(6.25vw, 32px);
  margin-bottom: 30px;
}

.notfound p {
  margin-bottom: 15px;
}

.notfound p strong {
  font-size: min(4.17vw, 20px);
  font-weight: bold;
  display: block;
  margin-bottom: 10px;
}

.notfound a {
  text-decoration: underline;
  display: inline-block;
}
/* -------------------------------------
header
------------------------------------- */
header {
  position: absolute;
  width: 100%;
  padding: 27px;
  left: 0;
  right: 0;
  z-index: 2;
}
#logo {
  width: 17.08vw;
  max-width: 116px;
}
/* -------------------------------------
footer
------------------------------------- */
footer {
  color: #ffff;
  text-align: center;
  padding: 45px 0 50px;
  background: #51a7dd;
}
footer a {
  color: #ffff;
  display: inline-block;
  padding: 0.2em 0.8em;
  text-decoration: none;
}
.f_nav {
  margin-bottom: 38px;
}
.f_nav li {
  display: inline;
}
.f_nav li ~ li:before {
  display: inline-block;
  content: "|";
}
.f_nav li a {
  font-size: clamp(10px, 3.13vw, 18px);
  display: inline-block;
  padding: 0.2em 0.8em;
  text-decoration: none;
}
.f_txt {
  font-size: clamp(10px, 2.92vw, 14px);
}
.f_txt span {
  display: inline-block;
  margin-right: 0.5em;
}
@media screen and (max-width: 640px) {
  /* -------------------------------------
common
------------------------------------- */
  img[src*="_sp"] {
    display: block;
  }

  img[src*="_pc"] {
    display: none;
  }
  a.sptel {
    cursor: pointer;
    pointer-events: auto;
  }
}
@media screen and (max-width: 500px) {
  /* -------------------------------------
	footer
	------------------------------------- */
  .f_txt:last-child {
    margin-top: 30px;
  }
  .f_txt a {
    display: block;
  }
}
@media screen and (max-width: 480px) {
  footer {
    padding: 10% 0 11%;
  }
  .f_nav {
    margin-bottom: 9%;
  }
  .f_txt:last-child {
    margin-top: 7%;
  }
}
