@charset "UTF-8";
/*--------------------
共通設定
----------------------*/
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  transition: .4s;
  color: #000000; }
  a:hover {
    text-decoration: none;
    color: #000000; }
  a.disabled {
    pointer-events: none;
    text-decoration: none; }
  a:visited {
    color: #000000; }

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; } }

.bold {
  font-family: "gotham", sans-serif;
  font-weight: 700;
  font-style: normal; }

.black {
  font-family: "gotham", sans-serif;
  font-weight: 800;
  font-style: normal; }

body {
  overflow-x: visible; }
  body.is-loading {
    overflow: hidden;
    height: 100vh; }

.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; }

.fade {
  opacity: 0;
  transition: opacity 1s, transform 1s; }
  .fade.visible {
    opacity: 1; }

/*--------------------------------------------*/
.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 10005;
  background: #000000;
  overflow: hidden; }
  .loading .anime1, .loading .anime2, .loading .anime3 {
    display: none;
    opacity: 0;
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0; }
    .loading .anime1.active, .loading .anime2.active, .loading .anime3.active {
      display: block;
      opacity: 1; }
  .loading p {
    color: #ffffff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: fit-content; }
    @media screen and (max-width: 600px) {
      .loading p {
        top: 45%; } }
  .loading .anime1 p {
    clip-path: inset(0 100% 0 0);
    transition: 0.8s cubic-bezier(0.37, 0, 0.63, 1);
    transition-property: clip-path;
    font-weight: 600;
    font-size: 30px;
    letter-spacing: 0.2em; }
    @media screen and (max-width: 600px) {
      .loading .anime1 p {
        font-size: min(6vw, 25px);
        white-space: nowrap; } }
    .loading .anime1 p::before {
      content: "";
      width: 100%;
      height: 100%;
      background: #000000;
      position: absolute;
      top: 0;
      left: 0;
      clip-path: inset(0 100% 0 0);
      transition: 0.2s cubic-bezier(0.53, 0.14, 0.36, 0.88);
      transition-property: clip-path; }
    .loading .anime1 p.visible {
      clip-path: inset(0); }
      .loading .anime1 p.visible::before {
        transition-delay: 1s;
        clip-path: inset(0); }
  .loading .anime2 p {
    font-size: 45px;
    letter-spacing: 0.1em;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 200px; }
    @media screen and (max-width: 600px) {
      .loading .anime2 p {
        font-size: min(6vw, 30px); } }
    .loading .anime2 p span {
      display: inline-block;
      opacity: 0;
      transition: opacity 0.1s ease-out; }
      .loading .anime2 p span.is-visible {
        opacity: 1; }
  .loading .anime3 {
    transition: opacity 0.4s ease; }
    .loading .anime3 img {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      transition: opacity .5s ease-in; }
      @media screen and (max-width: 600px) {
        .loading .anime3 img {
          max-width: 150px;
          top: 45%; } }
    .loading .anime3.active {
      display: block;
      animation: fadeIn 0.4s forwards;
      opacity: 1; }
    .loading .anime3.zoom-out img {
      opacity: 0; }

@keyframes fadeIn {
  to {
    opacity: 1; } }
/*--------------------------------------------*/
.header_loop {
  width: 100%;
  background: #ffffff;
  padding: 15px 0 15px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  height: 54px; }
  @media screen and (max-width: 1080px) {
    .header_loop {
      position: static; } }
  .header_loop .swiper2 .swiper-wrapper {
    transition-timing-function: linear; }
  @media screen and (max-width: 1080px) {
    .header_loop.is-fixed {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      z-index: 9999;
      height: 54px; } }
  .header_loop .header_loop.is-fixed + * {
    margin-top: 24px; }

/*--------------------------------------------*/
#future.lp_wrapper {
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0;
  letter-spacing: 0;
  color: #000000;
  font-size: 14px;
  text-align: left;
  font-family: hiragino-kaku-gothic-pron, sans-serif;
  font-weight: 300;
  font-style: normal;
  line-height: 1.5;
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  top: 54px; }
  @media screen and (max-width: 1080px) {
    #future.lp_wrapper {
      flex-direction: column;
      top: 0; } }
