@charset "UTF-8";
.f_box.gtr.lnk_btn {
  justify-content: center;
  margin-top: 5%;
}
.f_box.gtr.lnk_btn a.w33 {
  padding: 0.75em !important;
  background-color: #fff;
  color: #18234e;
  border: #999 solid 1px;
  text-align: center;
  font-weight: 700;
}

#mv {
  aspect-ratio: 2/1;
  position: relative;
  padding: 0;
}
#mv .kv {
  position: relative;
  height: 100%;
  overflow: hidden;
  background-color: #18234e;
}
#mv .kv-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  z-index: 0;
  visibility: hidden;
  will-change: opacity;
}
#mv .kv-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  will-change: transform, filter;
}
#mv {
  /* フェードイン */
}
#mv .kv-slide.is-active {
  opacity: 1;
  z-index: 3;
  visibility: visible;
  transition: opacity 1.6s ease;
}
#mv {
  /* フェードアウト（重なりを保ちながら退場） */
}
#mv .kv-slide.is-leaving {
  opacity: 0;
  z-index: 2;
  visibility: visible;
  transition: opacity 1.6s ease;
}
#mv .catch {
  position: absolute;
  top: 10vw;
  left: 8vw;
  z-index: 3;
  mix-blend-mode: difference;
  text-shadow: 2px 2px 3px rgba(255, 255, 255, 0.5);
}
#mv .catch p {
  color: #fff;
  font-size: clamp(20px, 3.6vw, 70px);
  font-weight: 900;
  margin-bottom: 0.5em;
  line-height: 1.5em;
  letter-spacing: 0px;
}
#mv .catch p span {
  font-size: 1.7em;
  font-family: "helvetica-neue-lt-pro-cond", sans-serif;
  font-weight: 700;
  font-style: normal;
  line-height: 1.25em;
}
#mv .catch p.text_2 {
  margin: 8vw 0 0;
  font-size: clamp(20px, 2.59vw, 44px);
}
@media screen and (max-width: 600px) {
  #mv {
    aspect-ratio: 1/1.51;
  }
  #mv #slider {
    aspect-ratio: 1/1.51;
  }
  #mv #slider .splide__slide .slide-bg {
    position: relative;
    left: 0;
    width: 200%;
    height: 100%;
    background-position: -80vw;
  }
  #mv .catch {
    top: 84vw;
    left: 6vw;
    z-index: 4;
  }
  #mv .catch p {
    font-size: clamp(22px, 6.7vw, 56px);
    margin-bottom: 0;
  }
  #mv .catch p span {
    font-size: 1.4em;
  }
  #mv .catch p.text_1 {
    line-height: 2em;
  }
  #mv .catch p.text_2 {
    margin-top: 10vw;
    font-size: clamp(20px, 5.2vw, 56px);
  }
}

#about {
  background-color: #f2f2f2;
}
#about h3.bar {
  text-align: center;
  position: relative;
  font-size: clamp(18px, 2vw, 25px);
}
#about h3.bar span {
  background-color: #f2f2f2;
  margin: 0 auto;
  padding: 0 1em;
  position: relative;
  z-index: 2;
  font-size: 1em;
}
#about h3.bar::after {
  position: absolute;
  display: block;
  content: "";
  width: 100%;
  height: 1px;
  background: #18234e;
  inset: 0 0 0 0;
  margin: auto auto auto auto;
}
#about .w33 {
  text-decoration: none;
  position: relative;
  background-color: #fff;
}
#about .w33 h4 {
  text-align: center;
  color: #fff;
  position: absolute;
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  inset: 3% 0 0;
  padding: 0 5%;
  font-size: clamp(18px, 1.6vw, 20px);
}
#about .w33 h4 span {
  display: block;
  margin-bottom: 0.75em;
  font-family: "helvetica-neue-lt-pro-cond", sans-serif;
  font-weight: 900;
  font-style: normal;
  font-size: 1.1em;
}
#about .w33 p {
  line-height: 2em;
  padding: 0 1.5em 1.5em;
  font-weight: 500;
}
#about .w33 p:has(img) {
  padding: 0;
  margin-bottom: 0.5em;
}
@media screen and (max-width: 1024px) {
  #about p {
    font-size: 1.3vw;
  }
  #about .w33 h4 {
    font-size: 1.7vw;
  }
  #about .w33 p {
    font-size: 1.5vw;
  }
}
@media screen and (max-width: 600px) {
  #about h3.bar span {
    font-size: 1.2em;
  }
  #about p {
    font-size: clamp(16px, 2vw, 19px);
  }
  #about .w33 h4 {
    top: 5.5%;
    font-size: 5vw;
  }
  #about .w33 h4 span {
    font-size: 1.3em;
    margin-bottom: 0.5em;
  }
  #about .w33 p {
    font-size: clamp(15px, 2vw, 19px);
  }
}

