@charset "UTF-8";
/* -------------------------------------------
共通
------------------------------------------- */
body {
  width: 100%;
  color: #000;
  font-size: 12px;
  font-family: sofia-pro, 游ゴシック, "Yu Gothic", 游ゴシック体, YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1;
}

@media screen and (min-width: 751px) {
  .sp-only {
    display: none;
  }
}

@media screen and (max-width: 750px) {
  .pc-only {
    display: none;
  }
}

/* -------------------------------------------
ヘッダー
------------------------------------------- */
@media screen and (min-width: 751px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 10000;
  }
  .header .logo {
    position: absolute;
    left: 30px;
    top: 20px;
    width: 79px;
  }
  .header .logo img {
    width: 100%;
    height: auto;
  }
  .header .menu {
    position: absolute;
    right: 27px;
    top: 29px;
  }
  .header .menu-list li {
    display: inline-block;
    font-size: 14px;
    letter-spacing: 0.09em;
    line-height: 19px;
    vertical-align: middle;
  }
  .header .menu-list li.shop {
    margin-right: 24px;
  }
  .header .menu-list li.sns {
    font-size: 17px;
    margin-right: 15px;
  }
  .header .menu-list li.sns a {
    padding: 1px;
  }
  .header .menu-list li:last-child {
    margin-right: 0;
  }
  .header a {
    display: block;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
  }
  .header a:hover {
    opacity: 0.5;
  }
}

@media screen and (max-width: 750px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
  }
  .header .logo {
    position: absolute;
    left: 30px;
    top: 20px;
    width: 60px;
  }
  .header .logo img {
    width: 100%;
    height: auto;
  }
  .header .menu {
    position: absolute;
    right: 17px;
    top: 20px;
  }
  .header .menu-list li {
    display: inline-block;
    font-size: 12px;
    letter-spacing: 0.09em;
    line-height: 19px;
    vertical-align: middle;
  }
  .header .menu-list li.shop {
    margin-right: 16px;
  }
  .header .menu-list li.sns {
    font-size: 16px;
    margin-right: 12px;
  }
  .header .menu-list li.sns a {
    padding: 1px;
  }
  .header .menu-list li:last-child {
    margin-right: 0;
  }
  .header a {
    display: block;
  }
}

