@charset "UTF-8";
/*--------------------
共通設定
----------------------*/
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  color: #000000;
  transition: .4s; }
  a:hover {
    text-decoration: none !important; }
  a:visited {
    color: #000000; }
  a.disabled {
    pointer-events: none;
    text-decoration: none; }

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, body {
  overflow-x: visible;
  min-height: 100vh;
  min-height: calc(var(--vh, 1vh) * 100);
  height: -webkit-fill-available;
  min-height: -webkit-fill-available; }

.fs-l-page {
  overflow: visible; }

p {
  margin: 0;
  padding: 0; }

.wrapper {
  margin: 0 auto !important; }

main {
  max-width: 100%; }

.mainBox {
  margin: 0 auto !important;
  padding-top: 0 !important; }

footer {
  position: relative;
  z-index: 9999; }

.fadeIn {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s, transform 1s; }
  .fadeIn.visible {
    opacity: 1;
    transform: translateY(0); }

/*--------------------------------------------*/
#future.lp_wrapper {
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0;
  letter-spacing: 0;
  color: #000000;
  font-size: 16px;
  text-align: center;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 300;
  font-style: normal;
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: #f5f5f5;
  width: 100%;
  min-height: 100vh; }
#future .sidearea {
  position: fixed;
  top: 0;
  left: 0;
  width: calc(100% - 800px);
  height: 100%; }
  @media screen and (max-width: 1600px) {
    #future .sidearea {
      width: calc(100% - 550px); } }
  @media screen and (max-width: 1080px) {
    #future .sidearea {
      display: none; } }
  #future .sidearea.boxleft .pc_nav {
    max-width: 1000px;
    width: 70%;
    margin: 0 auto;
    text-align: left;
    position: absolute;
    top: 5%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 999;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: column;
    height: 90%; }
    @media screen and (max-width: 1920px) {
      #future .sidearea.boxleft .pc_nav {
        width: 50%; } }
    @media screen and (max-width: 1600px) {
      #future .sidearea.boxleft .pc_nav {
        width: 83%; } }
    #future .sidearea.boxleft .pc_nav .ttl {
      max-height: 500px;
      height: 27%;
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      flex-direction: column; }
      @media screen and (max-width: 1600px) {
        #future .sidearea.boxleft .pc_nav .ttl {
          height: 23%; } }
      #future .sidearea.boxleft .pc_nav .ttl h3 {
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        font-size: 2.0em; }
        @media screen and (max-width: 1920px) {
          #future .sidearea.boxleft .pc_nav .ttl h3 {
            font-size: 1.2em; } }
      #future .sidearea.boxleft .pc_nav .ttl h2 {
        font-size: 3.5em;
        letter-spacing: 0.1em; }
        @media screen and (max-width: 1920px) {
          #future .sidearea.boxleft .pc_nav .ttl h2 {
            font-size: 2.5em; } }
    #future .sidearea.boxleft .pc_nav ul {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      flex-wrap: wrap; }
      #future .sidearea.boxleft .pc_nav ul li {
        width: calc(100%/4 - 1%);
        position: relative;
        padding-top: 1.2em;
        margin-bottom: 2.0em;
        text-align: center; }
        #future .sidearea.boxleft .pc_nav ul li span {
          position: absolute;
          font-size: .7em;
          font-weight: 600;
          color: #d2463c;
          top: 0;
          left: 0; }
        #future .sidearea.boxleft .pc_nav ul li p {
          font-size: 0.8em;
          line-height: 3.0; }
        #future .sidearea.boxleft .pc_nav ul li .btn {
          font-size: 0.7em;
          line-height: 1.0;
          border: 1px solid #000000;
          border-radius: 50vh;
          padding: 0.2em 0.8em; }
          #future .sidearea.boxleft .pc_nav ul li .btn:hover {
            color: #ffffff;
            background: #d2463c;
            border-color: #d2463c; }