#product .f_box .w33, #product .f_box .w5 {
  padding: 20.7% 2% 2%;
  text-decoration: none;
  position: relative;
}
@media screen and (min-width: 1025px) {
  #product .f_box .w33::after, #product .f_box .w5::after {
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: inherit;
    background: rgba(255, 255, 255, 0.5);
    inset: 0 0 0 0;
    margin: auto auto auto auto;
    opacity: 0;
    transition-duration: 0.5s;
  }
  #product .f_box .w33:hover::after, #product .f_box .w5:hover::after {
    opacity: 0.5;
    mix-blend-mode: hard-light;
  }
}
#product .f_box .w33 h4, #product .f_box .w5 h4 {
  text-align: center;
  color: #fff;
  font-size: clamp(18px, 2vw, 20px);
  font-weight: 900;
}
#product .f_box .w33 p, #product .f_box .w5 p {
  color: #fff;
  text-align: center;
  line-height: 2em;
  margin-top: 0.75em;
}
#product .f_box .w33 p img, #product .f_box .w5 p img {
  width: 1em;
}
#product .f_box .w33 p.link_text, #product .f_box .w5 p.link_text {
  text-align: right;
  font-size: 0.8em;
}
#product .f_box .w33 p.link_text img, #product .f_box .w5 p.link_text img {
  position: relative;
  top: 3px;
  margin-left: 0.5em;
}
#product .f_box .w33.item_1, #product .f_box .w5.item_1 {
  background: #fff url(../../images/index/product_1.webp) no-repeat center top;
  background-size: 100% auto;
}
#product .f_box .w33.item_2, #product .f_box .w5.item_2 {
  background: #fff url(../../images/index/product_2.webp) no-repeat center top;
  background-size: 100% auto;
}
#product .f_box .w33.item_3, #product .f_box .w5.item_3 {
  background: #fff url(../../images/index/product_3.webp) no-repeat center top;
  background-size: 100% auto;
}
#product .f_box .w33.item_4, #product .f_box .w5.item_4 {
  background: #fff url(../../images/index/product_4.webp) no-repeat center top;
  background-size: 100% auto;
}
#product .f_box .w33.item_5, #product .f_box .w5.item_5 {
  background: #fff url(../../images/index/product_5.webp) no-repeat center top;
  background-size: 100% auto;
}
#product .f_box .w5 {
  margin-top: 3%;
  padding-top: 18.2%;
}
@media screen and (max-width: 600px) {
  #product .f_box .w33, #product .f_box .w5 {
    padding: 43% 5% 5%;
    margin-top: 0;
    min-height: 340px;
  }
  #product .f_box .w33 h4, #product .f_box .w5 h4 {
    font-size: 5.3vw;
  }
  #product .f_box .w33 p, #product .f_box .w5 p {
    font-size: 3.4vw;
  }
  #product .f_box .w33 p.link_text, #product .f_box .w5 p.link_text {
    font-size: 3.4vw;
    padding-right: 0.5em;
    margin-top: 20%;
  }
  #product .f_box .w33.item_4, #product .f_box .w33.item_5, #product .f_box .w5.item_4, #product .f_box .w5.item_5 {
    background-size: cover;
  }
  #product .f_box .w33.item_4 p.link_text, #product .f_box .w33.item_5 p.link_text, #product .f_box .w5.item_4 p.link_text, #product .f_box .w5.item_5 p.link_text {
    margin-top: 40%;
  }
  #product .f_box .w33.item_1, #product .f_box .w5.item_1 {
    background: #fff url(../../images/index/product_1_sp.webp) no-repeat center top;
    background-size: 100% auto;
  }
  #product .f_box .w33.item_2, #product .f_box .w5.item_2 {
    background: #fff url(../../images/index/product_2_sp.webp) no-repeat center top;
    background-size: 100% auto;
  }
  #product .f_box .w33.item_3, #product .f_box .w5.item_3 {
    background: #fff url(../../images/index/product_3_sp.webp) no-repeat center top;
    background-size: 100% auto;
  }
  #product .f_box .w33.item_4, #product .f_box .w5.item_4 {
    background: #fff url(../../images/index/product_4_sp.webp) no-repeat center top;
    background-size: 100% auto;
  }
  #product .f_box .w33.item_5, #product .f_box .w5.item_5 {
    background: #fff url(../../images/index/product_5_sp.webp) no-repeat center top;
    background-size: 100% auto;
  }
}

#news {
  background-color: #fff;
}
#news ul {
  border-top: #ccc solid 1px;
}
#news ul li {
  padding: 1.5em;
  border-bottom: #ccc solid 1px;
  font-size: clamp(14px, 2vw, 15px);
  display: flex;
  align-items: center;
}
#news ul li span.category {
  display: inline-block;
  margin: 0 0.75em;
  padding: 5px 0.5em;
  width: 8em;
  text-align: center;
  background-color: #fff;
}
#news ul li span.category.cat_1 {
  border: #39b54a solid 1px;
}
#news ul li span.category.cat_2 {
  border: #2e3192 solid 1px;
}
#news ul li span.category.cat_3 {
  border: #a01e33 solid 1px;
}
#news ul li span.text {
  line-height: 1.4em;
}
#news p.btn {
  margin-top: 5%;
}
@media screen and (max-width: 600px) {
  #news ul li {
    flex-flow: wrap;
    padding: 1.5em 0.75em;
  }
  #news ul li span.text {
    width: 100%;
    padding-top: 1em;
  }
}
/*# sourceMappingURL=top.css.map */