#future .sidearea {
  position: fixed;
  top: 54px;
  height: calc(100vh - 54px);
  transition: .8s;
  width: calc((100% - 500px) * 0.5); }
  @media screen and (max-width: 1080px) {
    #future .sidearea {
      width: 100%;
      position: relative;
      height: 100vh;
      top: 0; } }
  #future .sidearea.boxleft {
    left: 0; }
    #future .sidearea.boxleft video {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    #future .sidearea.boxleft .video-Box {
      position: absolute;
      width: 100%;
      height: 100%;
      z-index: 9998;
      top: 0;
      left: 0; }
      #future .sidearea.boxleft .video-Box .ttl {
        position: absolute;
        width: 70%;
        top: 5%;
        left: 50%;
        transform: translateX(-50%);
        clip-path: inset(0 100% 0 0);
        transition: 0.8s cubic-bezier(0.37, 0, 0.63, 1);
        transition-property: clip-path; }
        @media screen and (max-width: 600px) {
          #future .sidearea.boxleft .video-Box .ttl {
            width: 80%;
            top: 7%; } }
        #future .sidearea.boxleft .video-Box .ttl.visible {
          clip-path: inset(0); }
      #future .sidearea.boxleft .video-Box .list {
        position: absolute;
        bottom: 0;
        right: 5%;
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 25%;
        max-width: 100px; }
        @media screen and (max-width: 600px) {
          #future .sidearea.boxleft .video-Box .list {
            max-width: 80px; } }
        #future .sidearea.boxleft .video-Box .list img {
          display: block;
          margin-bottom: 30px;
          text-align: center; }
          #future .sidearea.boxleft .video-Box .list img.size {
            width: 70%; }
  #future .sidearea.boxright {
    right: 0; }
    @media screen and (max-width: 1080px) {
      #future .sidearea.boxright {
        display: none; } }
    #future .sidearea.boxright .pc_menu {
      max-width: 380px;
      max-height: 85%;
      width: 80%;
      margin: 0 auto;
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      flex-wrap: wrap;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
      @media screen and (max-width: 1850px) {
        #future .sidearea.boxright .pc_menu {
          width: 70%; } }
      #future .sidearea.boxright .pc_menu div {
        width: 47%;
        margin-bottom: 8%;
        display: flex;
        align-items: flex-start; }
        #future .sidearea.boxright .pc_menu div p {
          font-size: 10px;
          display: flex;
          transform: rotate(90deg);
          white-space: nowrap;
          width: 18px;
          margin-left: 3px; }
        #future .sidearea.boxright .pc_menu div:last-child {
          margin-bottom: 0; }
        #future .sidearea.boxright .pc_menu div a {
          display: block;
          overflow: hidden; }
          #future .sidearea.boxright .pc_menu div a img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transform: scale(1);
            transition: .8s; }
            #future .sidearea.boxright .pc_menu div a img:hover {
              transform: scale(1.1); }
          #future .sidearea.boxright .pc_menu div a.line {
            position: relative; }
            #future .sidearea.boxright .pc_menu div a.line::after {
              position: absolute;
              content: "";
              top: 50%;
              left: 50%;
              transform: translate(-50%, -50%);
              width: 80%;
              z-index: 99; }
            #future .sidearea.boxright .pc_menu div a.line.expand::after {
              background: url("../images/SVG/pc_menu_5.svg") no-repeat;
              background-size: contain;
              height: 15%; }
            #future .sidearea.boxright .pc_menu div a.line.mate::after {
              background: url("../images/SVG/pc_menu_6.svg") no-repeat;
              background-size: contain;
              height: 15%;
              top: 15%; }
            #future .sidearea.boxright .pc_menu div a.line.convert::after {
              background: url("../images/SVG/pc_menu_7.svg") no-repeat;
              background-size: contain;
              height: 20%;
              top: 5%;
              left: 5%;
              transform: translate(0); }
            #future .sidearea.boxright .pc_menu div a.line.native::after {
              background: url("../images/SVG/pc_menu_8.svg") no-repeat;
              background-size: contain;
              height: 10%;
              top: auto;
              bottom: 5%;
              transform: translate(-50%, 0); }
