@charset "UTF-8";
@media print, screen and (min-width: 780.1px) {
  .sp {
    display: none !important;
  }
}
@media print, screen and (min-width: 1920px) {
  .sp {
    display: none !important;
  }
}

@media screen and (max-width: 780px) {
  .pc {
    display: none !important;
  }
}

main {
  margin: 0;
  padding: 0;
}

#kv {
  width: 100%;
  height: auto;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
@media print, screen and (min-width: 780.1px) {
  #kv {
    aspect-ratio: 1440/980;
    background-image: url(../img/product_kv_pc.webp);
  }
}
@media screen and (max-width: 780px) {
  #kv {
    aspect-ratio: 780/1191;
    background-image: url(../img/product_kv_sp.webp);
  }
}
#kv .catch {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
}
@media print, screen and (min-width: 780.1px) {
  #kv .catch {
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-564px, -124px);
            transform: translate(-564px, -124px);
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #kv .catch {
    -webkit-transform: translate(-32.7vw, 12.4vw);
            transform: translate(-32.7vw, 12.4vw);
  }
}
@media screen and (max-width: 780px) {
  #kv .catch {
    top: 24.6153846154vw;
    left: 7.6923076923vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #kv .catch h1 img {
    width: 426px;
  }
}
@media screen and (max-width: 780px) {
  #kv .catch h1 img {
    width: 84.6153846154vw;
  }
}
#kv .catch p {
  font-family: var(--font-jp);
  font-style: normal;
  font-weight: 600;
  line-height: 180%;
  white-space: nowrap;
  clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
  -webkit-animation: cacthMaskAnimText 0.8s 1s cubic-bezier(0.215, 0.610, 0.355, 1.000) forwards;
          animation: cacthMaskAnimText 0.8s 1s cubic-bezier(0.215, 0.610, 0.355, 1.000) forwards;
}
@media print, screen and (min-width: 780.1px) {
  #kv .catch p {
    margin-top: 27px;
    margin-left: 48px;
    font-size: 20px;
    letter-spacing: 0.2px;
    -webkit-transform: rotate(-6.5deg);
            transform: rotate(-6.5deg);
  }
}
@media screen and (max-width: 780px) {
  #kv .catch p {
    margin-top: 3.8461538462vw;
    margin-left: 4.358974359vw;
    font-size: 4.1025641026vw;
    letter-spacing: 0.041025641vw;
    -webkit-transform: rotate(-6.5deg);
            transform: rotate(-6.5deg);
  }
}
#kv .product-image {
  position: absolute;
}
@media print, screen and (min-width: 780.1px) {
  #kv .product-image {
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-94px, -272px);
            transform: translate(-94px, -272px);
  }
}
@media screen and (max-width: 780px) {
  #kv .product-image {
    top: 70.2564102564vw;
    left: 7.6923076923vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #kv .product-image img {
    width: 660px;
  }
}
@media screen and (max-width: 780px) {
  #kv .product-image img {
    width: 84.6153846154vw;
  }
}
#kv .oblique {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  white-space: nowrap;
  -webkit-transform: rotate(-6.5deg);
          transform: rotate(-6.5deg);
  position: absolute;
  left: 0;
}
@media print, screen and (min-width: 780.1px) {
  #kv .oblique {
    bottom: 264px;
  }
}
@media screen and (max-width: 780px) {
  #kv .oblique {
    bottom: 24.358974359vw;
  }
}
#kv .marquee {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: var(--White, #FFF);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-en);
  font-style: italic;
  font-weight: 600;
  line-height: 100%;
  white-space: nowrap;
  will-change: transform;
  -webkit-animation: marquee 20s linear infinite;
          animation: marquee 20s linear infinite;
}
@media print, screen and (min-width: 780.1px) {
  #kv .marquee {
    gap: 100px;
    padding-right: 100px;
    font-size: 230px;
    letter-spacing: -6.9px;
  }
}
@media screen and (max-width: 780px) {
  #kv .marquee {
    gap: 9.2307692308vw;
    padding-right: 9.2307692308vw;
    font-size: 25.641025641vw;
    letter-spacing: -0.7692307692vw;
  }
}
#kv .marquee span {
  display: inline-block;
}