#future #box-content {
  position: relative;
  z-index: 1000;
  flex: 1;
  max-width: 800px;
  background: #d2463c;
  margin: 0 0 0 auto;
  /* drawer */ }
  @media screen and (max-width: 1600px) {
    #future #box-content {
      max-width: 550px; } }
  @media screen and (max-width: 1080px) {
    #future #box-content {
      width: 100%;
      max-width: 100%;
      margin: 0 auto;
      overflow-x: hidden; } }
  #future #box-content #drawer {
    /* innerBox */ }
    @media screen and (max-width: 1080px) {
      #future #box-content #drawer {
        max-width: none; } }
    @media screen and (max-width: 550px) {
      #future #box-content #drawer {
        max-width: none; } }
    #future #box-content #drawer .innerBox {
      width: 70%;
      margin: 0 auto;
      background: #f5f5f5;
      /* section */
      /* item__Box */ }
      @media screen and (max-width: 1600px) {
        #future #box-content #drawer .innerBox {
          width: 80%; } }
      @media screen and (max-width: 1080px) {
        #future #box-content #drawer .innerBox {
          max-width: 560px; } }
      @media screen and (max-width: 550px) {
        #future #box-content #drawer .innerBox {
          width: 100%; } }
      #future #box-content #drawer .innerBox .main_txt {
        margin: 20% auto;
        width: 80%; }
        @media screen and (max-width: 550px) {
          #future #box-content #drawer .innerBox .main_txt {
            margin: 27% auto; } }
        #future #box-content #drawer .innerBox .main_txt .ttl {
          display: flex;
          align-items: flex-start;
          justify-content: space-between;
          margin-bottom: 5%; }
          @media screen and (max-width: 550px) {
            #future #box-content #drawer .innerBox .main_txt .ttl {
              margin-bottom: 15%; } }
          #future #box-content #drawer .innerBox .main_txt .ttl h3 {
            -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
            font-size: 1.2em; }
            @media screen and (max-width: 550px) {
              #future #box-content #drawer .innerBox .main_txt .ttl h3 {
                font-size: 4.0vw; } }
          #future #box-content #drawer .innerBox .main_txt .ttl h2 {
            font-size: 2.0em;
            letter-spacing: 0.1em; }
            @media screen and (max-width: 550px) {
              #future #box-content #drawer .innerBox .main_txt .ttl h2 {
                font-size: 8.2vw; } }
        #future #box-content #drawer .innerBox .main_txt p {
          text-align: left;
          line-height: 2.0;
          font-size: 1.0em; }
          @media screen and (max-width: 550px) {
            #future #box-content #drawer .innerBox .main_txt p {
              font-size: 3.2vw; } }
      #future #box-content #drawer .innerBox section#lineup {
        width: 96%;
        margin: 20% auto; }
        #future #box-content #drawer .innerBox section#lineup ul {
          display: flex;
          align-items: flex-start;
          justify-content: center;
          flex-wrap: wrap;
          width: 100%; }
          #future #box-content #drawer .innerBox section#lineup ul li {
            width: calc(100%/3 - 3.5%);
            position: relative;
            padding-top: 1.4em;
            margin: 0 1% 10%;
            text-align: center; }
            #future #box-content #drawer .innerBox section#lineup ul li span {
              position: absolute;
              font-size: .8em;
              font-weight: 600;
              color: #d2463c;
              top: 0;
              left: 0; }
              @media screen and (max-width: 550px) {
                #future #box-content #drawer .innerBox section#lineup ul li span {
                  font-size: 2.9vw; } }
            #future #box-content #drawer .innerBox section#lineup ul li p {
              font-size: 0.8em;
              line-height: 3.0; }
              @media screen and (max-width: 550px) {
                #future #box-content #drawer .innerBox section#lineup ul li p {
                  font-size: 2.9vw; } }
            #future #box-content #drawer .innerBox section#lineup ul li .btn {
              font-size: 0.7em;
              line-height: 1.0;
              border: 1px solid #000000;
              border-radius: 50vh;
              padding: 0.2em 0.8em; }
              @media screen and (max-width: 550px) {
                #future #box-content #drawer .innerBox section#lineup ul li .btn {
                  font-size: 2.6vw; } }
              #future #box-content #drawer .innerBox section#lineup ul li .btn:hover {
                color: #ffffff;
                background: #d2463c;
                border-color: #d2463c; }
      #future #box-content #drawer .innerBox section h4 {
        width: calc(100% - 6%);
        font-size: 1.7em;
        text-align: left;
        padding: 1% 5%;
        line-height: 1.0;
        border-top: 1px solid #000000;
        border-bottom: 1px solid #000000;
        font-weight: 400;
        margin: 0 auto 10%;
        letter-spacing: .1em; }
        @media screen and (max-width: 550px) {
          #future #box-content #drawer .innerBox section h4 {
            font-size: 6.0vw; } }
      #future #box-content #drawer .innerBox section#point {
        margin-bottom: 20%; }
        #future #box-content #drawer .innerBox section#point h4 {
          width: 90%; }
        #future #box-content #drawer .innerBox section#point ul {
          display: flex;
          align-items: flex-start;
          justify-content: space-between;
          flex-wrap: wrap;
          width: 80%;
          margin: 0 auto; }
          #future #box-content #drawer .innerBox section#point ul li {
            width: calc(100%/2 - 3%);
            margin-bottom: 10%; }
            #future #box-content #drawer .innerBox section#point ul li img {
              border: 1px solid #000;
              box-sizing: border-box; }
            #future #box-content #drawer .innerBox section#point ul li p {
              font-size: 0.8em;
              margin-top: 1.0em; }
              @media screen and (max-width: 550px) {
                #future #box-content #drawer .innerBox section#point ul li p {
                  font-size: 3.0vw; } }
      #future #box-content #drawer .innerBox .item__Box .swiper_item {
        overflow: hidden;
        position: relative; }
        #future #box-content #drawer .innerBox .item__Box .swiper_item .swiper-pagination {
          width: fit-content;
          left: 20px;
          height: 20px; }
        #future #box-content #drawer .innerBox .item__Box .swiper_item .swiper-pagination-bullet {
          background: #ffffff;
          opacity: 1;
          width: 6px;
          height: 6px;
          margin: 0 3px; }
          @media screen and (max-width: 550px) {
            #future #box-content #drawer .innerBox .item__Box .swiper_item .swiper-pagination-bullet {
              width: 4px;
              height: 4px;
              margin: 0 3px; } }
        #future #box-content #drawer .innerBox .item__Box .swiper_item .swiper-pagination-bullet-active {
          background: #d2463c; }
        #future #box-content #drawer .innerBox .item__Box .swiper_item .ttl {
          position: absolute;
          top: 20px;
          right: 20px;
          z-index: 10; }
          #future #box-content #drawer .innerBox .item__Box .swiper_item .ttl img {
            max-width: 11px; }
            @media screen and (max-width: 550px) {
              #future #box-content #drawer .innerBox .item__Box .swiper_item .ttl img {
                max-width: 9px; } }
      #future #box-content #drawer .innerBox .item__Box .item_flex {
        margin-top: -1px;
        display: flex;
        align-items: stretch;
        justify-content: center;
        width: 100%; }
        #future #box-content #drawer .innerBox .item__Box .item_flex div {
          width: 50%; }
          #future #box-content #drawer .innerBox .item__Box .item_flex div:nth-child(2) img {
            object-fit: cover;
            width: 100%;
            height: 100%; }
      #future #box-content #drawer .innerBox .item__Box .item__detail {
        margin-bottom: 20%; }
        @media screen and (max-width: 1920px) {
          #future #box-content #drawer .innerBox .item__Box .item__detail {
            margin-bottom: 30%; } }
        #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox {
          display: flex;
          align-items: flex-start;
          justify-content: space-between;
          width: 80%;
          margin: 10% auto; }
          #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div p {
            font-size: .9em;
            text-align: left;
            margin: 0;
            white-space: nowrap;
            width: fit-content; }
            @media screen and (max-width: 550px) {
              #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div p {
                font-size: 3.2vw; } }
            #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div p.name {
              line-height: 1.2;
              font-weight: 600;
              font-size: 1.5em;
              margin-bottom: .5em; }
              @media screen and (max-width: 550px) {
                #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div p.name {
                  font-size: 4.8vw; } }
          #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div a {
            border: 1px solid #000;
            width: 65px;
            height: 65px;
            border-radius: 50%;
            line-height: 65px;
            display: block;
            font-size: 0.9em;
            font-weight: 600; }
            @media screen and (max-width: 550px) {
              #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div a {
                font-size: 3.2vw; } }
            #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div a:hover {
              border-color: #d2463c;
              background: #d2463c;
              color: #ffffff; }
          #future #box-content #drawer .innerBox .item__Box .item__detail .flexBox div:nth-child(2) {
            padding-right: 5%; }
        #future #box-content #drawer .innerBox .item__Box .item__detail p {
          width: 80%;
          margin: 0 auto;
          text-align: left;
          font-size: 0.8em;
          line-height: 2.0; }
          @media screen and (max-width: 550px) {
            #future #box-content #drawer .innerBox .item__Box .item__detail p {
              font-size: 2.7vw; } }
      #future #box-content #drawer .innerBox .linkBtn {
        max-width: 300px;
        margin: 0 auto;
        padding-bottom: 3.0em; }
        #future #box-content #drawer .innerBox .linkBtn a {
          display: block;
          border: 1px solid #000;
          line-height: 1.0;
          padding: 1.5em;
          font-size: 0.9em;
          margin-bottom: 1.0em; }
          @media screen and (max-width: 550px) {
            #future #box-content #drawer .innerBox .linkBtn a {
              font-size: 3.0vw; } }
          #future #box-content #drawer .innerBox .linkBtn a:hover {
            background: #d2463c;
            border-color: #d2463c;
            color: #fff; }
            #future #box-content #drawer .innerBox .linkBtn a:hover img {
              -webkit-filter: brightness(0) invert(1);
              filter: brightness(0) invert(1); }
          #future #box-content #drawer .innerBox .linkBtn a img {
            vertical-align: middle; }
    #future #box-content #drawer .btn_1 {
      position: fixed;
      top: 70px;
      right: 0;
      z-index: 999;
      visibility: hidden;
      opacity: 0; }
      @media screen and (max-width: 550px) {
        #future #box-content #drawer .btn_1.view {
          visibility: visible;
          opacity: 1;
          transition: opacity 0.8s; } }
      #future #box-content #drawer .btn_1 a img {
        max-width: 50px; }
