@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500&family=Roboto:wght@300;400;500&family=Sawarabi+Mincho&display=swap");
@import url("https://fonts.googleapis.com/css2?family=EB+Garamond&display=swap");
#loader {
  width: 100%;
  height: 100vh;
  height: -webkit-fill-available;
  background-image: url(../images/main1.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-color: #FFF;
  position: fixed;
  left: 0px;
  top: 0px;
  z-index: 99999;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center; }
  #loader .bar {
    width: 100%;
    background-color: rgba(255, 255, 255, 0.25);
    position: absolute;
    left: 0px;
    bottom: 0px; }
    #loader .bar span {
      width: 0;
      height: 5px;
      background-color: #FFF;
      display: block; }

article {
  width: 50%;
  margin: 0 0 0 -25%;
  position: fixed;
  bottom: -50px;
  left: 50%;
  z-index: 99;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center; }
  article::after {
    content: '';
    width: 2px;
    height: 115px;
    background-color: #FFF; }
  article span {
    color: #FFF;
    font-family: "Roboto", sans-serif;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.1em;
    margin-bottom: 15px; }

section {
  scroll-snap-align: start;
  /* sec2 */
  /* sec3 */
  /* sec4 */
  /* sec5 */
  /* sec6 */ }
  section .btn {
    width: 150px;
    height: 50px;
    position: absolute;
    right: 50px;
    bottom: 50px;
    z-index: 10; }
    section .btn a {
      width: 100%;
      height: 100%;
      background-color: #FFF;
      display: flex;
      flex-direction: row;
      flex-wrap: nowrap;
      justify-content: center;
      align-items: center; }
      section .btn a span {
        color: #e65a23;
        font-family: "Noto Sans JP", sans-serif;
        font-size: 1.6rem;
        font-weight: 400;
        line-height: 1;
        letter-spacing: 0.1em;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: fle-start;
        align-items: center;
        position: relative;
        z-index: 1;
        transition: all 0.25s ease-in 0s; }
        section .btn a span::before {
          content: '';
          width: 6px;
          height: 11px;
          margin: 0 10px 0 0;
          background-image: url(../../common/images/arrow.svg);
          background-repeat: no-repeat;
          background-position: center;
          background-size: contain; }
      section .btn a:hover span {
        opacity: 0.6; }
  section h4 a {
    text-align: left;
    text-indent: 999%;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: all 0.25s ease-in 0s; }
    section h4 a:hover {
      opacity: 0.7; }
  section .pager {
    text-align: left;
    line-height: 1;
    width: auto;
    position: absolute;
    left: 50px;
    bottom: 50px;
    z-index: 100; }
    section .pager span.swiper-pagination-bullet {
      width: 120px;
      height: 3px;
      background-color: #000;
      margin: 0px;
      border-radius: 0px;
      opacity: 1; }
      section .pager span.swiper-pagination-bullet.swiper-pagination-bullet-active {
        background-color: #FFF; }
      section .pager span.swiper-pagination-bullet:not(:first-child) {
        margin-left: 5px; }
  section.sec1 {
    width: 100%; }
    section.sec1:before {
      content: '';
      width: 100%;
      height: 100%;
      background-image: url(../images/main2.jpg);
      background-repeat: no-repeat;
      background-position: center;
      background-size: cover;
      position: absolute;
      left: 0px;
      top: 0px;
      z-index: 0;
      opacity: 0;
      transition: opacity 0.5s ease-in; }
    section.sec1:after {
      content: '';
      width: 100%;
      height: 100%;
      background-image: url(../images/main3.jpg);
      background-repeat: no-repeat;
      background-position: center;
      background-size: cover;
      position: absolute;
      left: 0px;
      top: 0px;
      z-index: 2;
      opacity: 0;
      transition: opacity 0.5s ease-in; }
    section.sec1 .inner {
      width: 100%;
      height: 100vh;
      display: flex;
      flex-direction: row;
      flex-wrap: nowrap;
      justify-content: center;
      align-items: center; }
      section.sec1 .inner:before {
        content: '';
        width: 100%;
        height: 100%;
        background-image: url(../images/main1.jpg);
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
        position: absolute;
        left: 0px;
        top: 0px;
        z-index: 1;
        opacity: 0;
        transition: opacity 0.5s ease-in; }
      section.sec1 .inner h1 {
        width: 130px;
        margin: 0 0 0 -65px;
        position: absolute;
        top: 10%;
        left: 50%;
        z-index: 10; }
        section.sec1 .inner h1 a {
          background-image: url(../../common/images/logo.svg);
          text-align: left;
          text-indent: 999%;
          white-space: nowrap;
          display: block;
          overflow: hidden;
          background-repeat: no-repeat;
          background-position: center;
          background-size: contain;
          height: 60px; }
      section.sec1 .inner ul {
        position: relative;
        z-index: 5;
        display: flex;
        flex-direction: column;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center; }
        section.sec1 .inner ul li a {
          text-align: left;
          text-indent: 999%;
          white-space: nowrap;
          display: block;
          overflow: hidden;
          background-repeat: no-repeat;
          background-position: center;
          background-size: contain;
          opacity: 0.6;
          transition: all 0.25s ease-in 0s; }
        section.sec1 .inner ul li:nth-child(1) {
          width: 300px; }
          section.sec1 .inner ul li:nth-child(1) a {
            background-image: url(../../common/images/name_product1.svg);
            height: 53px; }
        section.sec1 .inner ul li:nth-child(2) {
          width: 803px; }
          section.sec1 .inner ul li:nth-child(2) a {
            background-image: url(../../common/images/name_product2.svg);
            height: 53px; }
        section.sec1 .inner ul li:nth-child(3) {
          width: 402px; }
          section.sec1 .inner ul li:nth-child(3) a {
            background-image: url(../../common/images/name_product3.svg);
            height: 53px; }
        section.sec1 .inner ul li:not(:last-child) {
          margin-bottom: 60px; }
      section.sec1 .inner .mainvisual {
        width: 100%;
        height: 100%;
        position: absolute;
        left: 0px;
        top: 0px;
        z-index: -1; }
        section.sec1 .inner .mainvisual .swiper-wrapper {
          width: 100%;
          height: 100%; }
          section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide {
            width: 100%;
            height: 100%;
            background-repeat: no-repeat;
            background-position: center;
            background-size: cover; }
            section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide.mv1 {
              background-image: url(../images/main1.jpg); }
            section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide.mv2 {
              background-image: url(../images/main2.jpg); }
            section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide.mv3 {
              background-image: url(../images/main3.jpg); }
    section.sec1.scene1 .inner::before {
      opacity: 1; }
    section.sec1.scene1 .inner ul li:nth-child(1) a {
      opacity: 1; }
    section.sec1.scene2::before {
      opacity: 1; }
    section.sec1.scene2 .inner ul li:nth-child(2) a {
      opacity: 1; }
    section.sec1.scene3::after {
      opacity: 1; }
    section.sec1.scene3 .inner ul li:nth-child(3) a {
      opacity: 1; }
  section.sec2 {
    width: 100%;
    height: 100vh;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    background-color: #FFF; }
    section.sec2 .inner {
      width: 920px; }
      section.sec2 .inner h3 {
        width: 864px;
        height: 52px;
        background-image: url(../images/lead.svg);
        text-align: left;
        text-indent: 999%;
        white-space: nowrap;
        display: block;
        overflow: hidden;
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        margin: 0 auto 20px auto; }
      section.sec2 .inner h4 {
        width: 290px;
        height: 27px;
        background-image: url(../images/lead_en.svg);
        text-align: left;
        text-indent: 999%;
        white-space: nowrap;
        display: block;
        overflow: hidden;
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        margin: 0 auto 80px auto; }
      section.sec2 .inner p {
        color: #000;
        font-family: "EB Garamond", "Sawarabi Mincho", sans-serif;
        font-size: 2.3rem;
        font-weight: 400;
        line-height: 4.5rem;
        letter-spacing: 0em;
        text-align: justify;
        font-feature-settings: "palt"; }
  section.sec3 {
    width: 100%;
    position: relative; }
    section.sec3 h4 {
      width: 227px;
      position: absolute;
      left: 50px;
      bottom: 83px;
      z-index: 5; }
      section.sec3 h4 a {
        background-image: url(../../common/images/name_product1.svg);
        height: 40px; }
    section.sec3 .visual1 {
      width: 100%;
      height: 100vh; }
      section.sec3 .visual1 .swiper-wrapper {
        width: 100%;
        height: 100%; }
        section.sec3 .visual1 .swiper-wrapper .swiper-slide {
          width: 100%;
          height: 100%;
          background-repeat: no-repeat;
          background-position: center;
          background-size: cover; }
          section.sec3 .visual1 .swiper-wrapper .swiper-slide.v1-1 {
            background-image: url(../images/visual1_1.jpg); }
          section.sec3 .visual1 .swiper-wrapper .swiper-slide.v1-2 {
            background-image: url(../images/visual1_2.jpg); }
          section.sec3 .visual1 .swiper-wrapper .swiper-slide.v1-3 {
            background-image: url(../images/visual1_3.jpg); }
  section.sec4 {
    width: 100%;
    position: relative; }
    section.sec4 h4 {
      width: 622px;
      position: absolute;
      left: 50px;
      bottom: 83px;
      z-index: 5; }
      section.sec4 h4 a {
        background-image: url(../../common/images/name_product2.svg);
        height: 53px; }
    section.sec4 .visual2 {
      width: 100%;
      height: 100vh; }
      section.sec4 .visual2 .swiper-wrapper {
        width: 100%;
        height: 100%; }
        section.sec4 .visual2 .swiper-wrapper .swiper-slide {
          width: 100%;
          height: 100%;
          background-repeat: no-repeat;
          background-position: center;
          background-size: cover; }
          section.sec4 .visual2 .swiper-wrapper .swiper-slide.v2-1 {
            background-image: url(../images/visual2_1.jpg); }
          section.sec4 .visual2 .swiper-wrapper .swiper-slide.v2-2 {
            background-image: url(../images/visual2_2.jpg); }
          section.sec4 .visual2 .swiper-wrapper .swiper-slide.v2-3 {
            background-image: url(../images/visual2_3.jpg); }
  section.sec5 {
    width: 100%;
    position: relative; }
    section.sec5 h4 {
      width: 301px;
      position: absolute;
      left: 50px;
      bottom: 83px;
      z-index: 5; }
      section.sec5 h4 a {
        background-image: url(../../common/images/name_product3.svg);
        height: 40px; }
    section.sec5 .visual3 {
      width: 100%;
      height: 100vh; }
      section.sec5 .visual3 .swiper-wrapper {
        width: 100%;
        height: 100%; }
        section.sec5 .visual3 .swiper-wrapper .swiper-slide {
          width: 100%;
          height: 100%;
          background-repeat: no-repeat;
          background-position: center;
          background-size: cover; }
          section.sec5 .visual3 .swiper-wrapper .swiper-slide.v3-1 {
            background-image: url(../images/visual3_1.jpg); }
          section.sec5 .visual3 .swiper-wrapper .swiper-slide.v3-2 {
            background-image: url(../images/visual3_2.jpg); }
          section.sec5 .visual3 .swiper-wrapper .swiper-slide.v3-3 {
            background-image: url(../images/visual3_3.jpg); }
  section.sec6 {
    width: 100%;
    height: 100vh;
    position: relative; }
    section.sec6::before {
      content: '';
      width: 100%;
      height: 100%;
      background-image: url(../images/visual_deco.jpg);
      background-repeat: no-repeat;
      background-position: center;
      background-size: cover;
      position: absolute;
      left: 0px;
      top: 0px; }

footer {
  scroll-snap-align: start; }

/* --------------------------------------- Media Queries Smartphone --------------------------------------- */
@media screen and (max-width: 768px) {
  #loader {
    background-image: url(../images_sp/main1.jpg); }

  article {
    width: 50%;
    margin: 0 0 0 -25%;
    position: fixed;
    bottom: -25px;
    left: 50%;
    z-index: 99;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center; }
    article::after {
      content: '';
      width: 2px;
      height: 75px;
      background-color: #FFF; }
    article span {
      color: #FFF;
      font-family: "Roboto", sans-serif;
      font-size: 1.2rem;
      font-weight: 600;
      line-height: 1;
      letter-spacing: 0.1em;
      margin-bottom: 10px; }

  section {
    scroll-snap-align: start;
    /* sec2 */
    /* sec3 */
    /* sec4 */
    /* sec5 */
    /* sec6 */ }
    section .btn {
      width: 100%;
      height: 65px;
      right: 0px;
      bottom: 0px;
      z-index: 10; }
    section h4 a {
      text-align: left;
      text-indent: 999%;
      white-space: nowrap;
      display: block;
      overflow: hidden;
      background-repeat: no-repeat;
      background-position: center;
      background-size: contain;
      transition: all 0.25s ease-in 0s; }
      section h4 a:hover {
        opacity: 0.7; }
    section .pager {
      text-align: center;
      width: 100%;
      left: 0px;
      bottom: 80px;
      z-index: 100; }
      section .pager span.swiper-pagination-bullet {
        width: 80px;
        height: 3px;
        background-color: #000;
        margin: 0px;
        border-radius: 0px;
        opacity: 1; }
        section .pager span.swiper-pagination-bullet.swiper-pagination-bullet-active {
          background-color: #FFF; }
        section .pager span.swiper-pagination-bullet:not(:first-child) {
          margin-left: 5px; }
    section.sec1 .inner {
      height: -webkit-fill-available; }
      section.sec1 .inner h1 {
        width: 65px;
        margin: 0px;
        top: 35px;
        left: 20px; }
        section.sec1 .inner h1 a {
          height: 30px; }
      section.sec1 .inner ul li a {
        opacity: 0.6;
        transition: all 0.25s ease-in 0s; }
      section.sec1 .inner ul li:nth-child(1) {
        width: 113px; }
        section.sec1 .inner ul li:nth-child(1) a {
          height: 20px; }
      section.sec1 .inner ul li:nth-child(2) {
        width: 303px; }
        section.sec1 .inner ul li:nth-child(2) a {
          height: 20px; }
      section.sec1 .inner ul li:nth-child(3) {
        width: 151px; }
        section.sec1 .inner ul li:nth-child(3) a {
          height: 20px; }
      section.sec1 .inner ul li:not(:last-child) {
        margin-bottom: 40px; }
      section.sec1 .inner ul li.active a {
        opacity: 1; }
      section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide.mv1 {
        background-image: url(../images_sp/main1.jpg); }
      section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide.mv2 {
        background-image: url(../images_sp/main2.jpg); }
      section.sec1 .inner .mainvisual .swiper-wrapper .swiper-slide.mv3 {
        background-image: url(../images_sp/main3.jpg); }
    section.sec1.scene1 .inner::before {
      opacity: 1; }
    section.sec1.scene1 .inner ul li:nth-child(1) a {
      opacity: 1; }
    section.sec1.scene2::before {
      opacity: 1; }
    section.sec1.scene2 .inner ul li:nth-child(2) a {
      opacity: 1; }
    section.sec1.scene3::after {
      opacity: 1; }
    section.sec1.scene3 .inner ul li:nth-child(3) a {
      opacity: 1; }
    section.sec2 {
      width: 100%;
      height: auto;
      display: flex;
      flex-direction: row;
      flex-wrap: nowrap;
      justify-content: center;
      align-items: center;
      background-color: #FFF; }
      section.sec2 .inner {
        width: 100%;
        padding: 80px 25px 60px 25px; }
        section.sec2 .inner h3 {
          width: 281px;
          height: 74px;
          background-image: url(../images_sp/lead_sp.svg);
          margin: 0 auto 25px auto; }
        section.sec2 .inner h4 {
          width: 193px;
          height: 18px;
          margin: 0 auto 75px auto; }
        section.sec2 .inner p {
          color: #000;
          font-family: "EB Garamond", "Sawarabi Mincho", sans-serif;
          font-size: 1.6rem;
          font-weight: 400;
          line-height: 2.8rem;
          letter-spacing: 0em; }
    section.sec3 {
      width: 100%;
      position: relative; }
      section.sec3 h4 {
        width: 114px;
        margin: 0 0 0 -57px;
        position: absolute;
        left: 50%;
        bottom: 105px; }
        section.sec3 h4 a {
          height: 20px; }
      section.sec3 .visual1 .swiper-wrapper .swiper-slide.v1-1 {
        background-image: url(../images_sp/visual1_1.jpg); }
      section.sec3 .visual1 .swiper-wrapper .swiper-slide.v1-2 {
        background-image: url(../images_sp/visual1_2.jpg); }
      section.sec3 .visual1 .swiper-wrapper .swiper-slide.v1-3 {
        background-image: url(../images_sp/visual1_3.jpg); }
    section.sec4 {
      width: 100%;
      position: relative; }
      section.sec4 h4 {
        width: 172px;
        margin: 0 0 0 -86px;
        position: absolute;
        left: 50%;
        bottom: 105px; }
        section.sec4 h4 a {
          background-image: url(../images_sp/name_product2.svg);
          height: 51px; }
      section.sec4 .visual2 .swiper-wrapper .swiper-slide {
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover; }
        section.sec4 .visual2 .swiper-wrapper .swiper-slide.v2-1 {
          background-image: url(../images_sp/visual2_1.jpg); }
        section.sec4 .visual2 .swiper-wrapper .swiper-slide.v2-2 {
          background-image: url(../images_sp/visual2_2.jpg); }
        section.sec4 .visual2 .swiper-wrapper .swiper-slide.v2-3 {
          background-image: url(../images_sp/visual2_3.jpg); }
    section.sec5 {
      width: 100%;
      position: relative; }
      section.sec5 h4 {
        width: 151px;
        margin: 0 0 0 -75px;
        left: 50%;
        bottom: 105px; }
        section.sec5 h4 a {
          height: 20px; }
      section.sec5 .visual3 .swiper-wrapper .swiper-slide.v3-1 {
        background-image: url(../images_sp/visual3_1.jpg); }
      section.sec5 .visual3 .swiper-wrapper .swiper-slide.v3-2 {
        background-image: url(../images_sp/visual3_2.jpg); }
      section.sec5 .visual3 .swiper-wrapper .swiper-slide.v3-3 {
        background-image: url(../images_sp/visual3_3.jpg); }
    section.sec6 {
      width: 100%;
      height: 100vw;
      position: relative; }
      section.sec6::before {
        background-image: url(../images_sp/visual_deco.jpg); } }