@-webkit-keyframes marquee {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

@keyframes marquee {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@-webkit-keyframes cacthMaskAnimText {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}
@keyframes cacthMaskAnimText {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}
#concept {
  position: relative;
}
@media print, screen and (min-width: 780.1px) {
  #concept {
    padding-top: 108px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept {
    margin-top: 100px;
  }
}
@media screen and (max-width: 780px) {
  #concept {
    padding-top: 25.641025641vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #concept .wrapper {
    height: 786px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
  }
}
#concept h2 {
  -webkit-font-feature-settings: "palt" on, "liga" off;
          font-feature-settings: "palt" on, "liga" off;
  font-weight: 700;
  line-height: 130%;
}
@media print, screen and (max-width: 960px) and (min-width: 780.1px) {
  #concept h2 {
    margin-left: 12px;
    white-space: nowrap;
  }
  #concept h2 br.pc {
    display: none;
  }
}
#concept h2 span {
  display: block;
  line-height: 180%;
}
@media print, screen and (min-width: 780.1px) {
  #concept h2 span {
    margin-bottom: 16px;
    font-size: 20px;
    letter-spacing: 0.2px;
  }
}
@media screen and (max-width: 780px) {
  #concept h2 span {
    margin-bottom: 2.0512820513vw;
    font-size: 4.1025641026vw;
    letter-spacing: 0.041025641vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #concept h2 {
    font-size: 58px;
    font-weight: 700;
    line-height: 130%;
    letter-spacing: 0.58px;
    z-index: 2;
  }
}
@media screen and (max-width: 780px) {
  #concept h2 {
    font-size: 8.2051282051vw;
    letter-spacing: 0.0820512821vw;
  }
}
#concept small {
  display: block;
  font-weight: 400;
}
@media print, screen and (min-width: 780.1px) {
  #concept small {
    margin-top: 8px;
    font-size: 14px;
    line-height: 170%;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #concept small {
    margin-top: -1.0256410256vw;
    font-size: 2.5641025641vw;
    letter-spacing: 0.1282051282vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #concept .gallery {
    width: 100%;
    position: absolute;
    left: 0;
    top: calc(50% + 43px);
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    z-index: 1;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .gallery {
    margin-top: 40px;
    position: relative;
    top: 0;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@media screen and (max-width: 780px) {
  #concept .gallery {
    margin-top: 5.641025641vw;
    margin-left: -7.6923076923vw;
    margin-right: -7.6923076923vw;
    width: 100vw;
    position: relative;
  }
}
#concept .gallery .swiper {
  /*アクティブなスライド以外も見えるように*/
  overflow: visible !important;
}
@media print, screen and (min-width: 780.1px) {
  #concept .gallery .swiper {
    max-width: 234px;
    -webkit-transform: translateX(calc(-50% + 80px));
            transform: translateX(calc(-50% + 80px));
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .gallery .swiper {
    -webkit-transform: translateX(calc(-50% + 56px));
            transform: translateX(calc(-50% + 56px));
  }
}
@media screen and (max-width: 780px) {
  #concept .gallery .swiper {
    max-width: 44.6153846154vw;
    -webkit-transform: translateX(-5.1282051282vw);
            transform: translateX(-5.1282051282vw);
  }
}
#concept .gallery .swiper .swiper-wrapper {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 780.1px) {
  #concept .gallery .swiper .swiper-wrapper {
    height: 551px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .gallery .swiper .swiper-wrapper {
    height: 635px;
  }
}
@media screen and (max-width: 780px) {
  #concept .gallery .swiper .swiper-wrapper {
    height: 97.9487179487vw;
  }
}
#concept .gallery .swiper .swiper-wrapper .swiper-slide {
  opacity: 0.2;
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  cursor: pointer;
}
@media print, screen and (min-width: 780.1px) {
  #concept .gallery .swiper .swiper-wrapper .swiper-slide {
    width: 234px;
    height: 416px;
  }
}
@media screen and (max-width: 780px) {
  #concept .gallery .swiper .swiper-wrapper .swiper-slide {
    width: 44.6153846154vw;
    height: 79.2307692308vw;
  }
}
#concept .gallery .swiper .swiper-wrapper .swiper-slide img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
#concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active {
  opacity: 1;
  height: 100%;
}
@media print, screen and (min-width: 780.1px) {
  #concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active {
    width: 310px !important;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active {
    width: 357px !important;
  }
}
@media screen and (max-width: 780px) {
  #concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active {
    width: 55.1282051282vw !important;
  }
}
#concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active::before, #concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active::after {
  visibility: visible;
}
#concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active figcaption,
#concept .gallery .swiper .swiper-wrapper .swiper-slide.swiper-slide-active .nv_circle {
  opacity: 1;
}
#concept .gallery .swiper-pagination {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media print, screen and (min-width: 780.1px) {
  #concept .gallery .swiper-pagination {
    gap: 0;
    bottom: -48px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .gallery .swiper-pagination {
    bottom: -44px;
  }
}
@media screen and (max-width: 780px) {
  #concept .gallery .swiper-pagination {
    bottom: -12.3076923077vw;
  }
}
#concept figure {
  position: relative;
}
#concept figure::before {
  content: "";
  display: block;
  background-color: #262626;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.25;
}
#concept figure img {
  vertical-align: bottom;
}
#concept figure figcaption {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-left-color: var(--Gray-4, #EBF1F7);
  border-left-style: solid;
  color: var(--White, #FFF);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 700;
  line-height: 170%;
  position: absolute;
  left: 0;
  opacity: 0;
}
@media print, screen and (min-width: 780.1px) {
  #concept figure figcaption {
    padding-left: 16px;
    height: 48px;
    border-left-width: 4px;
    font-size: 14px;
    letter-spacing: 0.7px;
    bottom: 24px;
  }
}
@media screen and (max-width: 780px) {
  #concept figure figcaption {
    padding-left: 4.1025641026vw;
    height: 8.7179487179vw;
    border-left-width: 1.0256410256vw;
    font-size: 2.5641025641vw;
    letter-spacing: 0.1282051282vw;
    bottom: 4.1025641026vw;
  }
}
#concept .copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 780.1px) {
  #concept .copy {
    gap: 16px;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    margin-top: auto;
    width: 310px;
    z-index: 2;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .copy {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: 122px;
    width: 100%;
  }
}
@media screen and (max-width: 780px) {
  #concept .copy {
    gap: 4.358974359vw;
    margin-top: 17.4358974359vw;
  }
}
#concept .copy p {
  font-style: normal;
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #concept .copy p {
    font-size: 16px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #concept .copy p {
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #concept .copy a {
    margin-top: 8px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #concept .copy a {
    width: 357px;
  }
}
@media screen and (max-width: 780px) {
  #concept .copy a {
    margin-top: 1.0256410256vw;
  }
}

