@charset "utf-8";

body {
  font-family: "m-plus-rounded-1c", sans-serif;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: 0;
  font-style: normal;
  color: #383635;
  overflow-x: clip;
}

/* ======================
font
========================= */
.f_round {
  font-family: "m-plus-rounded-1c", sans-serif;
  font-weight: 500;
  /* r400,m500,b700,heavy800,black900 */
  font-style: normal;
}
.f_sic {
  font-family: "sicnewsnexus", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.f_sans {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.f_kaku {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 400;
  /* r400,b700*/
  font-style: normal;
}
.fw_4 {
  font-weight: 400;
}
.fw_5 {
  font-weight: 500;
}
.fw_7 {
  font-weight: 700;
}
.fw_8 {
  font-weight: 800;
}
.fw_9 {
  font-weight: 900;
}
/* ======================
common
========================= */
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.3s;
}
a.hv_opacity:hover {
  opacity: 0.7;
}
.nolink {
  pointer-events: none;
  cursor: default;
}
.cl_wh {
  color: #fff;
}
.cl_bl {
  color: #0d66a3;
}
.cl_bk {
  color: #000;
}
.txt_c {
  text-align: center;
}
.txt_c span {
  display: inline-block;
}
.inner-1240 {
  width: 86.11vw;
  /* max-width: 1654px;
  min-width: 1240px; */
  max-width: 1240px;
  margin: 0 auto;
}
.inner-1090 {
  width: 75.69vw;
  /* max-width: 1454px;
  min-width: 1090px; */
  max-width: 1090px;
  margin: 0 auto;
}
.inner-1077 {
  width: 74.79vw;
  /* max-width: 1436px;
  min-width: 1077px; */
  max-width: 1090px;
  margin: 0 auto;
}

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;
}
img[src*="_sp"] {
  display: none;
}
.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;
}
.bg_gry {
  background-color: #f2f2f2;
}
main {
  overflow-x: clip;
}
/* ===========
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_xtr {
  transform: rotateY(180deg);
}
.tl_ytr {
  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;
}

/* -------------------------------------
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: 1440px) {
  .inner-1240,
  .inner-1090,
  .inner-1077 {
    width: 92%;
    min-width: initial;
    max-width: 1240px;
  }
  .inner-1090 {
    max-width: 1090px;
  }
  .inner-1077 {
    max-width: 1077px;
  }
}

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

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