@charset "UTF-8";
@import url("https://use.typekit.net/mzu1hnx.css");
@import url("https://use.typekit.net/awi7bbz.css");
@keyframes bar-anime {
  0% {
    height: 40px;
    top: -40px; }
  75% {
    height: 40px;
    top: 50px; }
  100% {
    height: 40px;
    top: 50px; } }

@keyframes bar-anime-sp {
  0% {
    height: 40px;
    top: -40px; }
  75% {
    height: 40px;
    top: 40px; }
  100% {
    height: 40px;
    top: 40px; } }

/* ------------------------------------------------------------------------------------------------------------------------ */
html, body {
  width: 100%;
  height: 100%; }

html {
  font-size: 12pt;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

body {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-size: 1rem;
  line-height: 1.6rem;
  color: #111;
  text-align: center;
  -webkit-text-size-adjust: 100%;
  position: fixed;
  left: 0px;
  top: 0px;
  overflow: hidden; }
  body.loaded {
    position: static;
    overflow: visible; }

a {
  color: #111;
  text-decoration: none;
  cursor: pointer; }

a:hover, a:active, a.active {
  color: #999; }

img {
  width: 100%;
  height: auto;
  vertical-align: bottom; }

i {
  font-style: normal; }

form, section, p, div, ul, li, dl, dt, dd, a, span, input, textarea {
  padding: 0px;
  margin: 0px;
  box-sizing: border-box;
  list-style: none; }

/* ---------------------------------------------------------page--------------------------------------------------------- */
#loader {
  color: #FFF;
  width: 100%;
  height: 100vh;
  background-color: #FFF;
  position: fixed;
  right: 0px;
  top: 0px;
  z-index: 99999;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  overflow: hidden; }
  #loader .loadtext {
    color: #111;
    font-family: acumin-pro, sans-serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 100%;
    letter-spacing: 0rem; }
  #loader .bar {
    width: 100%;
    position: absolute;
    left: 0px;
    top: 0px;
    z-index: 5; }
  #loader .bar span {
    width: 0%;
    background-color: #111;
    height: 5px;
    display: block; }