#features {
  position: relative;
  display: block;
}
@media print, screen and (min-width: 780.1px) {
  #features {
    width: 100%;
  }
  #features #svg_pc5 {
    visibility: visible;
    width: 13889px;
    height: 742px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    position: absolute;
    top: -10px;
    left: -244px;
    z-index: -1;
    pointer-events: none;
  }
  #features #svg_pc5 path {
    stroke: #EBF1F7;
    stroke-linecap: round;
    fill: none;
  }
}
@media screen and (min-width: 780.1px) and (min-width: 834.1px) {
  #features #svg_pc5 path {
    stroke-width: 20px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #features #svg_pc5 path {
    stroke-width: 15px;
  }
}
#features .contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media print, screen and (min-width: 780.1px) {
  #features .contents {
    gap: 80px;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    white-space: nowrap;
  }
}
@media screen and (max-width: 780px) {
  #features .contents {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 15.8974358974vw;
    margin-top: 10.2564102564vw;
  }
}
#features .cont {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  position: relative;
  z-index: 1;
}
@media print, screen and (min-width: 780.1px) {
  #features .cont {
    width: 1440px;
    height: 800px;
    padding: 213px 0 183px 157px;
    white-space: nowrap;
  }
}
@media screen and (max-width: 780px) {
  #features .cont {
    padding-left: 22.5641025641vw;
  }
}
#features .cont::before {
  content: "";
  display: block;
  color: var(--Gray-3, #F7F9FB);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-en);
  font-style: italic;
  font-weight: 600;
  line-height: 100%; /* 400px */
  -webkit-transform: rotate(-6.5deg);
          transform: rotate(-6.5deg);
  position: absolute;
  z-index: -1;
}
@media print, screen and (min-width: 780.1px) {
  #features .cont::before {
    font-size: 400px;
    letter-spacing: -28px;
    top: 70px;
    left: -10px;
  }
}
@media screen and (max-width: 780px) {
  #features .cont::before {
    font-size: 38.4615384615vw;
    letter-spacing: -2.5641025641vw;
    top: -6.1538461538vw;
    left: -8.2051282051vw;
  }
}
#features .cont h3 {
  -webkit-font-feature-settings: "palt" on, "liga" off;
          font-feature-settings: "palt" on, "liga" off;
  font-weight: 700;
  line-height: 130%;
}
@media print, screen and (min-width: 780.1px) {
  #features .cont h3 {
    font-size: 36px;
    letter-spacing: 0.36px;
  }
}
@media screen and (max-width: 780px) {
  #features .cont h3 {
    font-size: 5.1282051282vw;
    letter-spacing: 0.0512820513vw;
  }
}
#features .cont h3 sup {
  font-size: 60%;
  vertical-align: top;
  position: relative;
  top: -0.3em;
}
#features .cont p {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 400;
  line-height: 170%;
  white-space: wrap;
}
@media print, screen and (min-width: 780.1px) {
  #features .cont p {
    margin-top: 64px;
    margin-left: 116px;
    width: 427px;
    font-size: 16px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #features .cont p {
    margin-top: 6.1538461538vw;
    width: 70vw;
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #features .cont p.notes {
    margin-top: 24px;
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #features .cont p.notes {
    margin-top: 4.1025641026vw;
    font-size: 2.5641025641vw;
    letter-spacing: 0.1282051282vw;
  }
}
#features .cont picture.image {
  display: block;
}
@media print, screen and (min-width: 780.1px) {
  #features .cont picture.image {
    aspect-ratio: 583/434;
    clip-path: polygon(0 72px, 100% 0, 100% calc(100% - 72px), 0% 100%);
    width: 583px;
    position: absolute;
    top: 183px;
    right: 0;
  }
}
@media screen and (max-width: 780px) {
  #features .cont picture.image {
    margin-top: 4.1025641026vw;
    aspect-ratio: 303/226;
    clip-path: polygon(0 9.4871794872vw, 100% 0, 100% calc(100% - 9.4871794872vw), 0% 100%);
  }
}
#features .cont picture.image img {
  width: 100%;
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 {
    padding: 158px 40px;
  }
}
@media screen and (max-width: 780px) {
  #features #features0 {
    padding: 20.5128205128vw 0 52.3076923077vw;
  }
}
#features #features0 h2 {
  color: var(--Black, #262626);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-en);
  font-style: italic;
  font-weight: 600;
  line-height: 100%; /* 200px */
  position: relative;
  z-index: 2;
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 h2 {
    width: 1360px;
    height: 484px;
    font-size: 200px;
    letter-spacing: -4px;
  }
}
@media screen and (max-width: 780px) {
  #features #features0 h2 {
    font-size: 16.4102564103vw;
    letter-spacing: -0.3076923077vw;
  }
}
#features #features0 h2 span {
  display: inline-block;
  -webkit-transform: rotate(-6.5deg);
          transform: rotate(-6.5deg);
  position: absolute;
  top: 50%;
  left: 50%;
  opacity: 0;
}
#features #features0 h2 span:nth-child(1) {
  -webkit-transition-delay: 0.15s;
          transition-delay: 0.15s;
  -webkit-animation-delay: 0.1s;
          animation-delay: 0.1s;
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 h2 span:nth-child(1) {
    -webkit-transform: translate(-670px, -192px) rotate(-6.5deg);
            transform: translate(-670px, -192px) rotate(-6.5deg);
  }
}
@media screen and (max-width: 780px) {
  #features #features0 h2 span:nth-child(1) {
    -webkit-transform: translate(-43.5897435897vw, 0) rotate(-6.5deg);
            transform: translate(-43.5897435897vw, 0) rotate(-6.5deg);
  }
}
#features #features0 h2 span:nth-child(2) {
  -webkit-transition-delay: 0.25s;
          transition-delay: 0.25s;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 h2 span:nth-child(2) {
    font-size: 130px;
    letter-spacing: -1px;
    -webkit-transform: translate(-89px, -55px) rotate(-6.5deg);
            transform: translate(-89px, -55px) rotate(-6.5deg);
  }
}
@media screen and (max-width: 780px) {
  #features #features0 h2 span:nth-child(2) {
    font-size: 8.2051282051vw;
    -webkit-transform: translate(-14.8717948718vw, 13.3333333333vw) rotate(-6.5deg);
            transform: translate(-14.8717948718vw, 13.3333333333vw) rotate(-6.5deg);
  }
}
#features #features0 h2 span:nth-child(3) {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
  -webkit-animation-delay: 0.35s;
          animation-delay: 0.35s;
  -webkit-animation-duration: 0.9s;
          animation-duration: 0.9s;
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 h2 span:nth-child(3) {
    letter-spacing: -4.5px;
    -webkit-transform: translate(104px, -75px) rotate(-6.5deg);
            transform: translate(104px, -75px) rotate(-6.5deg);
  }
}
@media screen and (max-width: 780px) {
  #features #features0 h2 span:nth-child(3) {
    -webkit-transform: translate(-3.1794871795vw, 12.3076923077vw) rotate(-6.5deg);
            transform: translate(-3.1794871795vw, 12.3076923077vw) rotate(-6.5deg);
  }
}
#features #features0 h2 span.is-show {
  opacity: 1;
  -webkit-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-duration: 0.1s;
          transition-duration: 0.1s;
  -webkit-animation-name: cacthMaskAnimMid;
          animation-name: cacthMaskAnimMid;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
          animation-timing-function: cubic-bezier(0.550, 0.055, 0.675, 0.190);
}
#features #features0 picture.is-parallax {
  position: absolute;
}
#features #features0 picture.is-parallax img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center top;
     object-position: center top;
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 picture.is-parallax.photo1 {
    clip-path: polygon(0 38px, 100% 0, 100% calc(100% - 38px), 0% 100%);
    width: 310px;
    height: 231px;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-560px, -29px);
            transform: translate(-560px, -29px);
  }
  #features #features0 picture.is-parallax.photo1 img {
    margin-top: -50px;
  }
}
@media screen and (max-width: 780px) {
  #features #features0 picture.is-parallax.photo1 {
    clip-path: polygon(0 3.8vw, 100% 0, 100% calc(100% - 3.8vw), 0% 100%);
    width: 30.7692307692vw;
    height: 22.8205128205vw;
    top: 40.2564102564vw;
    left: 0;
  }
  #features #features0 picture.is-parallax.photo1 img {
    margin-top: -5.1282051282vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 picture.is-parallax.photo2 {
    clip-path: polygon(0 20px, 100% 0, 100% calc(100% - 20px), 0% 100%);
    width: 167px;
    height: 124px;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(20px, 120px);
            transform: translate(20px, 120px);
  }
}
@media screen and (max-width: 780px) {
  #features #features0 picture.is-parallax.photo2 {
    clip-path: polygon(0 2vw, 100% 0, 100% calc(100% - 2vw), 0% 100%);
    width: 17.1794871795vw;
    height: 12.8205128205vw;
    top: 47.9487179487vw;
    left: 45.641025641vw;
  }
  #features #features0 picture.is-parallax.photo2 img {
    margin-top: 2.0512820513vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #features #features0 picture.is-parallax.photo3 {
    clip-path: polygon(0 26px, 100% 0, 100% calc(100% - 26px), 0% 100%);
    width: 220px;
    height: 164px;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(343px, -181px);
            transform: translate(343px, -181px);
  }
  #features #features0 picture.is-parallax.photo3 img {
    margin-top: -18px;
  }
}
@media screen and (max-width: 780px) {
  #features #features0 picture.is-parallax.photo3 {
    clip-path: polygon(0 2.4vw, 100% 0, 100% calc(100% - 2.4vw), 0% 100%);
    width: 20.7692307692vw;
    height: 15.3846153846vw;
    top: 19.7435897436vw;
    right: 0;
  }
}
#features #features1::before {
  content: "01";
}
#features #features2::before {
  content: "02";
}
#features #features3::before {
  content: "03";
}
#features #features4::before {
  content: "04";
}
#features #features5::before {
  content: "05";
}
#features #features6::before {
  content: "06";
}
#features #features7::before {
  content: "07";
}
#features #features8::before {
  content: "08";
}

