@charset "UTF-8";
/*--------------------
共通設定
----------------------*/
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  transition: .4s;
  color: #614336; }
  a.disabled {
    pointer-events: none;
    text-decoration: none;
    color: #614336; }
  a:hover {
    text-decoration: none;
    color: #614336; }
  a:visited {
    color: #614336; }

ul, ol {
  list-style: none; }

.pc {
  display: block; }
  @media screen and (max-width: 1080px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media screen and (max-width: 1080px) {
    .sp {
      display: block; } }

html {
  scroll-behavior: smooth; }

body {
  overflow-x: visible;
  min-height: 100vh;
  min-height: calc(var(--vh, 1vh) * 100);
  height: -webkit-fill-available;
  min-height: -webkit-fill-available;
  -webkit-overflow-scrolling: auto; }

.fs-l-page {
  overflow: visible; }

p {
  margin: 0;
  padding: 0; }

.wrapper {
  margin: 0 auto !important; }

main {
  max-width: 100%; }

.mainBox {
  margin: 0 auto !important; }

footer {
  position: relative;
  z-index: 9999; }

.fadeIn {
  opacity: 0;
  transition: 1.2s;
  transform: translateY(50px); }
  .fadeIn.visible {
    opacity: 1;
    transform: translateY(0); }

/*--------------------------------------------*/
.js-trigger {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s ease-out, transform 1s ease-out; }

.is-loaded .js-trigger {
  opacity: 1;
  transform: translateY(0); }

@media (hover: hover) {
  .box:hover .hidden {
    opacity: 1; } }
/*--------------------------------------------*/
#collection {
  min-height: 100vh;
  min-height: calc(var(--vh, 1vh) * 100);
  height: -webkit-fill-available;
  min-height: -webkit-fill-available;
  -webkit-overflow-scrolling: auto;
  /* main */ }
  #collection.lp_wrapper {
    margin: 0 auto;
    box-sizing: border-box;
    padding: 0;
    letter-spacing: 0;
    font-size: 14px;
    text-align: center;
    font-family: "hiragino-kaku-gothic-pron", sans-serif;
    color: #614336;
    font-weight: 400;
    font-style: normal;
    line-height: 1.5; }
  #collection .loading {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden; }
    #collection .loading .loading_logo {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      z-index: 100;
      display: block; }
      @media screen and (max-width: 1080px) {
        #collection .loading .loading_logo {
          width: 80%; } }
    #collection .loading .swiper-slide {
      width: 100%;
      height: 100vh; }
      #collection .loading .swiper-slide img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
  #collection .main {
    width: 100%;
    display: none; }
    #collection .main .kv_1 {
      width: 100%;
      position: relative;
      padding-top: 10%; }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_1 {
          padding-top: 52%; } }
      #collection .main .kv_1 .center {
        width: 80%;
        margin: 0 auto;
        max-width: 782px; }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_1 .center {
            width: 50%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_1 .center {
            width: 60%; } }
      #collection .main .kv_1 .left {
        position: absolute;
        top: 0;
        left: 0;
        text-align: left; }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_1 .left {
            width: 40%;
            left: -20%;
            text-align: right;
            top: 0; } }
        #collection .main .kv_1 .left img {
          max-width: 400px; }
          @media screen and (max-width: 1800px) {
            #collection .main .kv_1 .left img {
              width: 65%; } }
          @media screen and (max-width: 1080px) {
            #collection .main .kv_1 .left img {
              width: 100%; } }
      #collection .main .kv_1 .right {
        position: absolute;
        top: 0;
        right: 0;
        text-align: right; }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_1 .right {
            width: 40%; } }
        @media screen and (max-width: 600px) {
          #collection .main .kv_1 .right {
            width: 50%; } }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_1 .right img {
            width: 65%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_1 .right img {
            width: 100%; } }
    #collection .main .kv_2 {
      position: relative;
      margin-top: -30px; }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_2 {
          margin-top: 0; } }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_2 .center {
          padding-top: 15%; } }
      @media screen and (max-width: 600px) {
        #collection .main .kv_2 .center {
          margin: 0 auto; } }
      #collection .main .kv_2 .center .ttl {
        position: relative;
        z-index: 100; }
        #collection .main .kv_2 .center .ttl img {
          max-width: 200px; }
          @media screen and (max-width: 600px) {
            #collection .main .kv_2 .center .ttl img {
              width: 30%;
              max-width: 120px; } }
        #collection .main .kv_2 .center .ttl h1 {
          font-size: 1.2em;
          margin: 3.0em auto; }
          @media screen and (max-width: 600px) {
            #collection .main .kv_2 .center .ttl h1 {
              font-size: 3.5vw; } }
        #collection .main .kv_2 .center .ttl p {
          font-size: 1.0em;
          line-height: 2.2;
          font-weight: 400; }
          @media screen and (max-width: 600px) {
            #collection .main .kv_2 .center .ttl p {
              font-size: 2.5vw;
              line-height: 1.8; } }
      #collection .main .kv_2 .left {
        position: absolute;
        top: -150px;
        left: 7%;
        text-align: left; }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_2 .left {
            left: 5%; }
            #collection .main .kv_2 .left img {
              width: 65%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_2 .left {
            text-align: right;
            left: -15%;
            top: 0;
            width: 30%; }
            #collection .main .kv_2 .left img {
              width: 100%; } }
      #collection .main .kv_2 .right {
        position: absolute;
        top: 30px;
        right: 0;
        text-align: right;
        z-index: -1; }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_2 .right img {
            width: 65%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_2 .right {
            top: 35%;
            width: 35%; }
            #collection .main .kv_2 .right img {
              width: 100%; } }
    #collection .main .kv_3 {
      position: relative;
      display: flex;
      justify-content: space-between;
      align-items: center;
      width: 90%;
      margin: 6.0em auto 0; }
      @media screen and (max-width: 1800px) {
        #collection .main .kv_3 {
          width: 95%;
          margin-top: 5%; } }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_3 {
          width: 100%;
          margin-top: 20%;
          align-items: flex-end; } }
      #collection .main .kv_3 .left {
        text-align: left; }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_3 .left img {
            width: 65%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_3 .left {
            width: 65%; }
            #collection .main .kv_3 .left img {
              width: 100%; } }
      #collection .main .kv_3 .right {
        padding-top: 10%;
        padding-right: 5%; }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_3 .right {
            padding-right: 0; }
            #collection .main .kv_3 .right img {
              width: 65%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_3 .right {
            width: 35%;
            text-align: right;
            padding-top: 0;
            padding-bottom: 10%; }
            #collection .main .kv_3 .right img {
              margin-left: -10%; } }
    #collection .main .kv_4 {
      margin-top: -400px;
      position: relative;
      z-index: 100; }
      @media screen and (max-width: 1800px) {
        #collection .main .kv_4 {
          margin-top: -300px; }
          #collection .main .kv_4 img {
            width: 30%; } }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_4 {
          margin-top: 10%; }
          #collection .main .kv_4 img {
            width: 50%; } }
    #collection .main .kv_5 {
      position: relative;
      width: 70%;
      max-width: 1200px;
      text-align: right;
      margin: 3.0em auto 0; }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_5 {
          width: 80%;
          margin-top: -1.5em; } }
      @media screen and (max-width: 600px) {
        #collection .main .kv_5 {
          margin-top: -1.0em; } }
      @media screen and (max-width: 1800px) {
        #collection .main .kv_5 img {
          width: 45%; } }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_5 img {
          width: 60%; } }
      #collection .main .kv_5 .left {
        position: absolute;
        bottom: -150px;
        left: 450px; }
        @media screen and (max-width: 1800px) {
          #collection .main .kv_5 .left {
            bottom: -100px;
            left: 33%; }
            #collection .main .kv_5 .left img {
              width: 80%; } }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_5 .left {
            width: 35%;
            left: 15%;
            bottom: -30%; }
            #collection .main .kv_5 .left img {
              width: 100%; } }
    #collection .main .kv_6 {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      width: 95%;
      margin: 0 auto 0 0; }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_6 {
          width: 100%; } }
      #collection .main .kv_6 .left {
        text-align: left; }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_6 .left img {
            margin-left: -15%; } }
      #collection .main .kv_6 .right {
        text-align: right;
        padding-top: 300px; }
        @media screen and (max-width: 1080px) {
          #collection .main .kv_6 .right {
            padding-top: 150px; } }
        @media screen and (max-width: 600px) {
          #collection .main .kv_6 .right {
            padding-top: 75px; } }
      @media screen and (max-width: 1800px) {
        #collection .main .kv_6 img {
          width: 70%; } }
      @media screen and (max-width: 1080px) {
        #collection .main .kv_6 {
          margin-top: 20%; } }
      @media screen and (max-width: 600px) {
        #collection .main .kv_6 {
          margin-top: 25%; } }
    #collection .main .ttlBox {
      width: 90%;
      margin: -5% auto 10%;
      position: relative; }
      @media screen and (max-width: 600px) {
        #collection .main .ttlBox {
          margin: 10% auto 30%; } }
      #collection .main .ttlBox img {
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        max-width: 2.0em; }
        @media screen and (max-width: 600px) {
          #collection .main .ttlBox img {
            max-width: 1.2em; } }
      #collection .main .ttlBox h2 {
        text-align: left;
        font-weight: 600;
        font-size: 2.5em;
        margin-bottom: 7em; }
        @media screen and (max-width: 600px) {
          #collection .main .ttlBox h2 {
            font-size: 7.0vw; } }
      #collection .main .ttlBox p {
        text-align: left;
        line-height: 2.0;
        font-size: 1.2em;
        letter-spacing: 0.1em;
        padding-left: 10%; }
        @media screen and (max-width: 600px) {
          #collection .main .ttlBox p {
            font-size: 3.0vw; } }
    #collection .main .js-parallax {
      position: relative;
      transform-origin: center center; }
    #collection .main .youtubeBox {
      max-width: 1000px;
      margin: 0 auto;
      width: 90%; }
      @media screen and (max-width: 1080px) {
        #collection .main .youtubeBox {
          margin-bottom: 20%; } }
      #collection .main .youtubeBox iframe {
        width: 100%;
        aspect-ratio: 16 / 9; }
        @media screen and (max-width: 600px) {
          #collection .main .youtubeBox iframe {
            max-height: 250px; } }
  #collection .stickyBox .sticky {
    position: sticky;
    position: -webkit-sticky;
    top: 0;
    display: block;
    overflow: visible !important;
    contain: paint;
    height: auto;
    z-index: 150; }
    #collection .stickyBox .sticky.lineupBox {
      left: 0;
      transform: translateX(calc(-100% + 60px));
      max-width: 500px;
      background: #614336;
      padding: 50px 60px 50px;
      transition: 0.4s;
      opacity: 1;
      visibility: visible; }
      @media screen and (max-width: 1080px) {
        #collection .stickyBox .sticky.lineupBox {
          max-width: none;
          width: 100%; } }
      #collection .stickyBox .sticky.lineupBox.is-hidden {
        opacity: 0;
        visibility: hidden; }
      @media screen and (max-width: 1080px) {
        #collection .stickyBox .sticky.lineupBox {
          transform: translateY(calc(100vh - 50px));
          padding: 50px 30px; } }
      #collection .stickyBox .sticky.lineupBox p.btn {
        cursor: pointer;
        color: #ffffff;
        font-size: 1.0em;
        position: absolute;
        top: 0;
        right: 0;
        padding-top: 50px;
        height: 100%; }
        @media screen and (max-width: 1080px) {
          #collection .stickyBox .sticky.lineupBox p.btn {
            left: 0;
            padding-top: 0;
            right: auto;
            padding-left: 50px;
            height: auto;
            width: 100%;
            text-align: left; } }
        #collection .stickyBox .sticky.lineupBox p.btn span {
          white-space: pre;
          writing-mode: vertical-rl;
          display: inline-block;
          line-height: 60px;
          font-size: 100%; }
          @media screen and (max-width: 1080px) {
            #collection .stickyBox .sticky.lineupBox p.btn span {
              line-height: 50px;
              writing-mode: horizontal-tb; } }
        #collection .stickyBox .sticky.lineupBox p.btn::before, #collection .stickyBox .sticky.lineupBox p.btn::after {
          content: "";
          width: 12px;
          height: 1px;
          background: #ffffff;
          position: absolute;
          top: 30px;
          left: 25px; }
          @media screen and (max-width: 1080px) {
            #collection .stickyBox .sticky.lineupBox p.btn::before, #collection .stickyBox .sticky.lineupBox p.btn::after {
              top: 25px; } }
        #collection .stickyBox .sticky.lineupBox p.btn::before {
          transform: rotate(90deg); }
      #collection .stickyBox .sticky.lineupBox.active {
        transform: translateX(0); }
        @media screen and (max-width: 1080px) {
          #collection .stickyBox .sticky.lineupBox.active {
            transform: translateY(calc(100vh - 100%)); } }
        #collection .stickyBox .sticky.lineupBox.active p.btn::after {
          display: none; }
          @media screen and (max-width: 1080px) {
            #collection .stickyBox .sticky.lineupBox.active p.btn::after {
              display: block; } }
        @media screen and (max-width: 1080px) {
          #collection .stickyBox .sticky.lineupBox.active p.btn::before {
            transform: rotate(0); } }
      #collection .stickyBox .sticky.lineupBox ul {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-wrap: wrap; }
        #collection .stickyBox .sticky.lineupBox ul li {
          width: calc(100%/2 - 2%);
          margin-bottom: 4%; }
  #collection .stickyBox .lineBox {
    width: 90%;
    margin: 10% auto; }
    #collection .stickyBox .lineBox .border {
      position: relative;
      text-align: center; }
      #collection .stickyBox .lineBox .border::before {
        content: "";
        position: absolute;
        left: 50%;
        bottom: 0;
        width: 0;
        height: 1px;
        background: #614336;
        transform: translateX(-50%);
        transform-origin: center;
        transition: 2s; }
      #collection .stickyBox .lineBox .border.visible::before {
        width: 100%; }
  #collection section {
    overflow-x: hidden;
    padding: 10% 0; }
    @media screen and (max-width: 600px) {
      #collection section {
        padding: 13% 0;
        margin-bottom: 20%; } }
    #collection section#item1 {
      margin-top: -500px; }
      @media screen and (max-width: 600px) {
        #collection section#item1 {
          margin-top: -450px; } }
    #collection section h2 {
      font-size: 2.0em;
      width: 90%;
      margin: 0 auto 10%;
      letter-spacing: 0.2em; }
      @media screen and (max-width: 600px) {
        #collection section h2 {
          font-size: 5.0vw;
          width: 70%; } }
      #collection section h2.right {
        text-align: right; }
        @media screen and (max-width: 600px) {
          #collection section h2.right {
            margin-bottom: 25%; } }
      #collection section h2.left {
        text-align: left;
        margin-bottom: 5%; }
  #collection .swiper_2, #collection .swiper_3 {
    overflow: visible;
    padding-bottom: 70px; }
    #collection .swiper_2 .swiper-slide, #collection .swiper_3 .swiper-slide {
      transition: .7s; }
    #collection .swiper_2 .swiper-slide-active, #collection .swiper_3 .swiper-slide-active {
      opacity: 1;
      transform: translateY(-50px);
      z-index: 1; }
    #collection .swiper_2 .swiper-button-next, #collection .swiper_2 .swiper-button-prev, #collection .swiper_3 .swiper-button-next, #collection .swiper_3 .swiper-button-prev {
      top: auto;
      bottom: 0;
      width: 15%; }
      @media screen and (max-width: 600px) {
        #collection .swiper_2 .swiper-button-next, #collection .swiper_2 .swiper-button-prev, #collection .swiper_3 .swiper-button-next, #collection .swiper_3 .swiper-button-prev {
          width: 22%; } }
    #collection .swiper_2 .swiper-button-prev, #collection .swiper_3 .swiper-button-prev {
      left: calc(100%/3 - 50px + 20px); }
      @media screen and (max-width: 600px) {
        #collection .swiper_2 .swiper-button-prev, #collection .swiper_3 .swiper-button-prev {
          left: calc(100%/3 - 60px); } }
      #collection .swiper_2 .swiper-button-prev::before, #collection .swiper_3 .swiper-button-prev::before {
        content: "";
        position: absolute;
        top: 50%;
        left: 0;
        width: 100%;
        height: 1px;
        background: #614336; }
    #collection .swiper_2 .swiper-button-next, #collection .swiper_3 .swiper-button-next {
      right: calc(100%/3 - 50px + 20px); }
      @media screen and (max-width: 600px) {
        #collection .swiper_2 .swiper-button-next, #collection .swiper_3 .swiper-button-next {
          right: calc(100%/3 - 60px); } }
      #collection .swiper_2 .swiper-button-next::before, #collection .swiper_3 .swiper-button-next::before {
        content: "";
        position: absolute;
        top: 50%;
        right: 0;
        width: 100%;
        height: 1px;
        background: #614336; }
    #collection .swiper_2 .swiper-button-prev::after, #collection .swiper_2 .swiper-button-next::after, #collection .swiper_3 .swiper-button-prev::after, #collection .swiper_3 .swiper-button-next::after {
      bottom: 0;
      top: 0;
      content: "";
      height: 10px;
      margin: auto;
      position: absolute;
      width: 10px; }
      @media screen and (max-width: 600px) {
        #collection .swiper_2 .swiper-button-prev::after, #collection .swiper_2 .swiper-button-next::after, #collection .swiper_3 .swiper-button-prev::after, #collection .swiper_3 .swiper-button-next::after {
          height: 8px;
          width: 8px; } }
    #collection .swiper_2 .swiper-button-prev::after, #collection .swiper_3 .swiper-button-prev::after {
      border-bottom: 1px solid #614336;
      border-left: 1px solid #614336;
      transform: rotate(45deg);
      left: 0; }
    #collection .swiper_2 .swiper-button-next::after, #collection .swiper_3 .swiper-button-next::after {
      border-bottom: 1px solid #614336;
      border-left: 1px solid #614336;
      transform: rotate(-135deg);
      right: 0; }
    #collection .swiper_2 .swiper-pagination, #collection .swiper_3 .swiper-pagination {
      font-size: .9em; }
      @media screen and (max-width: 600px) {
        #collection .swiper_2 .swiper-pagination, #collection .swiper_3 .swiper-pagination {
          font-size: 2.0vw;
          line-height: 2.0; } }
      #collection .swiper_2 .swiper-pagination span, #collection .swiper_3 .swiper-pagination span {
        font-size: 100%; }
        @media screen and (max-width: 600px) {
          #collection .swiper_2 .swiper-pagination span, #collection .swiper_3 .swiper-pagination span {
            font-size: 110%; } }
  #collection .box {
    position: relative; }
    #collection .box img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    #collection .box .hidden {
      opacity: 0;
      position: absolute;
      top: 0;
      left: 0;
      transition: opacity 0.3s ease; }
      #collection .box .hidden:hover {
        opacity: 1; }
  #collection .creditBox {
    width: 90%;
    margin: 5% auto;
    text-align: left; }
    @media screen and (max-width: 600px) {
      #collection .creditBox {
        margin: 15% auto; } }
    #collection .creditBox button {
      font-size: 1.2em;
      font-weight: 600;
      letter-spacing: 0.1em;
      position: relative;
      padding-left: 32px; }
      @media screen and (max-width: 600px) {
        #collection .creditBox button {
          font-size: 3.2vw;
          padding-left: 30px; } }
      #collection .creditBox button::before, #collection .creditBox button::after {
        content: "";
        position: absolute;
        width: 16px;
        height: .5px;
        background: #614336;
        left: 0;
        top: 50%;
        transform: translateY(-50%); }
      #collection .creditBox button::before {
        transform: translateY(-50%) rotate(90deg); }
      #collection .creditBox button.active::before {
        transform: translateY(-50%) rotate(45deg); }
      #collection .creditBox button.active::after {
        transform: translateY(-50%) rotate(-45deg); }
    #collection .creditBox .moreBox {
      align-items: flex-start;
      justify-content: space-between;
      padding: 3%;
      visibility: hidden;
      opacity: 0;
      transition: .4s;
      animation: fadeout .6s ease forwards;
      display: none; }
      @media screen and (max-width: 600px) {
        #collection .creditBox .moreBox {
          padding: 5%; } }
      #collection .creditBox .moreBox.active {
        display: flex;
        opacity: 1;
        visibility: visible;
        animation: fadeIn .6s ease forwards; }
        @media screen and (max-width: 1080px) {
          #collection .creditBox .moreBox.active {
            flex-direction: column; } }
      @media screen and (max-width: 600px) {
        #collection .creditBox .moreBox div:nth-child(1) {
          margin-bottom: 5%; } }
      #collection .creditBox .moreBox div p {
        font-size: 1.0em;
        line-height: 2.0; }
        @media screen and (max-width: 600px) {
          #collection .creditBox .moreBox div p {
            font-size: 2.8vw;
            line-height: 1.8; } }
      #collection .creditBox .moreBox div ul {
        display: flex;
        flex-direction: column;
        justify-content: flex-start; }
        #collection .creditBox .moreBox div ul li {
          width: 100%;
          margin-bottom: 1.0em;
          line-height: 1.4; }
          @media screen and (max-width: 600px) {
            #collection .creditBox .moreBox div ul li {
              width: 90%; } }
          #collection .creditBox .moreBox div ul li .day {
            text-decoration: none;
            font-size: 0.8em;
            margin-left: 25px; }
            @media screen and (max-width: 600px) {
              #collection .creditBox .moreBox div ul li .day {
                font-size: 2.8vw; } }
          #collection .creditBox .moreBox div ul li a {
            display: flex;
            align-items: flex-end;
            justify-content: flex-start;
            white-space: nowrap;
            font-size: 1.0em; }
            @media screen and (max-width: 600px) {
              #collection .creditBox .moreBox div ul li a {
                font-size: 2.9vw; } }
            #collection .creditBox .moreBox div ul li a span {
              font-size: 100%;
              text-decoration: underline;
              display: block;
              margin-right: 16px; }
              #collection .creditBox .moreBox div ul li a span:first-child {
                text-decoration: none;
                width: 25px;
                margin-right: 0; }
              #collection .creditBox .moreBox div ul li a span:nth-child(2) {
                width: 200px; }
              #collection .creditBox .moreBox div ul li a span:nth-child(3) {
                width: 100px;
                margin-right: 0; }
            #collection .creditBox .moreBox div ul li a.disabled span {
              text-decoration: none; }
  #collection .swiper_box {
    width: 90%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center; }
    @media screen and (max-width: 1080px) {
      #collection .swiper_box {
        display: block; } }
    #collection .swiper_box .swiper_3 {
      width: calc(100%/2);
      overflow: hidden; }
      @media screen and (max-width: 1080px) {
        #collection .swiper_box .swiper_3 {
          width: 100%;
          padding-bottom: 24px; } }
    #collection .swiper_box .thumbnail {
      margin-left: 24px;
      width: calc(100%/2 - 24px); }
      @media screen and (max-width: 1080px) {
        #collection .swiper_box .thumbnail {
          width: 100%;
          margin-left: 0; } }
      #collection .swiper_box .thumbnail .swiper-slide {
        opacity: .5;
        transition: opacity .5s;
        width: calc(100% / 7 - 10px); }
        #collection .swiper_box .thumbnail .swiper-slide.swiper-slide-thumb-active {
          opacity: 1;
          width: auto; }
    #collection .swiper_box .creditBox {
      width: 100%; }
      #collection .swiper_box .creditBox .moreBox {
        flex-direction: column; }
        #collection .swiper_box .creditBox .moreBox div {
          width: 100%; }
          #collection .swiper_box .creditBox .moreBox div:first-child {
            margin-bottom: 32px; }
  #collection .flex_box {
    display: flex;
    align-items: center;
    width: 90%;
    margin: 0 auto; }
    @media screen and (max-width: 1080px) {
      #collection .flex_box {
        display: block; } }
    #collection .flex_box .box {
      width: 50%; }
      @media screen and (max-width: 1080px) {
        #collection .flex_box .box {
          width: 100%; } }
    #collection .flex_box .creditBox {
      width: calc(50% - 24px);
      margin-left: 24px; }
      @media screen and (max-width: 1080px) {
        #collection .flex_box .creditBox {
          width: 100%;
          margin-left: 0; } }
      #collection .flex_box .creditBox .moreBox {
        flex-direction: column; }
        #collection .flex_box .creditBox .moreBox div {
          width: 100%; }
          #collection .flex_box .creditBox .moreBox div:first-child {
            margin-bottom: 32px; }
  #collection .footerBox {
    max-width: 1200px;
    margin: 10% auto 20%;
    padding-top: 10%; }
    @media screen and (max-width: 1080px) {
      #collection .footerBox {
        width: 90%; } }
    #collection .footerBox .center_img {
      margin-bottom: 10%; }
      @media screen and (max-width: 600px) {
        #collection .footerBox .center_img {
          padding-top: 20%; } }
      #collection .footerBox .center_img video {
        width: 90%;
        max-width: 500px; }
        @media screen and (max-width: 1080px) {
          #collection .footerBox .center_img video {
            max-width: 400px; } }
    #collection .footerBox .flex {
      display: flex;
      justify-content: space-between;
      align-items: flex-end; }
      @media screen and (max-width: 1080px) {
        #collection .footerBox .flex {
          width: 85%;
          margin: 30% auto;
          padding-bottom: 20%; } }
      #collection .footerBox .flex div {
        width: 50%; }
        @media screen and (max-width: 600px) {
          #collection .footerBox .flex div {
            width: auto; } }
        #collection .footerBox .flex div p {
          text-align: left;
          font-size: 1.0em;
          line-height: 2.2; }
          @media screen and (max-width: 1080px) {
            #collection .footerBox .flex div p {
              font-size: 0.8em; } }
          @media screen and (max-width: 600px) {
            #collection .footerBox .flex div p {
              font-size: 2.8vw; } }
        #collection .footerBox .flex div .sns {
          display: flex;
          flex-direction: column;
          justify-content: flex-start;
          width: fit-content;
          margin: 10% 0; }
          @media screen and (max-width: 1080px) {
            #collection .footerBox .flex div .sns {
              margin: 15% 0; } }
          @media screen and (max-width: 600px) {
            #collection .footerBox .flex div .sns {
              margin: 20% 0; } }
          #collection .footerBox .flex div .sns a {
            display: block;
            margin-bottom: 3.0em; }
            @media screen and (max-width: 1080px) {
              #collection .footerBox .flex div .sns a {
                margin-bottom: 2.0em; } }
            @media screen and (max-width: 600px) {
              #collection .footerBox .flex div .sns a {
                margin-bottom: 1.0em; } }
            @media screen and (max-width: 600px) {
              #collection .footerBox .flex div .sns a img {
                max-width: 15px; } }
        @media screen and (max-width: 1080px) {
          #collection .footerBox .flex div:nth-child(1) {
            padding-bottom: 20%; } }
        #collection .footerBox .flex div:nth-child(2) {
          text-align: right; }
          @media screen and (max-width: 600px) {
            #collection .footerBox .flex div:nth-child(2) img {
              max-width: 85px; } }

/* collection */
.touch-device .box .swiper_2 .box {
  cursor: pointer; }
  .touch-device .box .swiper_2 .box.tapped .hidden {
    opacity: 1; }
  .touch-device .box .swiper_2 .box:not(.tapped) .hidden {
    opacity: 0; }

@keyframes fadeIn {
  from {
    transform: translateY(-50px); }
  to {
    transform: translateY(0); } }
@keyframes fadeout {
  from {
    transform: translateY(0); }
  to {
    transform: translateY(-50px); } }