/* -------------------------------------------
一覧画面
------------------------------------------- */
@media screen and (min-width: 751px) {
  .area-list {
    position: relative;
    overflow: hidden;
  }
  .area-list.is-show-cursor a {
    cursor: none;
  }
  .area-list.is-show-cursor .cursor {
    opacity: 1;
  }
  .area-list .cursor {
    position: absolute;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    background: url(../img/cursor_plus_01.svg) no-repeat center center/contain;
    width: 60px;
    height: 60px;
    opacity: 0;
    -webkit-transition: opacity .1s;
    transition: opacity .1s;
    pointer-events: none;
    z-index: 50;
  }
  .area-list .layer-title {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
    pointer-events: none;
  }
  .area-list .title-main {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -53%);
            transform: translate(-50%, -53%);
  }
  .area-list .layer-photo {
    height: 176.32vw;
  }
  .area-list .box-photo {
    position: absolute;
    z-index: 5;
    -webkit-transition: opacity .7s, -webkit-transform .5s ease;
    transition: opacity .7s, -webkit-transform .5s ease;
    transition: opacity .7s, transform .5s ease;
    transition: opacity .7s, transform .5s ease, -webkit-transform .5s ease;
    opacity: 0;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  .area-list .box-photo.is-show {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  .area-list .box-photo a {
    position: relative;
    display: block;
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1), -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
  }
  .area-list .box-photo a:hover img, .area-list .box-photo a:hover .video {
    -webkit-transform: scale(1.15);
            transform: scale(1.15);
  }
  .area-list .box-photo.pc-upper {
    z-index: 20;
  }
  .area-list .box-photo img {
    width: 100%;
    height: auto;
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1), -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
  }
  .area-list .box-photo .video {
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
    transition: transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1), -webkit-transform 0.5s cubic-bezier(0.17, 0.5, 0.35, 1);
  }
  .area-list .box-photo .video video {
    width: 100%;
    height: auto;
  }
  .area-list .box-photo-01 {
    width: 10%;
    left: 5%;
    top: 13.05vw;
  }
  .area-list .box-photo-02 {
    width: 20%;
    left: 30%;
    top: 6.6vw;
  }
  .area-list .box-photo-03 {
    width: 10%;
    right: 30%;
    top: 11.6vw;
    z-index: 6;
  }
  .area-list .box-photo-04 {
    width: 15%;
    right: 20%;
    top: 20.6vw;
  }
  .area-list .box-photo-05 {
    width: 10%;
    right: 0;
    top: 15.7vw;
  }
  .area-list .box-photo-06 {
    width: 20%;
    left: 0;
    top: 32.73vw;
  }
  .area-list .box-photo-07 {
    width: 10%;
    left: 15%;
    top: 54.29vw;
  }
  .area-list .box-photo-08 {
    width: 10%;
    left: 30%;
    top: 40.1vw;
  }
  .area-list .box-photo-09 {
    width: 15%;
    left: 45%;
    top: 46.17vw;
  }
  .area-list .box-photo-10 {
    width: 20%;
    right: 10%;
    top: 46.17vw;
  }
  .area-list .box-photo-11 {
    width: 15%;
    right: 0;
    top: 66.48vw;
  }
  .area-list .box-photo-12 {
    width: 15%;
    left: 5%;
    top: 73.05vw;
  }
  .area-list .box-photo-13 {
    width: 20%;
    left: 25%;
    top: 76.18vw;
  }
  .area-list .box-photo-14 {
    width: 10%;
    left: 20%;
    top: 98.25vw;
  }
  .area-list .box-photo-15 {
    width: 10%;
    right: 30%;
    top: 90.82vw;
    z-index: 6;
  }
  .area-list .box-photo-16 {
    width: 15%;
    right: 20%;
    top: 100.1vw;
  }
  .area-list .box-photo-17 {
    width: 10%;
    right: 5%;
    top: 95.39vw;
  }
  .area-list .box-photo-18 {
    width: 10%;
    left: 0;
    top: 103.9vw;
  }
  .area-list .box-photo-19 {
    width: 10%;
    left: 40%;
    top: 110.7vw;
  }
  .area-list .box-photo-20 {
    width: 15%;
    left: 15%;
    top: 120vw;
  }
  .area-list .box-photo-21 {
    width: 20%;
    left: 0;
    top: 132.4vw;
  }
  .area-list .box-photo-22 {
    width: 10%;
    left: 30%;
    top: 155.7vw;
  }
  .area-list .box-photo-23 {
    width: 20%;
    right: 30%;
    top: 131.1vw;
  }
  .area-list .box-photo-24 {
    width: 10%;
    right: 10%;
    top: 127.6vw;
    z-index: 6;
  }
  .area-list .box-photo-25 {
    width: 15%;
    right: 0;
    top: 139vw;
  }
  .area-list .box-photo-26 {
    width: 10%;
    right: 40%;
    top: 73.125vw;
  }
}