.indicator-container {
  z-index: 2;
  pointer-events: none;
  opacity: 0;
}
@media print, screen and (min-width: 780.1px) {
  .indicator-container {
    position: fixed;
    left: 20px;
    bottom: 46px;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
}
@media screen and (max-width: 780px) {
  .indicator-container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: fixed;
    top: 50%;
    left: 7.6923076923vw;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
}
@media screen and (max-width: 780px) {
  .indicator-container .indicator {
    margin: -0.5128205128vw 0 !important;
  }
}
.indicator-container .indicator:first-child {
  opacity: 0;
}
.indicator-container.is-active {
  opacity: 1;
}

#scene {
  position: relative;
}
@media print, screen and (min-width: 780.1px) {
  #scene {
    padding-top: 136px;
    padding-bottom: 25vw;
    overflow: hidden;
  }
  #scene #svg_pc6 {
    visibility: visible;
    aspect-ratio: 1572/1864;
    width: 110vw;
    height: auto;
    top: -1.4vw;
    right: -14.25vw;
    -webkit-transform: rotate(17deg);
            transform: rotate(17deg);
  }
}
@media screen and (max-width: 780px) {
  #scene {
    padding-top: 32.8205128205vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #scene .wrapper {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 780px) {
  #scene .wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media print, screen and (min-width: 780.1px) {
  #scene .text {
    padding-top: 12px;
  }
}
#scene .text h2 {
  font-family: var(--font-en);
  font-style: normal;
  font-weight: 600;
  line-height: 120%;
}
@media print, screen and (min-width: 780.1px) {
  #scene .text h2 {
    font-size: 80px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #scene .text h2 {
    font-size: 10.2564102564vw;
    letter-spacing: 0.1025641026vw;
  }
}
#scene .text p {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #scene .text p {
    margin-top: 32px;
    font-size: 16px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #scene .text p {
    margin-top: 3.5897435897vw;
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
#scene .image {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media print, screen and (min-width: 780.1px) {
  #scene .image {
    gap: 40px;
    width: 660px;
  }
}
@media screen and (max-width: 780px) {
  #scene .image {
    margin-top: 10.2564102564vw;
    gap: 6.1538461538vw 3.5897435897vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #scene .image figure {
    width: 310px;
  }
}
@media screen and (max-width: 780px) {
  #scene .image figure {
    width: 40.5128205128vw;
  }
}
#scene .image figure img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media print, screen and (min-width: 780.1px) {
  #scene .image figure img {
    height: 219px;
  }
}
@media screen and (max-width: 780px) {
  #scene .image figure img {
    height: 28.7179487179vw;
  }
}
#scene .image figure figcaption {
  color: var(--Black, #262626);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 700;
  line-height: 100%;
}
@media print, screen and (min-width: 780.1px) {
  #scene .image figure figcaption {
    margin-top: 15px;
    font-size: 16px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #scene .image figure figcaption {
    margin-top: 4.1025641026vw;
    font-size: 3.0769230769vw;
    letter-spacing: 0.1538461538vw;
  }
}

