@charset "UTF-8";
@font-face {
  font-family: "zen-kaku-gothic-new";
  src: url("path-to-font.woff2") format("woff2");
  unicode-range: U+0000-FFFF;
}
/* color
===================================================== */
/* 共通
===================================================== */
html,
body {
  font-family: YakuHanJPs, zen-kaku-gothic-new, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-weight: 400;
  font-style: normal;
  width: 100%;
  font-size: 16px;
  letter-spacing: 0.08em;
  margin: 0 auto;
  transition: all 1s ease 1s;
  background-color: transparent;
  color: #17396A;
  background-color: #E9E4DE;
  position: relative;
}

body {
  overflow-x: hidden;
  position: relative;
}

img,
video {
  width: 100%;
  display: block;
}

@media screen and (min-width: 769px) {
  .spNone {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .spNone {
    display: none;
  }
}
@media screen and (min-width: 769px) {
  .pcNone {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .pcNone {
    display: block;
  }
}
/* vw計算(pc用)
===================================================== */
/* vw変換(SP用)
===================================================== */
/* a
===================================================== */
a {
  display: block;
  text-decoration: none;
  transition: all 0.6s;
  color: #17396A;
}

a:hover {
  transition: all 0.6s;
  cursor: pointer;
}

a[href=""] {
  pointer-events: none;
}

/* font
===================================================== */
.en_1 {
  font-family: YakuHanMPs, "norman-variable", serif;
  font-variation-settings: "wght" 700;
}

.en_2 {
  font-family: YakuHanMPs, "norman-variable", serif;
  font-variation-settings: "wght" 520;
}

.en_3 {
  font-family: YakuHanJPs, "neue-haas-grotesk-text", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.ja_1 {
  font-family: YakuHanJPs, zen-kaku-gothic-new, sans-serif;
  font-weight: 500;
  font-style: normal;
}

.ja_2 {
  font-family: YakuHanMPs, "yu-mincho-pr6n", sans-serif;
  font-weight: 400;
  font-style: normal;
}

/* loading
===================================================== */
.loading {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  height: 100vh;
  background-color: #E9E4DE;
  color: #46714F;
  font-size: 2.6666666667vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .loading {
    font-size: min(0.7638888889vw, 11px);
  }
}
.loading .fv_txt {
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.loading p:nth-child(1) {
  margin-bottom: 4.8vw;
}
@media screen and (min-width: 769px) {
  .loading p:nth-child(1) {
    margin-bottom: min(1.7361111111vw, 25px);
  }
}
.loading img:nth-child(2) {
  width: 58.6666666667vw;
  margin: 0 auto 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .loading img:nth-child(2) {
    width: min(23.6111111111vw, 340px);
    margin: 0 auto min(1.7361111111vw, 25px);
  }
}

.speed1,
.speed2,
.speed3 {
  opacity: 0;
  visibility: hidden;
}

/* 共通s
===================================================== */
.up_text,
.up_text2 {
  width: fit-content;
}
.up_text p,
.up_text2 p {
  overflow: hidden;
}
.up_text p span,
.up_text2 p span {
  display: inline-block;
}
.up_text p span img,
.up_text2 p span img {
  height: 1em;
  width: auto;
  display: block;
}

.line1 {
  width: 100%;
  background-color: #17396A;
  height: 1px;
}

.line2 {
  width: 100%;
  background-color: #BA431F;
  height: 1px;
}

/* loading 
===================================================== */
/* fv
===================================================== */
.fv {
  position: relative;
  width: 100%;
  overflow-x: hidden;
}
.fv .fv_img {
  object-position: center top;
  object-fit: cover;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .fv .fv_img {
    width: 100%;
  }
}
.fv .fv_txt {
  color: #ffffff;
}
.fv .fv_txt > p:nth-child(1) {
  position: absolute;
  z-index: 100;
  font-size: 2.6666666667vw;
  text-align: left;
  top: 7.4666666667vw;
  left: 4.8vw;
}
@media screen and (min-width: 769px) {
  .fv .fv_txt > p:nth-child(1) {
    font-size: min(0.8333333333vw, 12px);
    top: min(2.0833333333vw, 30px);
    left: min(3.4722222222vw, 50px);
  }
}
.fv .fv_txt > p:nth-child(2) {
  position: absolute;
  z-index: 100;
  font-size: 2.6666666667vw;
  text-align: right;
  top: 7.4666666667vw;
  right: 4.8vw;
}
@media screen and (min-width: 769px) {
  .fv .fv_txt > p:nth-child(2) {
    font-size: min(0.8333333333vw, 12px);
    top: min(2.0833333333vw, 30px);
    right: min(3.4722222222vw, 50px);
  }
}
.fv .fv_txt > h1:nth-child(3) {
  position: absolute;
  z-index: 100;
  width: 64vw;
  top: 48%;
  left: 51%;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 769px) {
  .fv .fv_txt > h1:nth-child(3) {
    width: min(22.9166666667vw, 330px);
  }
}
.fv .fv_txt > h1:nth-child(3) > img:nth-child(1) {
  position: relative;
  z-index: 10;
}
.fv .fv_txt > h1:nth-child(3) > img:nth-child(2) {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  mix-blend-mode: multiply;
  opacity: 0.6;
}
@media screen and (min-width: 769px) {
  .fv .fv_txt > h1:nth-child(3) > img:nth-child(2) {
    opacity: 1;
  }
}
.fv .fv_txt > div:nth-child(4) {
  position: absolute;
  z-index: 100;
  font-size: 2.6666666667vw;
  bottom: 5.3333333333vw;
  left: 50%;
  transform: translate(-50%, 0);
}
@media screen and (min-width: 769px) {
  .fv .fv_txt > div:nth-child(4) {
    font-size: min(0.8333333333vw, 12px);
    bottom: min(1.5277777778vw, 22px);
  }
}

/* lead
===================================================== */
.lead .lead_wrap {
  position: relative;
  padding: 102.6666666667vw 0 138.1333333333vw;
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap {
    padding: 18.1944444444vw 0 20.4861111111vw;
  }
}
.lead .lead_wrap .up_text {
  position: relative;
  z-index: 10;
  font-size: 9.3333333333vw;
  margin: 0 auto 8vw 8.5333333333vw;
  line-height: 1.5294117647;
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .up_text {
    font-size: 3.75vw;
    margin: 0 auto 2.7777777778vw;
  }
}
.lead .lead_wrap .lead_txt {
  position: relative;
  z-index: 10;
  width: 83.2vw;
  font-size: 3.2vw;
  line-height: 2.3333333333;
  letter-spacing: 0.08em;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_txt {
    text-align: center;
    font-size: 0.9722222222vw;
    width: fit-content;
  }
}
.lead .lead_wrap .lead_txt p + p {
  margin-top: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_txt p + p {
    margin-top: 2.2222222222vw;
  }
}
.lead .lead_wrap .lead_img {
  position: absolute;
}
.lead .lead_wrap .lead_img.img1 {
  width: 32vw;
  top: 16vw;
  left: 42.1333333333vw;
  transform: translate(100%, -200%);
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_img.img1 {
    width: 12.5vw;
    top: 9.2361111111vw;
    left: 17.5vw;
    transform: translate(-250%, -100%);
  }
}
.lead .lead_wrap .lead_img.img2 {
  width: 34.6666666667vw;
  top: 41.0666666667vw;
  left: 0vw;
  transform: translate(-200%, 0%);
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_img.img2 {
    width: 13.5416666667vw;
    top: 16.0416666667vw;
    left: 0vw;
    transform: translate(-150%, 0%);
  }
}
.lead .lead_wrap .lead_img.img3 {
  width: 42.6666666667vw;
  top: 55.4666666667vw;
  left: 57.3333333333vw;
  transform: translate(200%, 0%);
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_img.img3 {
    width: 16.6666666667vw;
    top: 36.1805555556vw;
    left: 7.7083333333vw;
    transform: translate(-150%, 50%);
  }
}
.lead .lead_wrap .lead_img.img4 {
  width: 40vw;
  top: 215.4666666667vw;
  right: 55.4666666667vw;
  transform: translate(-200%, 0%);
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_img.img4 {
    width: 15.625vw;
    top: 10.9722222222vw;
    right: 11.3194444444vw;
    transform: translate(200%, -100%);
  }
}
.lead .lead_wrap .lead_img.img5 {
  width: 42.6666666667vw;
  top: 230.1333333333vw;
  right: 0vw;
  transform: translate(200%, 0%);
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_img.img5 {
    width: 16.6666666667vw;
    top: 30.7638888889vw;
    right: 0vw;
    transform: translate(150%, 0%);
  }
}
.lead .lead_wrap .lead_img.img6 {
  width: 34.6666666667vw;
  top: 262.9333333333vw;
  right: 50.1333333333vw;
  transform: translate(-200%, 100%);
}
@media screen and (min-width: 769px) {
  .lead .lead_wrap .lead_img.img6 {
    width: 13.5416666667vw;
    top: 43.6805555556vw;
    right: 19.0972222222vw;
    transform: translate(200%, 50%);
  }
}

/* 背景指定 ===================================================== */
.bgWrap {
  position: sticky;
  top: 0;
  left: 0;
  height: 100vh;
  pointer-events: none;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .bgWrap .bg_item {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    transition: all 0.8s ease-in-out;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
}
.bgWrap .bg_item.active {
  opacity: 1;
}
@media screen and (min-width: 769px) {
  .bgWrap .bg_item.bg_item--1 {
    background-image: url(../images/fv1_sp.webp);
  }
}
@media screen and (min-width: 769px) {
  .bgWrap .bg_item.bg_item--2 {
    background-image: url(../images/fv2_sp.webp);
  }
}
@media screen and (min-width: 769px) {
  .bgWrap .bg_item.bg_item--3 {
    background-image: url(../images/fv3_sp.webp);
  }
}

header,
footer,
main,
section {
  position: relative;
}

/* 流れる文字
========================================================= */
.loop_area {
  width: 100%;
  overflow: hidden;
}
@keyframes loop_left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
.loop_area .loop_wrap {
  display: flex;
}
.loop_area .loop_wrap .loop_left {
  animation: loop_left 40s infinite linear 1s both;
  display: flex;
  margin: 0;
  padding: 0;
}
.loop_area .loop_wrap .loop_left .loop_txt {
  font-size: 8.5333333333vw;
  letter-spacing: 0.04em;
  white-space: nowrap;
  color: #EFE9E2;
  padding: 0 0 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .loop_area .loop_wrap .loop_left .loop_txt {
    font-size: min(4.5833333333vw, 66px);
    padding: 0 0 min(0.6944444444vw, 10px);
  }
}

/* main
===================================================== */
@media screen and (min-width: 769px) {
  main .main_flex {
    display: flex;
  }
}
@media screen and (min-width: 769px) {
  main .main_flex .left_img {
    position: relative;
    width: 42%;
  }
}
@media screen and (min-width: 769px) {
  main .main_flex .main_container {
    width: 58%;
    padding: 0 10%;
    box-sizing: border-box;
  }
}
main .sec_catalog {
  margin-bottom: 32vw;
}
@media screen and (min-width: 769px) {
  main .sec_catalog {
    margin-bottom: 20.8333333333vw;
  }
}
main .section_cover {
  position: relative;
  width: 100%;
  aspect-ratio: 375/620;
  overflow: hidden;
  color: #fff;
  margin-bottom: 14.6666666667vw;
}
@media screen and (min-width: 769px) {
  main .section_cover {
    margin-bottom: 0;
    aspect-ratio: auto;
  }
}
main .section_cover > img:nth-child(1) {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
main .section_cover > p:nth-child(2) {
  position: absolute;
  font-size: 14.4vw;
  top: 8vw;
  right: 5.3333333333vw;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 769px) {
  main .section_cover > p:nth-child(2) {
    font-size: 6.9444444444vw;
    top: 4.1666666667vw;
    right: 4.1666666667vw;
  }
}
main .section_cover > h2:nth-child(3) {
  position: absolute;
  font-size: 15.4666666667vw;
  top: 34.6666666667vw;
  left: 8vw;
  letter-spacing: 0em;
}
@media screen and (min-width: 769px) {
  main .section_cover > h2:nth-child(3) {
    font-size: 5.5555555556vw;
    top: 13.8888888889vw;
    left: 4.4444444444vw;
  }
}
main .section_cover > p:nth-child(4) {
  position: absolute;
  font-size: 2.4vw;
  line-height: 1.4444444444;
  top: 56.5333333333vw;
  left: 8.5333333333vw;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 769px) {
  main .section_cover > p:nth-child(4) {
    font-size: 0.6944444444vw;
    top: 21.875vw;
    left: 4.4444444444vw;
  }
}
main .section_cover > p:nth-child(5) {
  position: absolute;
  font-size: 2.6666666667vw;
  bottom: 5.3333333333vw;
  left: 4.8vw;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 769px) {
  main .section_cover > p:nth-child(5) {
    font-size: 0.7638888889vw;
    bottom: 3.4722222222vw;
    left: 2.0833333333vw;
  }
}
main .section_cover > p:nth-child(6) {
  position: absolute;
  font-size: 2.6666666667vw;
  line-height: 1.2;
  bottom: 5.3333333333vw;
  right: 4.8vw;
  letter-spacing: 0.02em;
  text-align: right;
}
@media screen and (min-width: 769px) {
  main .section_cover > p:nth-child(6) {
    font-size: 0.7638888889vw;
    bottom: 3.4722222222vw;
    right: 2.0833333333vw;
  }
}
main #sec2 .section_cover {
  position: relative;
}
main #sec2 .section_cover > h2:nth-child(3) {
  top: 18.6666666667vw;
}
main #sec2 .section_cover > p:nth-child(4) {
  top: 57.6vw;
}
@media screen and (min-width: 769px) {
  main .bg_item--2 > h2:nth-child(3) {
    top: 9.0277777778vw;
  }
}
@media screen and (min-width: 769px) {
  main .bg_item--2 > p:nth-child(4) {
    top: 22.5694444444vw;
  }
}
@media screen and (min-width: 769px) {
  main .bg_item--3 > h2:nth-child(3) {
    top: 12.5vw;
  }
}
@media screen and (min-width: 769px) {
  main .bg_item--3 > p:nth-child(4) {
    top: 21.1805555556vw;
  }
}
main #sec3 .section_cover {
  position: relative;
}
main #sec3 .section_cover > p:nth-child(2) {
  right: 6.6666666667vw;
}
main #sec3 .section_cover > h2:nth-child(3) {
  top: 26.1333333333vw;
}
main #sec3 .section_cover > p:nth-child(4) {
  top: 47.4666666667vw;
}
main .section_ttl {
  width: 86.6666666667vw;
  margin: 0 auto 17.3333333333vw;
}
@media screen and (min-width: 769px) {
  main .section_ttl {
    width: 100%;
    margin: min(9.7222222222vw, 140px) auto 0;
  }
}
main .section_ttl h3 {
  font-size: 5.3333333333vw;
  line-height: 1.8;
  margin-bottom: 5.3333333333vw;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 769px) {
  main .section_ttl h3 {
    font-size: min(1.8055555556vw, 26px);
    margin-bottom: min(2.4305555556vw, 35px);
  }
}
main .section_ttl p {
  font-size: 3.2vw;
  line-height: 2;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 769px) {
  main .section_ttl p {
    font-size: min(0.9722222222vw, 14px);
  }
}
main .section_ttl p + p {
  margin-top: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  main .section_ttl p + p {
    margin-top: min(1.1111111111vw, 16px);
  }
}
main .item_ttl {
  font-size: 2.9333333333vw;
  letter-spacing: 0.02em;
  width: 89.3333333333vw;
  margin: 0 auto 9.6vw;
}
@media screen and (min-width: 769px) {
  main .item_ttl {
    margin: min(9.7222222222vw, 140px) auto min(4.1666666667vw, 60px);
    font-size: min(0.9027777778vw, 13px);
    width: 100%;
  }
}
main .item_ttl > p {
  margin-bottom: 2.1333333333vw;
}
@media screen and (min-width: 769px) {
  main .item_ttl > p {
    display: inline-block;
    margin-bottom: min(0.6944444444vw, 10px);
  }
}
@media screen and (min-width: 769px) {
  main .item_ttl p.spNone {
    float: right;
  }
}
main .item_wrap {
  width: 89.3333333333vw;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: 10.6666666667vw;
}
@media screen and (min-width: 769px) {
  main .item_wrap {
    width: 100%;
    row-gap: min(4.1666666667vw, 60px);
  }
}
main .item_wrap > li {
  width: 42.6666666667vw;
}
@media screen and (min-width: 769px) {
  main .item_wrap > li {
    width: 47%;
  }
}
main .item_wrap .item_block {
  overflow: hidden;
  font-size: 2.9333333333vw;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 769px) {
  main .item_wrap .item_block {
    font-size: min(0.8333333333vw, 12px);
  }
}
main .item_wrap .item_block .item_number {
  font-size: 2.6666666667vw;
  margin-bottom: 1.0666666667vw;
}
@media screen and (min-width: 769px) {
  main .item_wrap .item_block .item_number {
    font-size: min(0.8333333333vw, 12px);
    margin-bottom: min(0.5555555556vw, 8px);
  }
}
main .item_wrap .item_block .item_img {
  margin-bottom: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  main .item_wrap .item_block .item_img {
    margin-bottom: min(0.9722222222vw, 14px);
  }
}
main .item_wrap .item_block .item_name {
  margin-bottom: 2.1333333333vw;
}
@media screen and (min-width: 769px) {
  main .item_wrap .item_block .item_name {
    margin-bottom: min(0.6944444444vw, 10px);
  }
}
main .item_wrap .item_block .item_price {
  position: relative;
}
main .item_wrap .item_block .item_price::after {
  content: "BUY";
  position: absolute;
  top: 0;
  right: 0;
  text-decoration: underline;
}
main .item_wrap .item_block img {
  width: 100%;
}
main .item_wrap .item_block .slide_none {
  position: relative;
}
main .item_wrap .item_block .slide_none img {
  display: block;
  transition: opacity 0.6s ease;
}
main .item_wrap .item_block .slide_none .hover-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  transition: opacity 0.6s ease;
}
main .item_wrap .item_block .slide_none:hover .hover-img {
  opacity: 1;
}
main .item_wrap .item_block .slide_none:hover img:not(.hover-img) {
  opacity: 0;
}
main #sec4 {
  background-color: #DACDBB;
  position: relative;
  color: #BA431F;
  text-align: center;
  z-index: 0;
  width: 100%;
  overflow-x: hidden;
}
main #sec4::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  background-image: url(../images/bg1.png);
  background-size: 7.15%;
  background-repeat: repeat;
  opacity: 0.4;
  mix-blend-mode: multiply;
  z-index: 0;
}
@media screen and (min-width: 769px) {
  main #sec4::before {
    background-size: 2%;
  }
}
main #sec4 > div {
  position: relative;
}
main #sec4 .cam_wrap {
  margin: 16vw 0;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap {
    margin: min(6.5277777778vw, 94px) 0;
  }
}
main #sec4 .cam_wrap .cam_ttl p {
  font-size: 4vw;
  text-decoration: underline;
  text-underline-offset: 2.1333333333vw;
  text-decoration-thickness: 0.2666666667vw;
  margin-bottom: 8vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_ttl p {
    font-size: min(1.3888888889vw, 20px);
    text-underline-offset: min(0.6944444444vw, 10px);
    text-decoration-thickness: min(0.0694444444vw, 1px);
    margin-bottom: min(2.5vw, 36px);
  }
}
main #sec4 .cam_wrap .cam_ttl h3 {
  font-size: 8.5333333333vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_ttl h3 {
    font-size: min(2.9166666667vw, 42px);
  }
}
main #sec4 .cam_wrap .cam_box {
  position: relative;
  padding: 17.8666666667vw 0 15.4666666667vw;
  width: 92.5333333333vw;
  height: 137.0666666667vw;
  margin: 13.8666666667vw auto 9.6vw;
  box-sizing: border-box;
  background-image: url(../images/cam_img1.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box {
    padding: min(6.9444444444vw, 100px) 0 min(6.3888888889vw, 92px);
    width: min(63.8888888889vw, 920px);
    height: min(43.0555555556vw, 620px);
    margin: min(3.4722222222vw, 50px) auto min(3.8194444444vw, 55px);
    background-image: url(../images/cam_img1_pc.svg);
  }
}
main #sec4 .cam_wrap .cam_box .ttl {
  margin-bottom: 8vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .ttl {
    margin-bottom: min(2.7777777778vw, 40px);
  }
}
main #sec4 .cam_wrap .cam_box .ttl > img:nth-child(1) {
  width: 42.6666666667vw;
  margin: 0 auto 3.2vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .ttl > img:nth-child(1) {
    width: min(12.9166666667vw, 186px);
    margin: 0 auto min(1.0416666667vw, 15px);
  }
}
main #sec4 .cam_wrap .cam_box .ttl .line2:nth-child(2) {
  width: 45.3333333333vw;
  margin: 0 auto 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .ttl .line2:nth-child(2) {
    width: min(12.9166666667vw, 186px);
    margin: 0 auto min(0.6944444444vw, 10px);
  }
}
main #sec4 .cam_wrap .cam_box .ttl > p:nth-child(3) {
  font-size: 4.8vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .ttl > p:nth-child(3) {
    font-size: min(1.3888888889vw, 20px);
  }
}
main #sec4 .cam_wrap .cam_box .txt p {
  font-size: 3.2vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .txt p {
    font-size: min(0.9722222222vw, 14px);
  }
}
main #sec4 .cam_wrap .cam_box .txt > p:nth-child(1) {
  line-height: 2;
  margin-bottom: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .txt > p:nth-child(1) {
    margin-bottom: min(2.0833333333vw, 30px);
    line-height: 2.2857142857;
  }
}
main #sec4 .cam_wrap .cam_box .txt > p:nth-child(1) span {
  color: #EFE9E2;
  background-color: #BA431F;
  border-radius: 1.0666666667vw;
  padding: 0.5333333333vw 1.6vw 1.0666666667vw;
  margin: 0 1.0666666667vw;
  font-size: 1.16em;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .txt > p:nth-child(1) span {
    border-radius: min(0.2777777778vw, 4px);
    padding: min(0.2083333333vw, 3px) min(0.8333333333vw, 12px) min(0.4166666667vw, 6px);
    margin: 0 min(0.4166666667vw, 6px);
  }
}
main #sec4 .cam_wrap .cam_box .txt > p:nth-child(2) {
  margin-bottom: 4vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .txt > p:nth-child(2) {
    margin-bottom: min(1.25vw, 18px);
  }
}
main #sec4 .cam_wrap .cam_box .txt > p:nth-child(3) {
  font-size: 4.5333333333vw;
  line-height: 1.5882352941;
  width: 53.3333333333vw;
  padding: 4vw 0;
  margin: 0 auto 4.8vw;
  color: #EFE9E2;
  position: relative;
  background-image: url(../images/cam_img5.svg);
  background-size: 100%;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box .txt > p:nth-child(3) {
    font-size: min(1.3888888889vw, 20px);
    width: min(16.1111111111vw, 232px);
    padding: min(1.25vw, 18px) 0;
    margin: 0 auto min(2.0833333333vw, 30px);
  }
}
main #sec4 .cam_wrap .cam_box .txt > p:nth-child(4) {
  line-height: 1.6666666667;
}
main #sec4 .cam_wrap .cam_box > img {
  position: absolute;
}
main #sec4 .cam_wrap .cam_box > img:nth-child(3) {
  width: 44.08vw;
  top: -7.4666666667vw;
  right: -13.3333333333vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box > img:nth-child(3) {
    width: min(13.3333333333vw, 192px);
    top: min(4.5138888889vw, 65px);
    right: max(-4.1666666667vw, -60px);
  }
}
main #sec4 .cam_wrap .cam_box > img:nth-child(4) {
  width: 6.544vw;
  top: 13.3333333333vw;
  left: 10.6666666667vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box > img:nth-child(4) {
    width: min(1.9791666667vw, 28.5px);
    top: min(8.0555555556vw, 116px);
    left: min(18.2638888889vw, 263px);
  }
}
main #sec4 .cam_wrap .cam_box > img:nth-child(5) {
  width: 12.2133333333vw;
  top: 16vw;
  right: 6.6666666667vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .cam_box > img:nth-child(5) {
    width: min(3.6805555556vw, 53px);
    top: min(9.7222222222vw, 140px);
    right: min(17.3611111111vw, 250px);
  }
}
main #sec4 .cam_wrap .notice {
  position: relative;
}
main #sec4 .cam_wrap .notice::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 72vw;
  height: 7.3333333333vw;
  transform: translateX(-50%);
  background-image: url(../images/cam_img6.svg);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .notice::after {
    width: min(21.5277777778vw, 310px);
    height: min(2.2222222222vw, 32px);
  }
}
main #sec4 .cam_wrap .notice > p {
  font-size: 4vw;
  line-height: 1.8666666667;
  margin-bottom: 8vw;
  margin-left: 1.0666666667vw;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .notice > p {
    font-size: min(1.1805555556vw, 17px);
    margin-bottom: min(2.7777777778vw, 40px);
    margin-left: min(0.5555555556vw, 8px);
  }
}
main #sec4 .cam_wrap .notice > p span {
  color: #EFE9E2;
  background-color: #BA431F;
  border-radius: 1.0666666667vw;
  padding: 0.5333333333vw 2.6666666667vw 1.0666666667vw;
  margin-right: 1.0666666667vw;
  font-size: 1.1em;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .notice > p span {
    border-radius: min(0.2777777778vw, 4px);
    padding: min(0.2083333333vw, 3px) min(0.6944444444vw, 10px) min(0.4166666667vw, 6px);
    margin-right: min(0.4166666667vw, 6px);
  }
}
main #sec4 .cam_wrap .insta_btn {
  width: 69.3333333333vw;
  height: 13.8666666667vw;
  box-sizing: border-box;
  background-color: #BA431F;
  color: #ffffff;
  font-size: 3.4666666667vw;
  line-height: 13.8666666667vw;
  letter-spacing: 0.04em;
  text-align: center;
  position: relative;
  border-radius: 100vw;
  padding-right: 2.6666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .insta_btn {
    width: min(19.8611111111vw, 286px);
    height: min(3.8888888889vw, 56px);
    font-size: min(0.9930555556vw, 14.3px);
    line-height: min(3.8888888889vw, 56px);
    padding-right: min(1.3888888889vw, 20px);
  }
}
main #sec4 .cam_wrap .insta_btn img {
  width: 4.2666666667vw;
  position: absolute;
  right: 8vw;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 769px) {
  main #sec4 .cam_wrap .insta_btn img {
    width: min(1.2222222222vw, 17.6px);
    right: min(2.2916666667vw, 33px);
  }
}
main .all_btn {
  width: 74.6666666667vw;
  line-height: 14.9333333333vw;
  margin: -5.3333333333vw auto 32vw;
  text-align: center;
  background-color: #17396A;
  color: #ffffff;
  font-size: 3.7333333333vw;
  letter-spacing: 0.06em;
}
@media screen and (min-width: 769px) {
  main .all_btn {
    width: min(20.8333333333vw, 300px);
    line-height: min(4.1666666667vw, 60px);
    margin: max(-6.9444444444vw, -100px) auto min(16.6666666667vw, 240px);
    font-size: min(1.0416666667vw, 15px);
  }
}