#future #box-content {
  position: relative;
  z-index: 1000;
  width: 500px;
  /* drawer */ }
  @media screen and (max-width: 1080px) {
    #future #box-content {
      width: 100%; } }
  @media screen and (max-width: 600px) {
    #future #box-content {
      width: 100%; } }
  #future #box-content #drawer {
    position: relative;
    margin: 0 auto;
    background: #ffffff; }
    #future #box-content #drawer .innerBox {
      /* ttlBox */
      /* block */
      /* section */ }
      #future #box-content #drawer .innerBox .mv {
        position: relative;
        width: 100%;
        height: 100vh; }
        @media screen and (max-width: 1080px) {
          #future #box-content #drawer .innerBox .mv {
            min-height: 100vh;
            height: fit-content; } }
        #future #box-content #drawer .innerBox .mv .swiper_back .swiper-slide {
          position: relative;
          height: calc(100vh - 54px); }
          @media screen and (max-width: 1080px) {
            #future #box-content #drawer .innerBox .mv .swiper_back .swiper-slide {
              height: 100%; } }
          #future #box-content #drawer .innerBox .mv .swiper_back .swiper-slide::after {
            content: "";
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.8);
            position: absolute;
            top: 0;
            left: 0; }
          #future #box-content #drawer .innerBox .mv .swiper_back .swiper-slide img {
            width: 100%;
            height: 100%;
            object-fit: cover; }
        #future #box-content #drawer .innerBox .mv .msg {
          position: absolute;
          top: calc(50% - 54px);
          left: 50%;
          width: 80%;
          transform: translate(-50%, -50%);
          z-index: 100;
          clip-path: inset(0 0 100% 0);
          transition: 1s cubic-bezier(0.37, 0, 0.63, 1);
          transition-property: clip-path; }
          @media screen and (max-width: 600px) {
            #future #box-content #drawer .innerBox .mv .msg {
              top: 50%; } }
          #future #box-content #drawer .innerBox .mv .msg p {
            color: #ffffff;
            font-size: 1.0em;
            line-height: 2.0;
            margin-bottom: 2.0em; }
            @media screen and (max-width: 600px) {
              #future #box-content #drawer .innerBox .mv .msg p {
                font-size: min(3.2vw, 1em);
                margin: 10% auto; } }
            #future #box-content #drawer .innerBox .mv .msg p:last-child {
              margin-bottom: 0; }
          #future #box-content #drawer .innerBox .mv .msg.visible {
            clip-path: inset(0); }
      #future #box-content #drawer .innerBox .ttlBox {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        width: 80%;
        margin: 10vh auto; }
        @media screen and (max-width: 600px) {
          #future #box-content #drawer .innerBox .ttlBox {
            padding-top: 100px;
            margin-top: calc(10vh - 100px); } }
        #future #box-content #drawer .innerBox .ttlBox ul li {
          padding-left: 1.0em;
          position: relative;
          margin-bottom: 0.5em; }
          #future #box-content #drawer .innerBox .ttlBox ul li::before {
            content: "-";
            position: absolute;
            left: 0;
            top: 50%;
            transform: translateY(-50%); }
          #future #box-content #drawer .innerBox .ttlBox ul li a {
            font-size: 1.0em;
            letter-spacing: .05em; }
            @media screen and (max-width: 600px) {
              #future #box-content #drawer .innerBox .ttlBox ul li a {
                font-size: 3.5vw; } }
        #future #box-content #drawer .innerBox .ttlBox h3 {
          display: flex;
          font-size: 1.5em !important;
          color: #ffffff; }
          #future #box-content #drawer .innerBox .ttlBox h3 span {
            overflow: hidden;
            white-space: pre;
            writing-mode: vertical-rl;
            display: inline-block;
            font-size: 100%;
            background: #000000;
            padding: 0.5em 0.2em;
            height: fit-content;
            position: relative;
            clip-path: inset(0 0 100% 0);
            transition: 0.4s cubic-bezier(0.37, 0, 0.63, 1);
            transition-property: clip-path; }
            #future #box-content #drawer .innerBox .ttlBox h3 span:nth-child(1) {
              order: 2;
              padding-bottom: 0; }
            #future #box-content #drawer .innerBox .ttlBox h3 span:nth-child(2) {
              order: 1;
              margin-right: 0.5em; }
            #future #box-content #drawer .innerBox .ttlBox h3 span::before {
              content: "";
              width: 100%;
              height: 100%;
              background: #000000;
              position: absolute;
              top: 0;
              left: 0;
              clip-path: inset(0);
              transition: 0.6s cubic-bezier(0.37, 0, 0.63, 1);
              transition-property: clip-path; }
            #future #box-content #drawer .innerBox .ttlBox h3 span.visible {
              clip-path: inset(0); }
              #future #box-content #drawer .innerBox .ttlBox h3 span.visible::before {
                transition-delay: .8s;
                clip-path: inset(100% 0 0 0); }
      #future #box-content #drawer .innerBox .block {
        margin-bottom: 10vh; }
        #future #box-content #drawer .innerBox .block p {
          font-size: 1.0em;
          line-height: 1.8;
          margin: 1.0em 0 1.0em 1.0em;
          width: 85%; }
          @media screen and (max-width: 600px) {
            #future #box-content #drawer .innerBox .block p {
              font-size: 3.2vw; } }
        #future #box-content #drawer .innerBox .block .flexBox {
          display: flex;
          align-items: stretch;
          justify-content: space-between; }
          @media screen and (max-width: 1080px) {
            #future #box-content #drawer .innerBox .block .flexBox {
              justify-content: flex-start; } }
          @media screen and (max-width: 600px) {
            #future #box-content #drawer .innerBox .block .flexBox {
              justify-content: space-between; } }
          #future #box-content #drawer .innerBox .block .flexBox .vertical {
            width: 15%;
            display: flex;
            align-items: flex-start;
            justify-content: center;
            padding-top: 0.5em; }
            @media screen and (max-width: 600px) {
              #future #box-content #drawer .innerBox .block .flexBox .vertical {
                width: 25%;
                padding: 0; } }
            #future #box-content #drawer .innerBox .block .flexBox .vertical p {
              font-size: 12px;
              transform: rotate(90deg);
              white-space: nowrap;
              width: 18px;
              margin: 0; }
              @media screen and (max-width: 600px) {
                #future #box-content #drawer .innerBox .block .flexBox .vertical p {
                  font-size: 2.8vw; } }
        #future #box-content #drawer .innerBox .block .img-animation {
          overflow: hidden;
          position: relative; }
          #future #box-content #drawer .innerBox .block .img-animation::before {
            animation: animation 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.5s forwards;
            content: '';
            inset: 0;
            pointer-events: none;
            position: absolute;
            height: 100%;
            z-index: 4000; }
          #future #box-content #drawer .innerBox .block .img-animation.line1::before {
            background: #333333;
            height: 100%; }
          #future #box-content #drawer .innerBox .block .img-animation.line2::before {
            background: #ebebb4;
            height: 100%; }
          #future #box-content #drawer .innerBox .block .img-animation.line3::before {
            background: #052878;
            height: 100%; }
          #future #box-content #drawer .innerBox .block .img-animation.line4::before {
            background: #f2f2f2;
            height: 100%; }
          #future #box-content #drawer .innerBox .block .img-animation.line5::before {
            background: #c9171e;
            height: 100%; }
      #future #box-content #drawer .innerBox section {
        margin: 20vh auto;
        background: #ffffff; }
        #future #box-content #drawer .innerBox section.series {
          padding: 20vh 0 10vh;
          margin: 0 auto; }
        #future #box-content #drawer .innerBox section .vertical-anime {
          clip-path: inset(0 100% 0 0);
          transition: 0.8s cubic-bezier(0.37, 0, 0.63, 1);
          transition-property: clip-path; }
          #future #box-content #drawer .innerBox section .vertical-anime.visible {
            clip-path: inset(0); }
        #future #box-content #drawer .innerBox section .seriesBox {
          margin-bottom: 20vh; }
          #future #box-content #drawer .innerBox section .seriesBox .block_1 {
            text-align: center;
            margin-bottom: 15vh; }
            #future #box-content #drawer .innerBox section .seriesBox .block_1 img {
              margin: 0 auto;
              max-width: 200px; }
              @media screen and (max-width: 600px) {
                #future #box-content #drawer .innerBox section .seriesBox .block_1 img {
                  width: 40%; } }
          #future #box-content #drawer .innerBox section .seriesBox .itemBox {
            width: 90%;
            margin: 0 auto; }
            @media screen and (max-width: 1080px) {
              #future #box-content #drawer .innerBox section .seriesBox .itemBox {
                max-width: 600px; } }
            #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design {
              border-bottom: 1px solid #ffffff;
              display: flex;
              align-items: flex-end;
              justify-content: space-between; }
              #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design p {
                font-size: 0.7em;
                color: #ffffff;
                margin-bottom: 0.5em;
                letter-spacing: 1px; }
                @media screen and (max-width: 600px) {
                  #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design p {
                    font-size: 2.5vw; } }
              #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design.brown {
                border-color: #554641; }
                #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design.brown p {
                  color: #554641; }
              #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design.gray {
                border-color: #333333; }
                #future #box-content #drawer .innerBox section .seriesBox .itemBox .ttl-design.gray p {
                  color: #333333; }
            #future #box-content #drawer .innerBox section .seriesBox .itemBox h2 {
              display: flex;
              align-items: flex-end;
              justify-content: flex-start;
              color: #ffffff;
              font-size: 2.2em;
              letter-spacing: 1px;
              font-weight: 400;
              line-height: 1.2;
              margin: 0.5em 0; }
              @media screen and (max-width: 600px) {
                #future #box-content #drawer .innerBox section .seriesBox .itemBox h2 {
                  font-size: 6.8vw; } }
              #future #box-content #drawer .innerBox section .seriesBox .itemBox h2 span {
                font-size: 40%;
                margin-left: 2em; }
              #future #box-content #drawer .innerBox section .seriesBox .itemBox h2.brown {
                color: #554641; }
                #future #box-content #drawer .innerBox section .seriesBox .itemBox h2.brown span {
                  color: #554641; }
              #future #box-content #drawer .innerBox section .seriesBox .itemBox h2.gray {
                color: #333333; }
                #future #box-content #drawer .innerBox section .seriesBox .itemBox h2.gray span {
                  color: #333333; }
          #future #box-content #drawer .innerBox section .seriesBox .itemDetail {
            width: 90%;
            margin: 5% auto;
            display: flex;
            justify-content: center;
            align-items: flex-start; }
            @media screen and (max-width: 1080px) {
              #future #box-content #drawer .innerBox section .seriesBox .itemDetail {
                max-width: 600px; } }
            #future #box-content #drawer .innerBox section .seriesBox .itemDetail div {
              width: 50%; }
              #future #box-content #drawer .innerBox section .seriesBox .itemDetail div:nth-child(2) {
                width: 45%;
                margin-left: 5%; }
              #future #box-content #drawer .innerBox section .seriesBox .itemDetail div p {
                color: #ffffff;
                font-size: 0.9em;
                margin-bottom: 1.0em; }
                @media screen and (max-width: 600px) {
                  #future #box-content #drawer .innerBox section .seriesBox .itemDetail div p {
                    font-size: 2.8vw; } }
            #future #box-content #drawer .innerBox section .seriesBox .itemDetail.single div {
              width: 100%; }
            #future #box-content #drawer .innerBox section .seriesBox .itemDetail.brown p {
              color: #554641; }
            #future #box-content #drawer .innerBox section .seriesBox .itemDetail.gray p {
              color: #333333; }
          #future #box-content #drawer .innerBox section .seriesBox .btnBox {
            width: 90%;
            margin: 5% auto 0;
            display: flex;
            align-items: stretch;
            justify-content: flex-start; }
            @media screen and (max-width: 1080px) {
              #future #box-content #drawer .innerBox section .seriesBox .btnBox {
                max-width: 600px; } }
            #future #box-content #drawer .innerBox section .seriesBox .btnBox div {
              width: 50%;
              border: 1px solid #ffffff; }
              #future #box-content #drawer .innerBox section .seriesBox .btnBox div:nth-child(2) {
                border-left: none; }
              #future #box-content #drawer .innerBox section .seriesBox .btnBox div a {
                display: flex;
                justify-content: space-between;
                align-items: center;
                padding: 1.0em;
                position: relative;
                font-size: 0.8em;
                color: #ffffff; }
                @media screen and (max-width: 600px) {
                  #future #box-content #drawer .innerBox section .seriesBox .btnBox div a {
                    font-size: 2.8vw; } }
                #future #box-content #drawer .innerBox section .seriesBox .btnBox div a span {
                  display: inline-block;
                  width: 14px;
                  height: 14px;
                  mask-image: url("../images/SVG/arrow.svg");
                  mask-repeat: no-repeat;
                  mask-position: center;
                  background-color: #ffffff; }
                #future #box-content #drawer .innerBox section .seriesBox .btnBox div a:hover {
                  background: #ffffff;
                  color: #000000; }
                  #future #box-content #drawer .innerBox section .seriesBox .btnBox div a:hover span {
                    background-color: #000000; }
            #future #box-content #drawer .innerBox section .seriesBox .btnBox .schedule {
              width: 100%;
              padding: .5em;
              text-align: center;
              margin: 0 auto; }
              #future #box-content #drawer .innerBox section .seriesBox .btnBox .schedule p {
                color: #ffffff;
                font-size: .8em; }
                @media screen and (max-width: 600px) {
                  #future #box-content #drawer .innerBox section .seriesBox .btnBox .schedule p {
                    font-size: 2.8vw; } }
            #future #box-content #drawer .innerBox section .seriesBox .btnBox.brown div {
              border-color: #554641; }
              #future #box-content #drawer .innerBox section .seriesBox .btnBox.brown div a {
                color: #554641; }
                #future #box-content #drawer .innerBox section .seriesBox .btnBox.brown div a span {
                  background: #554641; }
            #future #box-content #drawer .innerBox section .seriesBox .btnBox.gray div {
              border-color: #333333; }
              #future #box-content #drawer .innerBox section .seriesBox .btnBox.gray div a {
                color: #333333; }
                #future #box-content #drawer .innerBox section .seriesBox .btnBox.gray div a span {
                  background: #333333; }
        #future #box-content #drawer .innerBox section#expand {
          background: #333333; }
        #future #box-content #drawer .innerBox section#mate {
          background: #ebebb4; }
        #future #box-content #drawer .innerBox section#convert {
          background: #052878; }
        #future #box-content #drawer .innerBox section#fit {
          background: #f2f2f2; }
          #future #box-content #drawer .innerBox section#fit .block_1 img {
            max-width: 150px; }
        #future #box-content #drawer .innerBox section#native {
          background: #c9171e; }
          #future #box-content #drawer .innerBox section#native .block_1 img {
            max-width: 300px; }
        #future #box-content #drawer .innerBox section.itemList-box {
          background: #f2f2f2;
          padding: 20vh 0;
          margin: 0 auto; }
          #future #box-content #drawer .innerBox section.itemList-box .block {
            width: 90%;
            margin: 0 auto; }
            @media screen and (max-width: 1080px) {
              #future #box-content #drawer .innerBox section.itemList-box .block {
                max-width: 600px; } }
          #future #box-content #drawer .innerBox section.itemList-box .ttl {
            display: flex;
            align-items: flex-end;
            justify-content: space-between;
            border-bottom: 1px solid #000000;
            padding-bottom: 0.5em;
            text-align: center; }
            #future #box-content #drawer .innerBox section.itemList-box .ttl p {
              font-size: 0.8em;
              line-height: 1.0;
              margin: 0;
              width: calc(100%/3); }
              @media screen and (max-width: 600px) {
                #future #box-content #drawer .innerBox section.itemList-box .ttl p {
                  font-size: 2.8vw; } }
              #future #box-content #drawer .innerBox section.itemList-box .ttl p:nth-child(1) {
                text-align: left; }
              #future #box-content #drawer .innerBox section.itemList-box .ttl p:nth-child(3) {
                text-align: right; }
          #future #box-content #drawer .innerBox section.itemList-box ul {
            display: flex;
            align-items: flex-end;
            justify-content: flex-start;
            flex-wrap: wrap;
            margin: 5% auto; }
            #future #box-content #drawer .innerBox section.itemList-box ul li {
              width: calc(100%/3 - 2%);
              margin: 0 1% 5%;
              text-align: center; }
              #future #box-content #drawer .innerBox section.itemList-box ul li p {
                font-size: 0.9em;
                margin: 0 auto; }
                @media screen and (max-width: 600px) {
                  #future #box-content #drawer .innerBox section.itemList-box ul li p {
                    font-size: 2.8vw; } }
              #future #box-content #drawer .innerBox section.itemList-box ul li .buy {
                display: block;
                margin: .5em auto 0;
                width: fit-content;
                color: #ffffff;
                background: #000000;
                font-size: 0.7em;
                padding: 0.2em 0.5em 0.1em;
                border: 1px solid #000000; }
                @media screen and (max-width: 600px) {
                  #future #box-content #drawer .innerBox section.itemList-box ul li .buy {
                    font-size: 2.5vw; } }
                #future #box-content #drawer .innerBox section.itemList-box ul li .buy:hover {
                  background: #ffffff;
                  color: #000000; }
      #future #box-content #drawer .innerBox .footerBox {
        background: #000000;
        padding: 10vh 0; }
        #future #box-content #drawer .innerBox .footerBox .credit {
          max-width: 90%;
          width: fit-content;
          margin: 0 auto; }
          #future #box-content #drawer .innerBox .footerBox .credit p {
            color: #ffffff;
            font-size: 0.8em;
            line-height: 2.0; }
            @media screen and (max-width: 600px) {
              #future #box-content #drawer .innerBox .footerBox .credit p {
                font-size: 2.8vw; } }
          #future #box-content #drawer .innerBox .footerBox .credit .sns {
            display: flex;
            justify-content: space-between;
            align-items: flex-end;
            margin-top: 10vh; }
            #future #box-content #drawer .innerBox .footerBox .credit .sns .icon {
              display: flex;
              flex-direction: column; }
              #future #box-content #drawer .innerBox .footerBox .credit .sns .icon a {
                display: block;
                margin-bottom: 15px; }
            #future #box-content #drawer .innerBox .footerBox .credit .sns .logo {
              max-width: 100px; }

.fixedBtn {
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 9999;
  max-width: 150px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: opacity 0.3s, transform 0.3s;
  display: flex;
  align-items: center;
  justify-content: center; }
  .fixedBtn a {
    display: block; }
    .fixedBtn a:nth-child(1) {
      margin-right: 10px; }
  .fixedBtn.is-show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0); }

@keyframes animation {
  100% {
    transform: translateX(105%); } }