#product {
  background-color: var(--Gray-4, #EBF1F7);
  clip-path: polygon(0 12.1vw, 100% 0, 100% calc(100% - 12.1vw), 0% 100%);
  position: relative;
  z-index: 1;
}
@media print, screen and (min-width: 780.1px) {
  #product {
    margin-top: calc(171px - 25vw);
    padding: 627px 0 263.5px;
  }
}
@media screen and (max-width: 780px) {
  #product {
    margin-top: 32.0512820513vw;
    padding: 83.0769230769vw 0 28.2051282051vw;
  }
}
#product .product {
  position: relative;
  z-index: 2;
}
@media print, screen and (min-width: 780.1px) {
  #product .product {
    margin: auto;
    max-width: 894px;
  }
}
@media screen and (max-width: 780px) {
  #product .product {
    padding-left: 7.6923076923vw;
    position: relative;
  }
}
#product .product h3 {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-en);
  font-weight: 600;
  line-height: 100%;
}
@media print, screen and (min-width: 780.1px) {
  #product .product h3 {
    font-size: 48px;
    letter-spacing: 0.48px;
  }
}
@media screen and (max-width: 780px) {
  #product .product h3 {
    font-size: 9.2307692308vw;
    letter-spacing: 0.0923076923vw;
  }
}
#product .product h3 small {
  display: block;
  line-height: 100%;
}
@media print, screen and (min-width: 780.1px) {
  #product .product h3 small {
    margin-bottom: 8px;
    font-size: 14px;
    letter-spacing: 0.14px;
  }
}
@media screen and (max-width: 780px) {
  #product .product h3 small {
    margin-bottom: 1.0256410256vw;
    font-size: 2.5641025641vw;
    letter-spacing: 0.0256410256vw;
  }
}
#product .product p {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-jp);
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #product .product p {
    margin-top: 32px;
    font-size: 16px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #product .product p {
    margin-top: 6.1538461538vw;
    width: 35.8974358974vw;
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  #product .product .btn_shop {
    margin-top: 32px;
    width: 200px;
    height: 40px;
  }
}
@media screen and (max-width: 780px) {
  #product .product .btn_shop {
    margin-top: 5.641025641vw;
    width: 84.6153846154vw;
    height: 16.4102564103vw;
    font-size: 4.1025641026vw;
    letter-spacing: 0.041025641vw;
  }
}
#product .product #productImage {
  position: relative;
}
#product .product #productImage picture {
  position: absolute;
}
@media print, screen and (min-width: 780.1px) {
  #product .product #productImage picture {
    width: 660px;
    top: calc(50% - 502px);
    left: calc(50% - 214px);
  }
}
@media screen and (max-width: 780px) {
  #product .product #productImage picture {
    width: 84.6153846154vw;
    top: -88.7179487179vw;
    left: 0.5128205128vw;
  }
}
#product .product #productImage picture img {
  width: 100%;
  -webkit-transition: -webkit-transform 1.2s cubic-bezier(0.175, 0.885, 0.320, 1.275);
  transition: -webkit-transform 1.2s cubic-bezier(0.175, 0.885, 0.320, 1.275);
  transition: transform 1.2s cubic-bezier(0.175, 0.885, 0.320, 1.275);
  transition: transform 1.2s cubic-bezier(0.175, 0.885, 0.320, 1.275), -webkit-transform 1.2s cubic-bezier(0.175, 0.885, 0.320, 1.275);
}
@media print, screen and (min-width: 780.1px) {
  #product .spec {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 24px 40px;
    margin-top: 136px;
  }
}
@media screen and (max-width: 780px) {
  #product .spec {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 6.2820512821vw;
    margin-top: 16.6666666667vw;
  }
}
#product .spec dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid var(--White, #FFF);
  position: relative;
}
@media print, screen and (min-width: 780.1px) {
  #product .spec dl {
    gap: 40px;
    padding-top: 16px;
    width: calc((100% - 40px) / 2);
    max-width: 543px;
  }
}
@media screen and (max-width: 780px) {
  #product .spec dl {
    gap: 6.4102564103vw;
    padding-top: 2.0512820513vw;
  }
}
#product .spec dl::before {
  content: "";
  display: block;
  background: var(--Gray-5, #79858D);
  height: 1px;
  position: absolute;
  top: -1px;
  left: 0;
}
@media print, screen and (min-width: 780.1px) {
  #product .spec dl::before {
    width: 16px;
  }
}
@media screen and (max-width: 780px) {
  #product .spec dl::before {
    width: 4.1025641026vw;
  }
}
#product .spec dl dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  color: var(--Gray-5, #79858D);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #product .spec dl dt {
    width: 193px;
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #product .spec dl dt {
    width: 35.8974358974vw;
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
#product .spec dl dd {
  color: var(--Black, #262626);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #product .spec dl dd {
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #product .spec dl dd {
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
#product .wrapper p {
  color: var(--Black, #262626);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-jp);
  font-style: normal;
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #product .wrapper p {
    margin-top: 40px;
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #product .wrapper p {
    margin-top: 10.2564102564vw;
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
#product .oblique {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  white-space: nowrap;
  -webkit-transform: rotate(-6.5deg);
          transform: rotate(-6.5deg);
  position: absolute;
  left: 0;
}
@media print, screen and (min-width: 780.1px) {
  #product .oblique {
    top: 160px;
  }
}
@media screen and (max-width: 780px) {
  #product .oblique {
    top: 38.7179487179vw;
  }
}
#product .marquee {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: var(--White, #FFF);
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-en);
  font-style: italic;
  font-weight: 600;
  line-height: 100%;
  white-space: nowrap;
  will-change: transform;
  -webkit-animation: marquee 20s linear infinite;
          animation: marquee 20s linear infinite;
}
@media print, screen and (min-width: 780.1px) {
  #product .marquee {
    gap: 100px;
    padding-right: 100px;
    font-size: 345px;
    letter-spacing: -10.35px;
  }
}
@media screen and (max-width: 780px) {
  #product .marquee {
    gap: 12.8205128205vw;
    padding-right: 12.8205128205vw;
    font-size: 23.8461538462vw;
    letter-spacing: -0.7153846154vw;
  }
}
#product .marquee span {
  display: inline-block;
}