/* footer
===================================================== */
footer {
  position: relative;
  background-color: #E9E4DE;
  padding: 24vw 0 16vw;
}
@media screen and (min-width: 769px) {
  footer {
    padding: min(11.1111111111vw, 160px) 0 0;
  }
}
footer .footer_ttl {
  width: 81.3333333333vw;
  margin: 0 auto 2.1333333333vw;
  display: flex;
  justify-content: space-between;
  font-size: 2.6666666667vw;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 769px) {
  footer .footer_ttl {
    width: min(75vw, 1080px);
    margin: 0 auto min(1.25vw, 18px);
    font-size: min(0.9027777778vw, 13px);
  }
}
footer .line1 {
  width: 81.3333333333vw;
  margin: 0 auto 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  footer .line1 {
    width: min(75vw, 1080px);
    margin: 0 auto min(6.9444444444vw, 100px);
  }
}
@media screen and (min-width: 769px) {
  footer .footer_wrap {
    position: relative;
    display: flex;
    align-items: flex-start;
    flex-direction: row-reverse;
    justify-content: center;
    gap: min(6.25vw, 90px);
    width: min(75vw, 1080px);
    margin: 0 auto;
  }
}
footer .footer_wrap .footer_right {
  width: 81.3333333333vw;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_right {
    align-items: flex-start;
    position: sticky;
    top: 6vh;
    width: min(34.7222222222vw, 500px);
  }
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_right .ttl {
    position: absolute;
    white-space: nowrap;
    top: min(5.5555555556vw, 80px);
    left: min(18.4027777778vw, 265px);
    transform: rotate(90deg);
  }
}
footer .footer_wrap .footer_right .up_text2 {
  font-size: 13.6vw;
  margin-bottom: 5.3333333333vw;
  letter-spacing: 0;
  line-height: 1.8;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_right .up_text2 {
    font-size: min(3.8888888889vw, 56px);
  }
}
footer .footer_wrap .footer_right .video_wrap {
  margin-bottom: 19.4666666667vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_right .video_wrap {
    padding-right: min(6.9444444444vw, 100px);
    box-sizing: border-box;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left {
    width: min(33.3333333333vw, 480px);
    margin-bottom: min(9.7222222222vw, 140px);
  }
}
footer .footer_wrap .footer_left .brand_info {
  color: #019845;
}
footer .footer_wrap .footer_left .brand_info a {
  color: #019845;
}
footer .footer_wrap .footer_left .brand_info .sahir_ttl {
  width: 54.9333333333vw;
  margin: 0 auto 9.8666666667vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .sahir_ttl {
    width: min(16.6666666667vw, 240px);
    margin: 0 auto min(3.125vw, 45px);
  }
}
footer .footer_wrap .footer_left .brand_info .sahir_txt {
  font-size: 2.9333333333vw;
  text-align: center;
  line-height: 1.8;
  margin-bottom: 14.6666666667vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .sahir_txt {
    font-size: min(0.7986111111vw, 11.5px);
    line-height: 2.0869565217;
    margin-bottom: min(4.8611111111vw, 70px);
  }
}
footer .footer_wrap .footer_left .brand_info .sahir_txt p + p {
  margin-top: 3.2vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .sahir_txt p + p {
    margin-top: min(1.3888888889vw, 20px);
  }
}
footer .footer_wrap .footer_left .brand_info .btn1 {
  width: 69.3333333333vw;
  line-height: 14.9333333333vw;
  border: 1px solid #019845;
  text-align: center;
  display: block;
  margin: 0 auto;
  font-size: 4vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .btn1 {
    width: min(20.8333333333vw, 300px);
    line-height: min(4.1666666667vw, 60px);
    font-size: min(1.1111111111vw, 16px);
  }
}
footer .footer_wrap .footer_left .brand_info .btn1 :hover {
  color: #ffffff;
  background-color: #019845;
  opacity: 1;
}
footer .footer_wrap .footer_left .brand_info .archive {
  display: flex;
  flex-wrap: wrap;
  width: 69.3333333333vw;
  justify-content: center;
  gap: 2%;
  font-size: 3.2vw;
  margin: 8vw auto 10.6666666667vw;
  line-height: 1.9166666667;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .archive {
    width: min(20.8333333333vw, 300px);
    font-size: min(0.9722222222vw, 14px);
    margin: min(2.7777777778vw, 40px) auto min(4.1666666667vw, 60px);
  }
}
footer .footer_wrap .footer_left .brand_info .archive a {
  text-decoration: underline;
}
footer .footer_wrap .footer_left .brand_info .sns_link {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 9.0666666667vw;
  margin-bottom: 20.2666666667vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .sns_link {
    margin-bottom: min(6.9444444444vw, 100px);
    gap: min(2.5vw, 36px);
  }
}
footer .footer_wrap .footer_left .brand_info .sns_link a:first-child {
  width: 6.4vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .sns_link a:first-child {
    width: min(1.8055555556vw, 26px);
  }
}
footer .footer_wrap .footer_left .brand_info .sns_link a:last-child {
  width: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .brand_info .sns_link a:last-child {
    width: min(1.5277777778vw, 22px);
  }
}
footer .footer_wrap .footer_left .credit_wrap {
  margin-bottom: 16vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .credit_wrap {
    margin-bottom: min(6.25vw, 90px);
  }
}
footer .footer_wrap .footer_left .credit_wrap .credit_ttl {
  font-size: 5.8666666667vw;
  margin: 0vw auto 8vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .credit_wrap .credit_ttl {
    font-size: min(1.6666666667vw, 24px);
    margin: min(3.4722222222vw, 50px) auto min(2.7777777778vw, 40px);
    margin: min(0vw, 0px) auto min(2.7777777778vw, 40px);
  }
}
footer .footer_wrap .footer_left .credit_wrap .credit_list {
  line-height: 2.4;
  font-size: 2.6666666667vw;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .credit_wrap .credit_list {
    font-size: min(0.8333333333vw, 12px);
  }
}
footer .footer_wrap .footer_left .credit_wrap .credit_list + .credit_list {
  margin-top: 4.2666666667%;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .credit_wrap .credit_list + .credit_list {
    margin-top: min(2.0833333333vw, 30px);
  }
}
footer .footer_wrap .footer_left .line1 {
  width: 69.3333333333vw;
  margin: 0 auto 18.6666666667vw;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .line1 {
    width: min(19.4444444444vw, 280px);
    margin: 0 auto min(6.9444444444vw, 100px);
  }
}
footer .footer_wrap .footer_left .copyright {
  margin: 0 auto;
  width: 53.3333333333vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  footer .footer_wrap .footer_left .copyright {
    width: min(16.6666666667vw, 240px);
  }
}

/* 共通
===================================================== */
.slide1 .swiper-wrapper {
  overflow: hidden;
}

.slide2 .swiper-wrapper {
  overflow: hidden;
}

.fade_scale {
  overflow: hidden;
}

.skewAnim {
  transform-origin: center;
  will-change: transform;
}

/* totop
===================================================== */
.totop {
  width: 4.8vw;
  position: fixed;
  bottom: 4.8vw;
  right: 4.2666666667vw;
  z-index: 100;
  opacity: 1;
  transition: all 0.6s;
  mix-blend-mode: multiply;
}
@media screen and (min-width: 769px) {
  .totop {
    width: min(1.6666666667vw, 24px);
    bottom: min(2.0833333333vw, 30px);
    right: min(2.0833333333vw, 30px);
  }
}

/* 下矢印
===================================================== */
/* animation
===================================================== */
.swiper-slide .credit1 {
  opacity: 0;
  transition: 0.5s;
}

.swiper-slide-visible .credit1 {
  opacity: 1;
  transition: 0.5s;
}/*# sourceMappingURL=style.css.map */