@charset "utf-8";

body {
  font-family: "Noto Sans JP", sans-serif;
  /*font-size: clamp(17px, 2.34vw, 18px);*/
  font-weight: 400;
  line-height: 1.4;
  color: #414141;
  letter-spacing: 0.03em;
  -webkit-text-size-adjust: 100%;
  /*font-feature-settings: "palt";*/
  overflow-x: clip;
}

/* ======================
font
========================= */
.fgo {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  /* R400 M500 B700 */
  font-style: normal;
}
.chango {
  font-family: "Chango", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.ttsans {
  font-family: "TikTok Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  /* R400 M500 B700 */
  font-style: normal;
  font-variation-settings: "slnt" 0, "wdth" 100;
}

.fw_4 {
  font-weight: 400;
}
.fw_5 {
  font-weight: 500;
}
.fw_7 {
  font-weight: 700;
}

/* ======================
common
========================= */
/*main {
  overflow-x: clip;
}
article {
  min-height: 85vh;
}*/
a {
  color: #000;
  text-decoration: none;
  display: block;
  cursor: pointer;
}
a.no_link {
  pointer-events: none;
  opacity: 0.5;
}
a.sptel {
  pointer-events: none;
}
a.hv_opacity {
  transition: 0.2s;
}
a.hv_opacity:hover {
  opacity: 0.7;
}
.txt_c {
  text-align: center;
}
.txt_c span {
  display: inline-block;
}
img {
  width: 100%;
  height: auto;
  display: block;
}
.img_cnt {
  width: 100%;
  height: 100%;
  object-fit: contain;
  -o-object-fit: contain;
  object-position: center;
  -o-object-position: center;
}
.img_cvr {
  width: 100%;
  height: 100%;
  object-fit: cover;
  -o-object-fit: cover;
  object-position: center;
  -o-object-position: center;
}
.nolink {
  pointer-events: none;
  cursor: default;
}
.sp {
  display: none;
}
img[src*="_sp"] {
  display: none;
}

.flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.ilbk {
  display: inline-block;
}
.p_rltv {
  position: relative;
}
.p_sticky {
  position: sticky;
}




/* ===========
inview
============== */
.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);
}

.mov {
  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;
}
.mov.delay800 {
  transition-delay: 800ms;
}
.mov.delay900 {
  transition-delay: 900ms;
}
.mov.delay1000 {
  transition-delay: 1000ms;
}
.mov.delay1500 {
  transition-delay: 1500ms;
}



/* -------------------------------------
404 Not found
------------------------------------- */
.notfound {
  text-align: center;
  padding: 250px 0;
}

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

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

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

.notfound a {
  text-decoration: underline;
  display: inline-block;
}
@media screen and (max-width: 1600px) {

}
@media screen and (max-width: 1440px) {

}
@media screen and (min-width: 1200px) and (max-width: 1440px) {

}
@media screen and (min-width: 1200px) and (max-width: 1340px) {

}

@media screen and (max-width: 1200px) {

}
@media screen and (max-width: 1090px) {

}

@media screen and (min-width: 750px) and (max-width: 980px) {

}

@media screen and (max-width: 750px) {
  a.sptel {
    pointer-events: initial;
  }
  
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
  img[src*="_sp"] {
    display: block;
  }
  img[src*="_pc"] {
    display: none;
  }

}

@media screen and (max-width: 430px) {

}