#craftmanship {
  position: relative;
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship #svg_pc7 {
    visibility: visible;
    aspect-ratio: 1403/1944;
    width: 98vw;
    height: auto;
    bottom: 29.16vw;
    left: -6.3vw;
  }
}
#craftmanship .bgImage {
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  z-index: -2;
  overflow: hidden;
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship .bgImage {
    -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(55%, #000));
    -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 55%);
            mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(55%, #000));
            mask-image: linear-gradient(to bottom, transparent 0%, #000 55%);
  }
}
@media screen and (max-width: 780px) {
  #craftmanship .bgImage {
    -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(35%, #000));
    -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 35%);
            mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(35%, #000));
            mask-image: linear-gradient(to bottom, transparent 0%, #000 35%);
    bottom: -30.7692307692vw;
    aspect-ratio: 1440/1080;
  }
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship .bgImage img {
    width: 100%;
    aspect-ratio: 1440/1080;
  }
}
@media screen and (max-width: 780px) {
  #craftmanship .bgImage img {
    width: 149.7435897436vw;
    height: auto;
    -o-object-position: -28.9743589744vw -12.3076923077vw !important;
       object-position: -28.9743589744vw -12.3076923077vw !important;
  }
}
#craftmanship .wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship .wrapper {
    gap: 32px;
    padding-top: 187px;
    padding-bottom: 764px;
  }
}
@media screen and (max-width: 780px) {
  #craftmanship .wrapper {
    gap: 6.1538461538vw;
    padding-top: 25.1282051282vw;
    padding-right: 7.1794871795vw;
    padding-bottom: 59.4871794872vw;
  }
}
#craftmanship h2 {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-family: var(--font-en);
  font-weight: 600;
  line-height: 120%;
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship h2 {
    margin-bottom: 32px;
    font-size: 80px;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #craftmanship h2 {
    font-size: 10.2564102564vw;
    letter-spacing: 0.1025641026vw;
  }
}
#craftmanship h3 {
  -webkit-font-feature-settings: "palt" on, "liga" off;
          font-feature-settings: "palt" on, "liga" off;
  font-weight: 700;
  line-height: 130%;
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship h3 {
    margin-top: 32px;
    margin-left: auto;
    width: 660px;
    font-size: 26px;
    letter-spacing: 0.26px;
  }
}
@media screen and (max-width: 780px) {
  #craftmanship h3 {
    margin-top: 5.1282051282vw;
    font-size: 4.1025641026vw;
    letter-spacing: 0.041025641vw;
  }
}
#craftmanship p {
  -webkit-font-feature-settings: "palt" on;
          font-feature-settings: "palt" on;
  font-weight: 400;
}
@media print, screen and (min-width: 780.1px) {
  #craftmanship p {
    margin-left: auto;
    width: 660px;
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.8px;
  }
}
@media screen and (max-width: 780px) {
  #craftmanship p {
    font-size: 3.5897435897vw;
    line-height: 172%;
    letter-spacing: 0.1794871795vw;
  }
  #craftmanship p + h3 {
    margin-top: 3.8461538462vw;
  }
}

#news {
  background-color: #AEB9C0;
  clip-path: polygon(0 12.1vw, 100% 0, 100% 100%, 0% 100%);
  position: relative;
  z-index: 1;
}
@media print, screen and (min-width: 780.1px) {
  #news {
    margin-top: 160px;
    padding-top: 314px;
    padding-bottom: 120px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #news {
    margin-top: 260px;
    padding-top: 100px;
    padding-bottom: 94px;
  }
}
@media screen and (max-width: 780px) {
  #news {
    margin-top: 39.4871794872vw;
    padding-top: 31.7948717949vw;
    padding-bottom: 16.4102564103vw;
  }
}
@media print, screen and (max-width: 960px) and (min-width: 780.1px) {
  #news .wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 54px;
  }
}
#news h2 {
  font-family: var(--font-en);
  font-style: normal;
  font-weight: 600;
  line-height: 120%;
}
@media print, screen and (min-width: 780.1px) {
  #news h2 {
    font-size: 64px;
    letter-spacing: 0.64px;
  }
}
@media screen and (max-width: 780px) {
  #news h2 {
    font-size: 8.2051282051vw;
    letter-spacing: 0.0820512821vw;
  }
}
#news .newslist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 780.1px) {
  #news .newslist {
    gap: 40px;
    margin-top: 10px;
  }
}
@media screen and (max-width: 780px) {
  #news .newslist {
    gap: 6.1538461538vw;
    margin-top: 10.2564102564vw;
  }
}
#news .newslist dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media print, screen and (min-width: 780.1px) {
  #news .newslist dl {
    gap: 44px;
    max-width: 776px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  #news .newslist dl {
    gap: 24px;
  }
}
@media screen and (max-width: 780px) {
  #news .newslist dl {
    gap: 4.1025641026vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#news .newslist dl dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  color: var(--White, #FFF);
  font-family: var(--font-en);
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
}
@media print, screen and (min-width: 780.1px) {
  #news .newslist dl dt {
    padding-top: 4px;
    font-size: 14px;
    letter-spacing: 0.14px;
  }
}
@media screen and (max-width: 780px) {
  #news .newslist dl dt {
    font-size: 3.0769230769vw;
    letter-spacing: 0.0307692308vw;
  }
}
#news .newslist dl dd {
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  #news .newslist dl dd {
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #news .newslist dl dd {
    font-size: 2.5641025641vw;
    letter-spacing: 0.1282051282vw;
  }
}
#news .newslist dl dd a {
  text-decoration: underline;
}
#news .newslist dl dd a:hover {
  text-decoration: none;
  background: linear-gradient(71deg, rgba(255, 142, 67, 0.9) 9.11%, rgba(12, 106, 165, 0.9) 98.97%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media print, screen and (min-width: 780.1px) {
  #news .newslist p {
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}
@media screen and (max-width: 780px) {
  #news .newslist p {
    font-size: 2.5641025641vw;
    letter-spacing: 0.1282051282vw;
  }
}

.bg_line {
  position: relative;
  pointer-events: none;
}