nav {
  position: fixed;
  right: 25px;
  top: 25px;
  z-index: 999; }
  nav a {
    color: #FFF;
    font-family: acumin-pro, sans-serif;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 100%;
    letter-spacing: 0rem; }
    nav a.active {
      color: #111; }

header {
  width: 25%;
  height: 100vh;
  background-color: #FFF;
  position: absolute;
  left: 0px;
  top: 0px;
  z-index: 5;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  justify-content: center;
  align-items: center; }
  header div {
    margin: 200px 0 0 0;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: all 2s ease-out 0s; }
    header div h1 {
      width: 120px;
      height: 148px;
      background-image: url(../images/logo.png);
      margin-bottom: 40px;
      text-align: left;
      text-indent: 999%;
      white-space: nowrap;
      display: block;
      overflow: hidden;
      background-repeat: no-repeat;
      background-position: left top;
      background-size: contain; }
    header div h2 {
      width: 104px;
      height: 10px;
      background-image: url(../images/logo2.png);
      text-align: left;
      text-indent: 999%;
      white-space: nowrap;
      display: block;
      overflow: hidden;
      background-repeat: no-repeat;
      background-position: left top;
      background-size: contain; }
  header.active div {
    margin: 0px; }

main {
  width: 100%; }
  main .credits {
    padding: 24px 0 0 0;
    margin: 0 auto 60px auto; }
    main .credits .credit {
      width: 100%;
      margin: 0 0 10px 0; }
      main .credits .credit:last-child {
        margin: 0px; }
      main .credits .credit dl {
        text-align: left;
        width: 100%;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: row;
        justify-content: flex-start;
        align-items: center; }
        main .credits .credit dl dt {
          line-height: 100%; }
          main .credits .credit dl dt strong {
            color: #111;
            font-family: acumin-pro, sans-serif;
            font-size: 1rem;
            font-weight: 600;
            line-height: 1.6rem;
            letter-spacing: 0rem;
            display: inline-block; }
            main .credits .credit dl dt strong + strong {
              margin: 0 0 0 10px; }
          main .credits .credit dl dt span {
            color: #111;
            font-family: acumin-pro, sans-serif;
            font-size: 0.9rem;
            font-weight: 400;
            line-height: 1.3rem;
            letter-spacing: 0rem;
            display: inline-block; }
        main .credits .credit dl dd {
          margin: 0 0 0 30px; }
          main .credits .credit dl dd a {
            color: #FFF;
            font-family: acumin-pro, sans-serif;
            font-size: 1rem;
            font-weight: 600;
            line-height: 100%;
            letter-spacing: 0rem;
            background-color: #111;
            padding: 4px 8px;
            transition: all 0.25s ease-in; }
            main .credits .credit dl dd a:hover {
              color: #FFF;
              background-color: #999; }
  main .video {
    width: 100%; }
    main .video iframe {
      width: 100%;
      height: calc((45vw - 60px)*0.5625); }
  main .visual {
    width: 100%;
    margin: 0 auto; }
    main .visual ul {
      width: 100%;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: row;
      justify-content: flex-end;
      align-items: stretch; }
      main .visual ul li {
        width: 25%; }
        main .visual ul li div {
          width: 100%;
          height: 25vh;
          opacity: 0;
          background-repeat: no-repeat;
          background-position: center;
          background-size: cover; }
          main .visual ul li div.pc2,
          main .visual ul li div.pc3,
          main .visual ul li div.pc6 {
            height: 75vh; }
          main .visual ul li div.pc1 {
            transition: opacity 0.25s ease-in 1s; }
          main .visual ul li div.pc2 {
            transition: opacity 0.25s ease-in 1.25s; }
          main .visual ul li div.pc3 {
            transition: opacity 0.25s ease-in 1.5s; }
          main .visual ul li div.pc4 {
            transition: opacity 0.25s ease-in 1.75s; }
          main .visual ul li div.pc5 {
            transition: opacity 0.25s ease-in 2s; }
          main .visual ul li div.pc6 {
            transition: opacity 0.25s ease-in 2.25s; }
      main .visual ul.active li div {
        opacity: 1; }
    main .visual::after {
      content: '';
      width: 120px;
      height: 60px;
      margin: 0 0 0 -60px;
      background-image: url(../images/scroll.png);
      text-align: left;
      text-indent: 999%;
      white-space: nowrap;
      display: block;
      overflow: hidden;
      background-repeat: no-repeat;
      background-position: left top;
      background-size: contain;
      position: absolute;
      left: 50%;
      bottom: 0px;
      z-index: 5; }
  main .look {
    width: 100%;
    padding: 0px;
    box-sizing: border-box;
    position: relative; }
    main .look .mylook {
      padding: 60px;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: row;
      justify-content: flex-end;
      align-items: flex-start;
      position: relative; }
      main .look .mylook .prof {
        width: calc(55vw - 60px);
        height: 100vh;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: fixed;
        left: 0px;
        top: 0px;
        opacity: 0;
        box-sizing: border-box;
        transition: opacity 0.25s ease-in; }
        main .look .mylook .prof dl {
          margin-bottom: 60px; }
          main .look .mylook .prof dl dt {
            display: flex;
            flex-wrap: nowrap;
            flex-direction: row;
            justify-content: center;
            align-items: flex-start;
            margin-bottom: 20px; }
            main .look .mylook .prof dl dt span {
              color: #111;
              font-family: acumin-pro, sans-serif;
              font-size: 1.4rem;
              font-weight: 600;
              line-height: 0.5rem;
              letter-spacing: 0.1rem; }
              main .look .mylook .prof dl dt span sup {
                font-size: 0.8rem;
                vertical-align: super; }
            main .look .mylook .prof dl dt strong {
              color: #111;
              font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
              font-size: 1.6rem;
              font-weight: 600;
              line-height: 100%;
              letter-spacing: 0.1rem;
              margin: 0 0 0 10px; }
          main .look .mylook .prof dl dd {
            color: #111;
            font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
            font-size: 1.2rem;
            font-weight: 400;
            line-height: 100%;
            letter-spacing: 0rem; }
        main .look .mylook .prof ul li {
          color: #111;
          font-family: acumin-pro, sans-serif;
          font-size: 1.2rem;
          font-weight: 600;
          line-height: 100%;
          letter-spacing: 0.1rem; }
          main .look .mylook .prof ul li:not(:last-child) {
            margin-bottom: 10px; }
          main .look .mylook .prof ul li a {
            text-decoration: underline; }
      main .look .mylook .photo {
        width: calc(45vw - 60px);
        height: auto; }
        main .look .mylook .photo > div:first-child {
          margin-bottom: 60px; }
      main .look .mylook.active .prof {
        opacity: 1;
        z-index: 10; }
      main .look .mylook.active.end .prof {
        margin: -60px 0 0 0;
        position: absolute;
        left: 0px;
        top: 50%; }

footer {
  width: 100%;
  padding: 180px 0 120px 0;
  position: relative; }
  footer .inner {
    width: 100%;
    margin: 0 auto 120px auto; }
    footer .inner h2 {
      width: 200px;
      margin: 0 auto 60px auto; }
      footer .inner h2 a {
        height: 38px;
        background-image: url(../images/logo.svg);
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        text-align: left;
        text-indent: 999%;
        white-space: nowrap;
        display: block;
        overflow: hidden; }
    footer .inner ul {
      width: 570px;
      margin: 0 auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: row;
      justify-content: space-between;
      align-items: center; }
      footer .inner ul li {
        width: 265px; }
        footer .inner ul li strong {
          display: none; }
        footer .inner ul li a span {
          color: #FFF;
          font-family: acumin-pro, sans-serif;
          font-size: 1.2rem;
          font-weight: 700;
          line-height: 100%;
          letter-spacing: 0rem;
          height: 50px;
          background-color: #111;
          display: flex;
          flex-wrap: nowrap;
          flex-direction: row;
          justify-content: center;
          align-items: center;
          transition: all 0.25s ease-in; }
          footer .inner ul li a span:hover {
            color: #FFF;
            background-color: #999; }
        footer .inner ul li:nth-child(2) span:before {
          content: '';
          margin: 0 8px 0 0;
          width: 20px;
          height: 20px;
          background-image: url(../images/logo_insta.svg);
          background-repeat: no-repeat;
          background-position: center;
          background-size: contain;
          display: inline-block; }
  footer p {
    color: #111;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0rem;
    padding: 25px 0 0 0;
    border-top: solid 1px #111; }

.pgtop {
  width: 40px;
  position: fixed;
  right: 32px;
  bottom: 32px;
  z-index: 9999;
  display: none; }
  .pgtop a {
    height: 30px;
    background-image: url(../images/arrow.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    text-align: left;
    text-indent: 999%;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    transition: all 0.25s ease-in; }
    .pgtop a:hover {
      opacity: 0.7; }

/* ----------------------------------------------- Media Queries Smartphone ----------------------------------------------- */
@media screen and (max-width: 768px) {
  body {
    font-size: 1rem;
    line-height: 1.6rem; }
  nav {
    right: 20px;
    top: 10px; }
    nav a {
      color: #FFF;
      font-family: acumin-pro, sans-serif;
      font-size: 1rem;
      font-weight: 600;
      line-height: 100%;
      letter-spacing: 0rem;
      writing-mode: vertical-rl; }
      nav a.active {
        color: #111; }
  header {
    width: 100%;
    height: 100vh;
    background-color: transparent;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    justify-content: center;
    align-items: center; }
    header div {
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
      header div h1 {
        width: 94px;
        height: 116px;
        background-image: url(../images_sp/logo_w.png);
        margin-bottom: 3px; }
      header div h2 {
        width: 81px;
        height: 8px;
        background-image: url(../images_sp/logo2_w.png); }
  main {
    width: 100%; }
    main .credits {
      padding: 19px 0 0 0;
      margin: 0 auto 30px auto;
      display: flex;
      flex-wrap: wrap;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start; }
      main .credits .credit {
        width: 100%;
        margin: 0 0 5px 0; }
        main .credits .credit:last-child {
          margin: 0px; }
        main .credits .credit dl {
          text-align: left;
          width: auto;
          display: flex;
          flex-wrap: nowrap;
          flex-direction: row;
          justify-content: space-between;
          align-items: center; }
          main .credits .credit dl dt {
            line-height: 100%; }
            main .credits .credit dl dt strong {
              color: #111;
              font-family: acumin-pro, sans-serif;
              font-size: 0.9rem;
              font-weight: 600;
              line-height: 1.2rem;
              letter-spacing: 0rem;
              display: inline-block; }
              main .credits .credit dl dt strong + strong {
                margin: 0 0 0 10px; }
            main .credits .credit dl dt span {
              color: #111;
              font-family: acumin-pro, sans-serif;
              font-size: 0.8rem;
              font-weight: 400;
              line-height: 1.2rem;
              letter-spacing: 0rem;
              display: inline-block; }
          main .credits .credit dl dd {
            margin: 0 0 0 30px; }
            main .credits .credit dl dd a {
              color: #FFF;
              font-family: acumin-pro, sans-serif;
              font-size: 0.9rem;
              font-weight: 600;
              line-height: 100%;
              letter-spacing: 0rem;
              background-color: #111;
              padding: 4px 8px;
              transition: all 0.25s ease-in; }
              main .credits .credit dl dd a:hover {
                color: #FFF;
                background-color: #999; }
              main .credits .credit dl dd a:not([href]) {
                display: none; }
    main .video iframe {
      height: calc((100vw - 38px)*0.5625); }
    main .visual {
      width: 100%;
      height: 100vh;
      margin: 0 auto; }
      main .visual ul {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        flex-direction: row;
        justify-content: flex-start;
        align-items: flex-start; }
        main .visual ul li {
          width: 50%; }
          main .visual ul li:nth-child(1) {
            width: 100%;
            height: 35vh;
            display: flex;
            flex-wrap: nowrap;
            flex-direction: row;
            justify-content: flex-start;
            align-items: flex-start;
            order: 3; }
            main .visual ul li:nth-child(1) div {
              width: 50%;
              height: 100%;
              background-repeat: no-repeat;
              background-position: center top;
              background-size: cover;
              order: 2; }
              main .visual ul li:nth-child(1) div.pc1 {
                background-image: url(../images/visual6.jpg) !important; }
              main .visual ul li:nth-child(1) div.pc2 {
                height: 100%;
                order: 1; }
              main .visual ul li:nth-child(1) div.pc1 {
                transition: opacity 0.25s ease-in 2s; }
              main .visual ul li:nth-child(1) div.pc2 {
                transition: opacity 0.25s ease-in 2.25s; }
              main .visual ul li:nth-child(1) div.pc3 {
                transition: opacity 0.25s ease-in 1s; }
              main .visual ul li:nth-child(1) div.pc4 {
                transition: opacity 0.25s ease-in 1.5s; }
              main .visual ul li:nth-child(1) div.pc5 {
                transition: opacity 0.25s ease-in 1.25s; }
              main .visual ul li:nth-child(1) div.pc6 {
                transition: opacity 0.25s ease-in 1.75s; }
          main .visual ul li:nth-child(2) {
            height: 65vh;
            order: 1; }
            main .visual ul li:nth-child(2) div {
              width: 100%;
              height: 35%;
              background-repeat: no-repeat;
              background-position: center;
              background-size: cover; }
              main .visual ul li:nth-child(2) div.pc3 {
                height: 65%; }
          main .visual ul li:nth-child(3) {
            order: 2;
            height: 65vh;
            order: 1;
            display: flex;
            flex-wrap: nowrap;
            flex-direction: column;
            justify-content: flex-start;
            align-items: flex-start; }
            main .visual ul li:nth-child(3) div {
              width: 100%;
              height: 65%;
              background-repeat: no-repeat;
              background-position: center;
              background-size: cover;
              order: 2; }
              main .visual ul li:nth-child(3) div.pc5 {
                background-image: url(../images_sp/visual5_sp.jpg) !important; }
              main .visual ul li:nth-child(3) div.pc6 {
                background-image: url(../images/visual1.jpg) !important;
                height: 35%;
                order: 1; }
      main .visual::after {
        content: '';
        width: 60px;
        height: 30px;
        margin: 0 0 0 -30px;
        position: fixed;
        transition: all 0.25s ease-in; }
      main .visual.scroll::after {
        opacity: 0; }
    main .look {
      width: 100%;
      padding: 0px;
      box-sizing: border-box;
      position: relative; }
      main .look .mylook {
        padding: 0px;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
        position: relative; }
        main .look .mylook .prof {
          width: 100%;
          height: 70px;
          padding: 0 19px;
          background-color: #FFF;
          display: flex;
          flex-wrap: nowrap;
          flex-direction: row;
          justify-content: space-between;
          align-items: center;
          position: static;
          left: 0px;
          top: 0px;
          opacity: 1;
          box-sizing: border-box;
          transition: opacity 0.25s ease-in; }
          main .look .mylook .prof dl {
            text-align: left;
            margin-bottom: 0px; }
            main .look .mylook .prof dl dt {
              display: flex;
              flex-wrap: nowrap;
              flex-direction: row;
              justify-content: flex-start;
              align-items: flex-start;
              margin-bottom: 5px; }
              main .look .mylook .prof dl dt span {
                color: #111;
                font-family: acumin-pro, sans-serif;
                font-size: 0.8rem;
                font-weight: 600;
                line-height: 0.2rem;
                letter-spacing: 0.1rem; }
                main .look .mylook .prof dl dt span sup {
                  font-size: 0.6rem;
                  vertical-align: super; }
              main .look .mylook .prof dl dt strong {
                color: #111;
                font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
                font-size: 1rem;
                font-weight: 600;
                line-height: 100%;
                letter-spacing: 0rem;
                margin: 0 0 0 5px; }
            main .look .mylook .prof dl dd {
              color: #111;
              font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
              font-size: 0.7rem;
              font-weight: 400;
              line-height: 100%;
              letter-spacing: 0rem;
              margin: 0px; }
          main .look .mylook .prof ul {
            padding: 0 10px 0 0;
            display: flex;
            flex-wrap: nowrap;
            flex-direction: row;
            justify-content: flex-start;
            align-items: center; }
            main .look .mylook .prof ul li {
              color: #111;
              font-family: acumin-pro, sans-serif;
              font-size: 0.8rem;
              font-weight: 600;
              line-height: 100%;
              letter-spacing: 0rem; }
              main .look .mylook .prof ul li:not(:last-child) {
                margin-bottom: 0px; }
              main .look .mylook .prof ul li:last-child {
                margin: 0 0 0 5px; }
              main .look .mylook .prof ul li a {
                text-decoration: underline; }
        main .look .mylook .photo {
          width: 100%;
          height: auto;
          padding: 0 19px 19px 19px; }
          main .look .mylook .photo > div:first-child {
            margin-bottom: 19px; }
        main .look .mylook.active {
          padding-top: 70px; }
          main .look .mylook.active .prof {
            opacity: 1;
            position: fixed;
            z-index: 10; }
          main .look .mylook.active.end .prof {
            margin: -35px 0 0 0;
            position: absolute; }
        main .look .mylook.look1 {
          z-index: 0; }
        main .look .mylook.look2 {
          z-index: 1; }
        main .look .mylook.look3 {
          z-index: 2; }
        main .look .mylook.look4 {
          z-index: 3; }
        main .look .mylook.look5 {
          z-index: 4; }
        main .look .mylook.look6 {
          z-index: 5; }
  footer {
    width: 100%;
    padding: 60px 0 60px 0;
    position: relative; }
    footer .inner {
      width: 100%;
      margin: 0 auto 60px auto; }
      footer .inner h2 {
        width: 170px;
        margin: 0 auto 30px auto; }
        footer .inner h2 a {
          height: 32px; }
      footer .inner ul {
        width: 250px;
        margin: 0 auto;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: space-between;
        align-items: center; }
        footer .inner ul li {
          width: 100%; }
          footer .inner ul li:first-child {
            margin-bottom: 40px; }
          footer .inner ul li strong {
            color: #111;
            font-family: acumin-pro, sans-serif;
            font-size: 1.4rem;
            font-weight: 600;
            line-height: 100%;
            letter-spacing: 0rem;
            margin-bottom: 15px;
            display: block; }
          footer .inner ul li a span {
            color: #FFF;
            font-family: acumin-pro, sans-serif;
            font-size: 1.2rem;
            font-weight: 700;
            line-height: 100%;
            letter-spacing: 0rem;
            height: 50px;
            background-color: #111;
            display: flex;
            flex-wrap: nowrap;
            flex-direction: row;
            justify-content: center;
            align-items: center;
            transition: all 0.25s ease-in; }
            footer .inner ul li a span:hover {
              color: #FFF;
              background-color: #999; }
          footer .inner ul li:nth-child(2) span:before {
            content: '';
            margin: 0 8px 0 0;
            width: 20px;
            height: 20px;
            background-image: url(../images/logo_insta.svg);
            background-repeat: no-repeat;
            background-position: center;
            background-size: contain;
            display: inline-block; }
    footer p {
      color: #111;
      font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
      font-size: 0.7rem;
      font-weight: 400;
      line-height: 100%;
      letter-spacing: 0rem;
      padding: 19px 0 0 0;
      border-top: solid 1px #111; }
  .pgtop {
    margin: 0 -20px 0 0;
    right: 50%;
    bottom: 10px; }
    .pgtop a:hover {
      opacity: 1; } }