@media screen and (max-width: 750px) {
  .area-list {
    position: relative;
    overflow: hidden;
  }
  .area-list .cursor {
    display: none;
  }
  .area-list .layer-title {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
    pointer-events: none;
  }
  .area-list .title-main {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 62.13vw;
  }
  .area-list .title-main img {
    width: 100%;
    height: auto;
  }
  .area-list .layer-photo {
    height: 604.1vw;
  }
  .area-list .box-photo {
    position: absolute;
    z-index: 5;
    -webkit-transition: opacity .7s, -webkit-transform .5s ease;
    transition: opacity .7s, -webkit-transform .5s ease;
    transition: opacity .7s, transform .5s ease;
    transition: opacity .7s, transform .5s ease, -webkit-transform .5s ease;
    opacity: 0;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  .area-list .box-photo.is-show {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  .area-list .box-photo.is-show a {
    will-change: transform;
  }
  .area-list .box-photo a {
    position: relative;
    display: block;
  }
  .area-list .box-photo.sp-upper {
    z-index: 20;
  }
  .area-list .box-photo.btn-plus a::after {
    content: "";
    display: block;
    position: absolute;
    right: 10px;
    top: 10px;
    width: 15px;
    height: 15px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    z-index: 7;
  }
  .area-list .box-photo.btn-plus.white a::after {
    background-image: url(../img/ico_plus_white_01.svg);
  }
  .area-list .box-photo.btn-plus.black a::after {
    background-image: url(../img/ico_plus_black_01.svg);
  }
  .area-list .box-photo.btn-plus.small a::after {
    right: 5px;
    top: 5px;
  }
  .area-list .box-photo img {
    width: 100%;
    height: auto;
  }
  .area-list .box-photo .video video {
    width: 100%;
    height: auto;
  }
  .area-list .box-photo-01 {
    width: 19.73%;
    left: 0;
    top: 15.7vw;
  }
  .area-list .box-photo-02 {
    width: 39.46%;
    right: 10.53%;
    top: 16vw;
  }
  .area-list .box-photo-03 {
    width: 19.73%;
    left: 20.26%;
    top: 47.2vw;
    z-index: 6;
  }
  .area-list .box-photo-04 {
    width: 29.6%;
    left: 30.13%;
    top: 62.4vw;
  }
  .area-list .box-photo-05 {
    width: 19.73%;
    right: 0.8%;
    top: 76.8vw;
  }
  .area-list .box-photo-06 {
    width: 39.46%;
    left: 0.8%;
    top: 113.3vw;
  }
  .area-list .box-photo-07 {
    width: 19.73%;
    left: 30.13%;
    top: 150.4vw;
  }
  .area-list .box-photo-08 {
    width: 19.73%;
    right: 20.53%;
    top: 114vw;
  }
  .area-list .box-photo-09 {
    width: 29.6%;
    right: 0.8%;
    top: 145.06vw;
  }
  .area-list .box-photo-10 {
    width: 39.46%;
    left: 10.4%;
    top: 186.53vw;
  }
  .area-list .box-photo-11 {
    width: 29.6%;
    left: 40%;
    top: 218.53vw;
  }
  .area-list .box-photo-12 {
    width: 29.6%;
    left: 10.4%;
    top: 281.2vw;
  }
  .area-list .box-photo-13 {
    width: 39.46%;
    right: 0.8%;
    top: 270.4vw;
  }
  .area-list .box-photo-14 {
    width: 19.73%;
    right: 30.26%;
    top: 309.4vw;
  }
  .area-list .box-photo-15 {
    width: 19.73%;
    left: 20.26%;
    top: 338.7vw;
  }
  .area-list .box-photo-15.sp-upper {
    z-index: 21;
  }
  .area-list .box-photo-16 {
    width: 29.6%;
    left: 30.13%;
    top: 357.9vw;
  }
  .area-list .box-photo-17 {
    width: 19.73%;
    right: 0.8%;
    top: 350.46vw;
  }
  .area-list .box-photo-18 {
    width: 19.73%;
    left: 0.8%;
    top: 390.3vw;
  }
  .area-list .box-photo-19 {
    width: 19.73%;
    right: 10.53%;
    top: 404.46vw;
  }
  .area-list .box-photo-20 {
    width: 29.6%;
    left: 30.13%;
    top: 416.5vw;
  }
  .area-list .box-photo-21 {
    width: 39.46%;
    left: 0.8%;
    top: 445.33vw;
  }
  .area-list .box-photo-22 {
    width: 19.73%;
    left: 10.4%;
    top: 515vw;
  }
  .area-list .box-photo-23 {
    width: 39.46%;
    right: 20.53%;
    top: 535.6vw;
  }
  .area-list .box-photo-24 {
    width: 19.73%;
    right: 20.53%;
    top: 465.3vw;
    z-index: 6;
  }
  .area-list .box-photo-25 {
    width: 29.6%;
    right: 0.8%;
    top: 480.5vw;
  }
  .area-list .box-photo-26 {
    width: 19.73%;
    right: 0.8%;
    top: 195.5vw;
  }
}

/* -------------------------------------------
モーダル画面
------------------------------------------- */
@media screen and (min-width: 751px) {
  .area-modal {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    z-index: -100;
    overflow-y: scroll;
    opacity: 0;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
  }
  .area-modal.is-show {
    opacity: 1;
  }
  .area-modal.is-show .modal-scroll .box-item .img {
    will-change: transform;
  }
  .area-modal.is-active {
    z-index: 100;
  }
  .area-modal.no-transition .modal-scroll .box-item .img {
    -webkit-transition: none;
    transition: none;
  }
  .area-modal.no-scrollbar .modal-scroll .box-item {
    margin-bottom: 250vh;
  }
  .area-modal .modal-scroll {
    width: 100%;
  }
  .area-modal .modal-scroll .btn-scroll {
    display: none;
  }
  .area-modal .modal-scroll .box-item {
    position: relative;
    height: 100vh;
    margin-bottom: 150vh;
  }
  .area-modal .modal-scroll .box-item:nth-child(26) {
    margin-bottom: 0;
  }
  .area-modal .modal-scroll .box-item .box-img {
    position: fixed;
    left: 50.8%;
    top: 52.5%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    pointer-events: none;
  }
  .area-modal .modal-scroll .box-item .img {
    height: 86.25vh;
    max-height: 70vw;
    -webkit-transition: -webkit-transform .5s;
    transition: -webkit-transform .5s;
    transition: transform .5s;
    transition: transform .5s, -webkit-transform .5s;
  }
  .area-modal .modal-scroll .box-item .img .video {
    height: 100%;
  }
  .area-modal .modal-scroll .box-item .img .video video {
    width: auto;
    height: 100%;
  }
  .area-modal .modal-scroll .box-item .img img {
    width: auto;
    height: 100%;
  }
  .area-modal .modal-scroll .box-item .img video {
    width: auto;
    height: 100%;
  }
  .area-modal .modal-scroll .box-item .box-credit {
    position: fixed;
    left: 64px;
    bottom: 38px;
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 30px;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
    opacity: 0;
    pointer-events: none;
  }
  .area-modal .modal-scroll .box-item .box-credit::before {
    content: "CREDIT";
    display: block;
    font-size: 14px;
    letter-spacing: 0.04em;
    line-height: 30px;
    margin-bottom: 23px;
  }
  .area-modal .modal-scroll .box-item .box-credit a {
    text-decoration: underline;
  }
  .area-modal .modal-scroll .box-item .box-credit a:hover {
    text-decoration: none;
  }
  .area-modal .modal-scroll .box-item .box-credit a.is-disabled {
    pointer-events: none;
    text-decoration: none;
  }
  .area-modal .modal-scroll .box-item.is-active .box-credit {
    opacity: 1;
    pointer-events: all;
  }
  .area-modal .modal-scroll .box-item.is-active + .box-item.is-active .box-credit {
    opacity: 0;
    pointer-events: none;
  }
  .area-modal .modal-scroll .box-item:nth-child(1) {
    z-index: 25;
  }
  .area-modal .modal-scroll .box-item:nth-child(2) {
    z-index: 24;
  }
  .area-modal .modal-scroll .box-item:nth-child(3) {
    z-index: 23;
  }
  .area-modal .modal-scroll .box-item:nth-child(4) {
    z-index: 22;
  }
  .area-modal .modal-scroll .box-item:nth-child(5) {
    z-index: 21;
  }
  .area-modal .modal-scroll .box-item:nth-child(6) {
    z-index: 20;
  }
  .area-modal .modal-scroll .box-item:nth-child(7) {
    z-index: 19;
  }
  .area-modal .modal-scroll .box-item:nth-child(8) {
    z-index: 18;
  }
  .area-modal .modal-scroll .box-item:nth-child(9) {
    z-index: 17;
  }
  .area-modal .modal-scroll .box-item:nth-child(10) {
    z-index: 16;
  }
  .area-modal .modal-scroll .box-item:nth-child(11) {
    z-index: 15;
  }
  .area-modal .modal-scroll .box-item:nth-child(12) {
    z-index: 14;
  }
  .area-modal .modal-scroll .box-item:nth-child(13) {
    z-index: 13;
  }
  .area-modal .modal-scroll .box-item:nth-child(14) {
    z-index: 12;
  }
  .area-modal .modal-scroll .box-item:nth-child(15) {
    z-index: 11;
  }
  .area-modal .modal-scroll .box-item:nth-child(16) {
    z-index: 10;
  }
  .area-modal .modal-scroll .box-item:nth-child(17) {
    z-index: 9;
  }
  .area-modal .modal-scroll .box-item:nth-child(18) {
    z-index: 8;
  }
  .area-modal .modal-scroll .box-item:nth-child(19) {
    z-index: 7;
  }
  .area-modal .modal-scroll .box-item:nth-child(20) {
    z-index: 6;
  }
  .area-modal .modal-scroll .box-item:nth-child(21) {
    z-index: 5;
  }
  .area-modal .modal-scroll .box-item:nth-child(22) {
    z-index: 4;
  }
  .area-modal .modal-scroll .box-item:nth-child(23) {
    z-index: 3;
  }
  .area-modal .modal-scroll .box-item:nth-child(24) {
    z-index: 2;
  }
  .area-modal .modal-scroll .box-item:nth-child(25) {
    z-index: 1;
  }
  .area-modal .modal-scroll .box-item:nth-child(26) {
    z-index: 0;
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 1) .img img, .area-modal .modal-scroll .box-item:nth-child(3n + 1) .img video {
    -webkit-transform: translate(-10px, 10px);
            transform: translate(-10px, 10px);
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 2) .img img, .area-modal .modal-scroll .box-item:nth-child(3n + 2) .img video {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 3) .img img, .area-modal .modal-scroll .box-item:nth-child(3n + 3) .img video {
    -webkit-transform: translate(-20px, -10px);
            transform: translate(-20px, -10px);
  }
  .area-modal .modal-nav {
    position: fixed;
    right: calc(50vw - 33.7vh - 40px);
    top: 50%;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    z-index: 100;
  }
  .area-modal .modal-nav .num {
    width: 22px;
    height: 15px;
    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;
  }
  .area-modal .modal-nav .num .is-disabled {
    pointer-events: none;
  }
  .area-modal .modal-nav .border {
    height: 94px;
    width: 1px;
    background: #707070;
    margin: 15px auto;
  }
  .area-modal .modal-nav a {
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
  }
  .area-modal .modal-nav a:hover {
    opacity: 0.5;
  }
  .area-modal .modal-btn {
    text-align: right;
    position: fixed;
    right: 30px;
    top: 50%;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    z-index: 100;
  }
  .area-modal .modal-btn a {
    display: block;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
  }
  .area-modal .modal-btn a:hover {
    opacity: 0.5;
  }
  .area-modal .modal-btn .icon {
    display: inline-block;
    vertical-align: top;
    width: 14px;
    height: 14px;
  }
  .area-modal .modal-btn .text {
    display: inline-block;
    vertical-align: top;
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 13px;
    margin-left: 3px;
  }
}

@media screen and (max-width: 750px) {
  .area-modal {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    z-index: -100;
    overflow-y: scroll;
    opacity: 0;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
    pointer-events: none;
    display: none;
  }
  .area-modal.is-show {
    opacity: 1;
  }
  .area-modal.is-show .modal-scroll .box-item .img {
    will-change: transform;
  }
  .area-modal.is-active {
    z-index: 100;
    display: block;
    pointer-events: all;
  }
  .area-modal .modal-scroll {
    width: 100%;
  }
  .area-modal .modal-scroll .btn-scroll {
    display: block;
    position: fixed;
    left: 50%;
    top: 128.5vw;
    width: 50px;
    height: 86px;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
    background: url(../img/ico_line_scroll_01.svg) no-repeat center bottom/3px auto;
    color: #fff;
    text-align: center;
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 12px;
    z-index: 50;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
  }
  .area-modal .modal-scroll .btn-scroll a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .area-modal .modal-scroll .btn-scroll.is-hide {
    opacity: 0;
    pointer-events: none;
  }
  .area-modal .modal-scroll .box-item {
    position: relative;
    height: 100vh;
    margin-bottom: 100vh;
  }
  .area-modal .modal-scroll .box-item:nth-child(26) {
    margin-bottom: 0 !important;
  }
  .area-modal .modal-scroll .box-item .box-img {
    position: fixed;
    width: 100%;
    left: 0;
    top: 0;
    pointer-events: none;
  }
  .area-modal .modal-scroll .box-item .img {
    width: 98.66%;
    margin: 0 auto;
  }
  .area-modal .modal-scroll .box-item .img .video {
    width: 100%;
  }
  .area-modal .modal-scroll .box-item .img .video video {
    width: 100%;
    height: auto;
  }
  .area-modal .modal-scroll .box-item .img img {
    width: 100%;
    height: auto;
  }
  .area-modal .modal-scroll .box-item .box-credit {
    position: fixed;
    left: 0;
    bottom: 0;
    font-size: 14px;
    letter-spacing: 0.04em;
    line-height: 20px;
    -webkit-transition: opacity .3s, background .2s;
    transition: opacity .3s, background .2s;
    opacity: 0;
    pointer-events: none;
    padding: 18px 20px 22px;
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    z-index: 50;
  }
  .area-modal .modal-scroll .box-item .box-credit.is-open {
    background: #fff;
  }
  .area-modal .modal-scroll .box-item .box-credit.is-open::after {
    opacity: 1;
  }
  .area-modal .modal-scroll .box-item .box-credit::before {
    position: relative;
    content: "CREDIT";
    display: block;
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 12px;
    text-decoration: underline;
    z-index: 51;
  }
  .area-modal .modal-scroll .box-item .box-credit::after {
    content: "";
    display: block;
    position: absolute;
    right: 15px;
    top: 15px;
    width: 17px;
    height: 17px;
    background: url(../img/ico_plus_black_01.svg) no-repeat center center/contain;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transition: opacity .2s;
    transition: opacity .2s;
    opacity: 0;
    z-index: 51;
  }
  .area-modal .modal-scroll .box-item .box-credit a {
    text-decoration: underline;
  }
  .area-modal .modal-scroll .box-item .box-credit a.is-disabled {
    pointer-events: none;
    text-decoration: none;
  }
  .area-modal .modal-scroll .box-item .box-credit .credit-list {
    display: none;
    position: relative;
    z-index: 51;
  }
  .area-modal .modal-scroll .box-item .box-credit .credit-list li:first-child {
    padding-top: 50px;
  }
  .area-modal .modal-scroll .box-item .box-credit .credit-list li + li {
    margin-top: 11px;
  }
  .area-modal .modal-scroll .box-item.is-active .box-credit {
    opacity: 1;
    pointer-events: all;
  }
  .area-modal .modal-scroll .box-item:nth-child(1) .box-img {
    z-index: 25;
  }
  .area-modal .modal-scroll .box-item:nth-child(2) .box-img {
    z-index: 24;
  }
  .area-modal .modal-scroll .box-item:nth-child(3) .box-img {
    z-index: 23;
  }
  .area-modal .modal-scroll .box-item:nth-child(4) .box-img {
    z-index: 22;
  }
  .area-modal .modal-scroll .box-item:nth-child(5) .box-img {
    z-index: 21;
  }
  .area-modal .modal-scroll .box-item:nth-child(6) .box-img {
    z-index: 20;
  }
  .area-modal .modal-scroll .box-item:nth-child(7) .box-img {
    z-index: 19;
  }
  .area-modal .modal-scroll .box-item:nth-child(8) .box-img {
    z-index: 18;
  }
  .area-modal .modal-scroll .box-item:nth-child(9) .box-img {
    z-index: 17;
  }
  .area-modal .modal-scroll .box-item:nth-child(10) .box-img {
    z-index: 16;
  }
  .area-modal .modal-scroll .box-item:nth-child(11) .box-img {
    z-index: 15;
  }
  .area-modal .modal-scroll .box-item:nth-child(12) .box-img {
    z-index: 14;
  }
  .area-modal .modal-scroll .box-item:nth-child(13) .box-img {
    z-index: 13;
  }
  .area-modal .modal-scroll .box-item:nth-child(14) .box-img {
    z-index: 12;
  }
  .area-modal .modal-scroll .box-item:nth-child(15) .box-img {
    z-index: 11;
  }
  .area-modal .modal-scroll .box-item:nth-child(16) .box-img {
    z-index: 10;
  }
  .area-modal .modal-scroll .box-item:nth-child(17) .box-img {
    z-index: 9;
  }
  .area-modal .modal-scroll .box-item:nth-child(18) .box-img {
    z-index: 8;
  }
  .area-modal .modal-scroll .box-item:nth-child(19) .box-img {
    z-index: 7;
  }
  .area-modal .modal-scroll .box-item:nth-child(20) .box-img {
    z-index: 6;
  }
  .area-modal .modal-scroll .box-item:nth-child(21) .box-img {
    z-index: 5;
  }
  .area-modal .modal-scroll .box-item:nth-child(22) .box-img {
    z-index: 4;
  }
  .area-modal .modal-scroll .box-item:nth-child(23) .box-img {
    z-index: 3;
  }
  .area-modal .modal-scroll .box-item:nth-child(24) .box-img {
    z-index: 2;
  }
  .area-modal .modal-scroll .box-item:nth-child(25) .box-img {
    z-index: 1;
  }
  .area-modal .modal-scroll .box-item:nth-child(26) .box-img {
    z-index: 0;
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 1) .img img, .area-modal .modal-scroll .box-item:nth-child(3n + 1) .img video {
    -webkit-transform: translate(0, 8vw);
            transform: translate(0, 8vw);
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 2) .img img, .area-modal .modal-scroll .box-item:nth-child(3n + 2) .img video {
    -webkit-transform: translate(5.8vw, 2.6vw);
            transform: translate(5.8vw, 2.6vw);
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 3) .img img, .area-modal .modal-scroll .box-item:nth-child(3n + 3) .img video {
    -webkit-transform: translate(-2vw, 0);
            transform: translate(-2vw, 0);
  }
  .area-modal .modal-nav {
    position: fixed;
    right: 4px;
    top: 75vw;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    z-index: 49;
  }
  .area-modal .modal-nav .num {
    width: 35px;
    height: 20px;
    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;
  }
  .area-modal .modal-nav .num .is-disabled {
    pointer-events: none;
  }
  .area-modal .modal-nav .num img {
    -webkit-transform: scale(0.75);
            transform: scale(0.75);
  }
  .area-modal .modal-nav .num a {
    padding: 10px;
    text-align: center;
  }
  .area-modal .modal-nav .border {
    height: 94px;
    width: 1px;
    background: #707070;
    margin: 9px auto;
  }
  .area-modal .modal-btn {
    text-align: right;
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 49;
  }
  .area-modal .modal-btn a {
    display: block;
  }
  .area-modal .modal-btn .icon {
    display: inline-block;
    vertical-align: top;
    width: 14px;
    height: 14px;
  }
  .area-modal .modal-btn .text {
    display: inline-block;
    vertical-align: top;
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 13px;
    margin-left: 3px;
  }
  .area-modal .modal-btn-sp {
    text-align: right;
    position: fixed;
    right: 15px;
    bottom: 15px;
    height: 25px;
    width: 65px;
    z-index: 100;
  }
  .area-modal .modal-btn-sp a {
    display: block;
    width: 100%;
    height: 100%;
  }
}

@media screen and (max-width: 750px) and (min-aspect-ratio: 375 / 610) {
  .area-modal .modal-scroll .box-item .img {
    width: 90%;
  }
  .area-modal .modal-scroll .box-item:nth-child(3n + 3) .img img {
    -webkit-transform: translate(-4vw, 0);
            transform: translate(-4vw, 0);
  }
  .area-modal .modal-scroll .btn-scroll {
    top: 106vw;
  }
  .area-modal .modal-nav {
    top: 63vw;
  }
}

@media screen and (max-width: 750px) and (max-width: 330px) {
  .area-modal .modal-scroll .box-item .img {
    width: 80%;
  }
  .area-modal .modal-scroll .box-item .box-credit {
    font-size: 11px;
    letter-spacing: 0.04em;
    line-height: 23px;
    padding: 14px 15px 14px;
  }
  .area-modal .modal-scroll .box-item .box-credit::before {
    font-size: 11px;
    letter-spacing: 0.04em;
    line-height: 12px;
  }
  .area-modal .modal-scroll .box-item .box-credit::after {
    content: "";
    display: block;
    position: absolute;
    right: 15px;
    top: 15px;
    width: 15px;
    height: 15px;
    background: url(../img/ico_plus_black_01.svg) no-repeat center center/contain;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transition: opacity .2s;
    transition: opacity .2s;
    opacity: 0;
  }
  .area-modal .modal-scroll .box-item .box-credit .credit-list li:first-child {
    padding-top: 15px;
  }
  .area-modal .modal-scroll .btn-scroll {
    top: 91vw;
  }
  .area-modal .modal-nav {
    top: 57vw;
  }
  .area-modal .modal-nav .num img {
    -webkit-transform: scale(0.65);
            transform: scale(0.65);
  }
  .area-modal .modal-nav .border {
    height: 50px;
    margin: 4px auto;
  }
  .area-modal .modal-btn {
    right: 15px;
    bottom: 15px;
  }
  .area-modal .modal-btn .icon {
    width: 12px;
    height: 12px;
  }
  .area-modal .modal-btn .text {
    font-size: 11px;
    letter-spacing: 0.04em;
    line-height: 13px;
    margin-left: 3px;
  }
  .area-modal .modal-btn-sp {
    text-align: right;
    position: fixed;
    right: 5px;
    bottom: 5px;
    height: 30px;
    width: 65px;
    z-index: 100;
  }
  .area-modal .modal-btn-sp a {
    display: block;
    width: 100%;
    height: 100%;
  }
}

/* -------------------------------------------
フッター
------------------------------------------- */
@media screen and (min-width: 751px) {
  .footer {
    padding-bottom: 26px;
  }
  .footer .judge-device {
    display: none;
  }
  .footer .btn {
    width: 384px;
    height: 70px;
    margin: 0 auto;
  }
  .footer .btn span {
    position: relative;
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.09em;
    line-height: 20px;
    height: 20px;
  }
  .footer .btn span::before, .footer .btn span::after {
    content: "";
    display: inline-block;
    height: 20px;
    width: 8px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
    vertical-align: top;
    margin-left: 10px;
  }
  .footer .btn span::before {
    background-image: url(../img/ico_arrow_black_01.svg);
    position: absolute;
    right: 0;
    top: 0;
    opacity: 0;
  }
  .footer .btn span::after {
    background-image: url(../img/ico_arrow_white_01.svg);
    opacity: 1;
  }
  .footer .btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    height: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: #fff;
    background: #000;
    border: 1px solid #000;
    -webkit-transition: background .3s, color .3s;
    transition: background .3s, color .3s;
  }
  .footer .btn a:hover {
    background: #fff;
    color: #000;
  }
  .footer .btn a:hover span::before {
    opacity: 1;
  }
  .footer .btn a:hover span::after {
    opacity: 0;
  }
  .footer .credit {
    font-size: 12px;
    letter-spacing: 0.02em;
    line-height: 20px;
    text-align: center;
    color: #666;
    margin-top: 24px;
  }
  .footer .copyright {
    font-size: 12px;
    letter-spacing: 0.02em;
    line-height: 20px;
    text-align: center;
    color: #aaa;
    margin-top: 24px;
  }
}

@media screen and (max-width: 750px) {
  .footer {
    padding-bottom: 15px;
  }
  .footer .judge-device {
    display: block;
    position: absolute;
    visibility: hidden;
  }
  .footer .btn {
    width: 78.66%;
    height: 70px;
    margin: 0 auto;
  }
  .footer .btn span {
    position: relative;
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.09em;
    line-height: 20px;
    height: 20px;
  }
  .footer .btn span::before, .footer .btn span::after {
    content: "";
    display: inline-block;
    height: 20px;
    width: 8px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
    vertical-align: top;
    margin-left: 8px;
  }
  .footer .btn span::before {
    background-image: url(../img/ico_arrow_black_01.svg);
    position: absolute;
    right: 0;
    top: 0;
    opacity: 0;
  }
  .footer .btn span::after {
    background-image: url(../img/ico_arrow_white_01.svg);
    opacity: 1;
  }
  .footer .btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    height: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: #fff;
    background: #000;
    border: 1px solid #000;
  }
  .footer .credit {
    font-size: 12px;
    letter-spacing: 0.02em;
    line-height: 20px;
    text-align: center;
    color: #666;
    margin-top: 26px;
  }
  .footer .copyright {
    font-size: 12px;
    letter-spacing: 0.02em;
    line-height: 20px;
    text-align: center;
    color: #aaa;
    margin-top: 26px;
  }
}