svg[data-animate-path] {
  visibility: hidden;
  position: absolute;
  z-index: -1;
  pointer-events: none;
}
@media print, screen and (min-width: 780.1px) {
  svg[data-animate-path]#svg_pc1 {
    visibility: visible;
    aspect-ratio: 1655/427;
    width: 114.93vw;
    height: auto;
    top: 520px;
    left: -6.25vw;
  }
  svg[data-animate-path]#svg_pc4 {
    visibility: visible;
    aspect-ratio: 1687/523;
    width: 121vw;
    height: auto;
    top: 0;
    left: -9.4vw;
    -webkit-transform: translateY(-118%) rotate(-2.67deg);
            transform: translateY(-118%) rotate(-2.67deg);
  }
}
@media screen and (max-width: 780px) {
  svg[data-animate-path]#svg_sp1 {
    visibility: visible;
    width: 135.8974358974vw;
    height: 415.641025641vw;
    top: 78.4615384615vw;
    left: -28.2051282051vw;
  }
  svg[data-animate-path]#svg_sp2 {
    visibility: visible;
    width: 130.2564102564vw;
    height: 54.8717948718vw;
    top: 616.1538461538vw;
    left: -11.0256410256vw;
  }
  svg[data-animate-path]#svg_sp3 {
    visibility: visible;
    width: 114.1025641026vw;
    height: 60vw;
    top: 965.1282051282vw;
    left: -7.6923076923vw;
  }
  svg[data-animate-path]#svg_sp4 {
    visibility: visible;
    width: 171.5384615385vw;
    height: 1458.4615384615vw;
    top: 1009.2307692308vw;
    left: -39.4871794872vw;
  }
  svg[data-animate-path]#svg_sp5 {
    visibility: visible;
    width: 142.3076923077vw;
    height: 465.641025641vw;
    top: 2715.3846153846vw;
    left: -8.2051282051vw;
  }
  svg[data-animate-path]#svg_sp6 {
    visibility: visible;
    width: 63.0769230769vw;
    height: 254.6153846154vw;
    top: 3226.6666666667vw;
    left: -17.4358974359vw;
  }
}
svg[data-animate-path] path {
  stroke: #EBF1F7;
  stroke-linecap: round;
  fill: none;
}
@media screen and (min-width: 834.1px) {
  svg[data-animate-path] path {
    stroke-width: 20px;
  }
}
@media print, screen and (max-width: 960px) and (min-width: 780.1px) {
  svg[data-animate-path] path {
    stroke-width: 15px;
  }
}
@media screen and (max-width: 780px) {
  svg[data-animate-path] path {
    stroke-width: 2.5641025641vw;
  }
}

.modal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--Logo-Gradation, linear-gradient(71deg, rgba(255, 142, 67, 0.9) 9.11%, rgba(12, 106, 165, 0.9) 98.97%));
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.is-modal .modal {
  opacity: 1;
  pointer-events: auto;
}
.modal #modal_movie {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100vw;
  height: 100dvh;
  position: fixed;
  top: 0;
  right: 0;
  -webkit-overflow-scrolling: touch;
  visibility: hidden;
  pointer-events: none;
}
.modal #modal_movie.is-active {
  visibility: visible;
  pointer-events: auto;
}
.modal #modal_movie .iframe-container {
  position: relative;
  aspect-ratio: 16/9;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_movie .iframe-container {
    width: calc(100% - 314px);
    max-height: calc(100vh - 167px);
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_movie .iframe-container {
    width: 100%;
  }
}
.modal #modal_movie iframe {
  -o-object-fit: cover;
     object-fit: cover;
  height: auto;
  border: none;
}
.modal #modal_snsMovie {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100vw;
  height: 100dvh;
  overflow: hidden;
  position: fixed;
  top: 0;
  right: 0;
  -webkit-overflow-scrolling: touch;
  visibility: hidden;
  pointer-events: none;
}
.modal #modal_snsMovie.is-active {
  visibility: visible;
  pointer-events: auto;
}
.modal #modal_snsMovie .slide,
.modal #modal_snsMovie .swiper-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; /* 余計なスタイルがない場合でも適用 */
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
.modal #modal_snsMovie .swiper-slide {
  display: block;
  width: 100vw;
  position: relative;
  overflow: visible;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .swiper-slide {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 100vh;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .swiper-slide {
    height: 100dvh;
  }
}
.modal #modal_snsMovie .swiper-slide .iframe-container {
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .swiper-slide .iframe-container {
    width: 371px;
    height: 660px;
    pointer-events: auto;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .swiper-slide .iframe-container {
    width: 107.5%;
    height: auto;
    min-height: 100dvh;
    -o-object-fit: cover;
       object-fit: cover;
    pointer-events: none;
  }
}
.modal #modal_snsMovie .swiper-slide img {
  opacity: 1;
  pointer-events: none;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .swiper-slide img {
    width: 371px;
    height: 660px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .swiper-slide img {
    width: 100%;
    height: 100%;
  }
}
.modal #modal_snsMovie .swiper-slide p {
  color: var(--White, #FFF);
  font-weight: 700;
  line-height: 170%;
  position: absolute;
  opacity: 0;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .swiper-slide p {
    font-size: 14px;
    letter-spacing: 0.7px;
    left: 40px;
    bottom: 40px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .swiper-slide p {
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
    left: 7.6923076923vw;
    bottom: 10.2564102564vw;
  }
}
.modal #modal_snsMovie .swiper-slide-active img {
  opacity: 0;
  -webkit-transition: opacity 0.5s 0.5s;
  transition: opacity 0.5s 0.5s;
}
.modal #modal_snsMovie .swiper-slide-active p {
  opacity: 1;
  -webkit-transition: opacity 0.4s 0.8s;
  transition: opacity 0.4s 0.8s;
}
.modal #modal_snsMovie .nv_circle {
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 1;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .nv_circle {
    width: 80px;
    height: 80px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .nv_circle {
    width: 6.1538461538vw;
    height: 6.1538461538vw;
  }
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .nv_circle::before {
    border-width: 2px;
    opacity: 0.5;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .nv_circle::before {
    display: none;
  }
}
.modal #modal_snsMovie .nv_circle::after {
  content: "";
  display: block;
  background: #fff;
  -webkit-mask-image: url(../img/icon_arrow_mini.svg);
          mask-image: url(../img/icon_arrow_mini.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .nv_circle::after {
    width: 16px;
    height: 16px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .nv_circle::after {
    width: 6.1538461538vw;
    height: 6.1538461538vw;
  }
}
.modal #modal_snsMovie .nv_circle .circle circle {
  stroke-dasharray: 251.32;
  stroke-dashoffset: 251.32;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .nv_circle:hover::before {
    opacity: 0;
  }
  .modal #modal_snsMovie .nv_circle:hover .circle {
    opacity: 1;
  }
  .modal #modal_snsMovie .nv_circle:hover .circle circle {
    stroke-dashoffset: 0;
  }
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .swiper-button-prev {
    left: 40px;
  }
  .modal #modal_snsMovie .swiper-button-prev::after {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
  }
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_snsMovie .swiper-button-next {
    right: 40px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_snsMovie .swiper-button-next {
    top: auto;
    left: 50%;
    bottom: 4.1025641026vw;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
    -webkit-transform-origin: center;
            transform-origin: center;
  }
  .modal #modal_snsMovie .swiper-button-next::after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
    width: 6.1538461538vw;
  }
}
.modal #modal_snsMovie .swiper-button-disabled {
  opacity: 0.2;
}
.modal #modal_concept {
  width: 100%;
  height: 100%;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.215, 0.610, 0.355, 1.000);
  transition: -webkit-transform 0.4s cubic-bezier(0.215, 0.610, 0.355, 1.000);
  transition: transform 0.4s cubic-bezier(0.215, 0.610, 0.355, 1.000);
  transition: transform 0.4s cubic-bezier(0.215, 0.610, 0.355, 1.000), -webkit-transform 0.4s cubic-bezier(0.215, 0.610, 0.355, 1.000);
  position: relative;
  z-index: 1;
}
.modal #modal_concept.is-active {
  -webkit-transform: translateX(0);
          transform: translateX(0);
  pointer-events: auto;
}
.modal #modal_concept::before {
  content: "";
  display: block;
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept::before {
    width: 50%;
    min-width: 720px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept::before {
    width: 92.3076923077vw;
  }
}
.modal #modal_concept .wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  pointer-events: none;
  z-index: 3;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept .wrapper {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 48px;
    padding: 40px 88px;
    width: 50%;
    min-width: 720px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept .wrapper {
    gap: 8.2051282051vw;
    padding: 16.4102564103vw 12.3076923077vw;
    width: 92.3076923077vw;
    overflow-y: scroll;
  }
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept figure img.logo {
    width: 205px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept figure img.logo {
    width: 43.0769230769vw;
  }
}
.modal #modal_concept h2 {
  font-weight: 700;
  line-height: 130%;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept h2 {
    font-size: 30px;
    letter-spacing: 0.3px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept h2 {
    font-size: 5.1282051282vw;
    letter-spacing: 0.0512820513vw;
  }
}
.modal #modal_concept .bodycopy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-style: normal;
  font-weight: 400;
  line-height: 170%;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept .bodycopy {
    gap: 24px;
    font-size: 16px;
    letter-spacing: 0.8px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  .modal #modal_concept .bodycopy {
    gap: 16px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept .bodycopy {
    gap: 4.1025641026vw;
    font-size: 3.5897435897vw;
    letter-spacing: 0.1794871795vw;
  }
}
.modal #modal_concept .bodycopy ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept .bodycopy ul {
    gap: 16px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept .bodycopy ul {
    gap: 2.0512820513vw;
  }
}
.modal #modal_concept svg {
  pointer-events: none;
}
.modal #modal_concept #line-modal {
  position: absolute;
  opacity: 0;
  z-index: 2;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept #line-modal {
    width: 1300px;
    right: -122px;
    bottom: -26px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept #line-modal {
    width: 149.7435897436vw;
    bottom: -22.8vw;
    left: -41.8vw;
    -webkit-transform: rotate(4deg);
            transform: rotate(4deg);
  }
}
.modal #modal_concept.is-active #line-modal {
  opacity: 1;
}
.modal #modal_concept path {
  stroke: var(--Gray-4, #EBF1F7);
  stroke-linecap: round;
  fill: none;
}
@media print, screen and (min-width: 780.1px) {
  .modal #modal_concept path {
    stroke-width: 20px;
  }
}
@media screen and (max-width: 780px) {
  .modal #modal_concept path {
    stroke-width: 2.5641025641vw;
  }
}
.modal #toggleMuteButton,
.modal .nv_modalClose {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 100%;
  background-color: var(--Gray-3, #F7F9FB);
  position: fixed;
  -webkit-transform: scale(0);
          transform: scale(0);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.680, -0.550, 0.265, 1.550);
  transition: -webkit-transform 0.4s cubic-bezier(0.680, -0.550, 0.265, 1.550);
  transition: transform 0.4s cubic-bezier(0.680, -0.550, 0.265, 1.550);
  transition: transform 0.4s cubic-bezier(0.680, -0.550, 0.265, 1.550), -webkit-transform 0.4s cubic-bezier(0.680, -0.550, 0.265, 1.550);
  cursor: pointer;
  z-index: 10;
}
.is-modal .modal #toggleMuteButton,
.is-modal .modal .nv_modalClose {
  -webkit-transform: scale(1);
          transform: scale(1);
}
@media print, screen and (min-width: 780.1px) {
  .modal #toggleMuteButton,
  .modal .nv_modalClose {
    width: 48px;
    height: 48px;
    top: 40px;
    right: 40px;
  }
}
@media print, screen and (min-width: 780.1px) and (max-width: 960px) and (min-width: 780.1px) {
  .modal #toggleMuteButton,
  .modal .nv_modalClose {
    top: 53px;
    right: 48px;
  }
}
@media print, screen and (min-width: 780.1px) {
  .modal #toggleMuteButton:hover,
  .modal .nv_modalClose:hover {
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
}
@media screen and (max-width: 780px) {
  .modal #toggleMuteButton,
  .modal .nv_modalClose {
    width: 12.3076923077vw;
    height: 12.3076923077vw;
    right: 7.6923076923vw;
    bottom: 10.2564102564vw;
  }
}
.modal #toggleMuteButton::after,
.modal .nv_modalClose::after {
  content: "";
  display: block;
  background-color: #262626;
  -webkit-mask-image: url(../img/icon_close.svg);
          mask-image: url(../img/icon_close.svg);
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@media print, screen and (min-width: 780.1px) {
  .modal #toggleMuteButton::after,
  .modal .nv_modalClose::after {
    width: 10px;
    height: 10px;
  }
}
@media screen and (max-width: 780px) {
  .modal #toggleMuteButton::after,
  .modal .nv_modalClose::after {
    width: 2.5641025641vw;
    height: 2.5641025641vw;
  }
}
.modal #toggleMuteButton {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  bottom: 28.2051282051vw;
}
.modal #toggleMuteButton::after {
  width: 5.1282051282vw;
  height: 5.1282051282vw;
  -webkit-mask-image: url(../img/icon_sound-on.svg);
          mask-image: url(../img/icon_sound-on.svg);
}
.modal #toggleMuteButton.is-muted::after {
  -webkit-mask-image: url(../img/icon_sound-off.svg);
          mask-image: url(../img/icon_sound-off.svg);
}

@media print, screen and (min-width: 780.1px) {
  #contact {
    margin-top: -18.263vw;
  }
}
@media screen and (max-width: 780px) {
  #contact {
    margin-top: -13.8461538462vw;
    padding-top: 30.7692307692vw;
  }
}