@charset "UTF-8";
@import url("https://use.typekit.net/lli1phf.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: minerva-modern, 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--------------------------------------------------------- */
header {
  width: 100%;
  padding: 32px;
  box-sizing: border-box;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  left: 0px;
  top: 0px;
  z-index: 999; }
  header h1 {
    transition: all 0.25s ease-in;
    opacity: 0; }
    header h1 a {
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start; }
      header h1 a strong {
        color: #111;
        font-family: minerva-modern, sans-serif;
        font-size: 1rem;
        font-weight: 700;
        line-height: 100%;
        letter-spacing: 0rem;
        margin-bottom: 1px; }
      header h1 a span {
        color: #111;
        font-family: minerva-modern, sans-serif;
        font-size: 0.8rem;
        font-weight: 700;
        line-height: 100%;
        letter-spacing: 0rem; }
  header .link a {
    color: #FFF;
    font-family: minerva-modern, sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 100%;
    letter-spacing: 0.15rem;
    transition: all 0.25s ease-in; }

header.active h1 {
  opacity: 1; }

header.active .link a {
  color: #111; }

main {
  position: relative;
  z-index: 0; }
  main .credits {
    padding: 24px 0 0 0; }
    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 {
          color: #111;
          font-family: minerva-modern, sans-serif;
          font-size: 0.9rem;
          font-weight: 400;
          line-height: 1.3rem;
          letter-spacing: 0rem; }
          main .credits .credit dl dt strong {
            font-weight: 700;
            display: inline-block; }
            main .credits .credit dl dt strong + span {
              margin: 0 0 0 10px; }
          main .credits .credit dl dt span {
            display: inline-block; }
        main .credits .credit dl dd {
          margin: 0 0 0 30px; }
          main .credits .credit dl dd a {
            color: #FFF;
            font-family: minerva-modern, sans-serif;
            font-size: 0.9rem;
            font-weight: 700;
            line-height: 100%;
            letter-spacing: 0rem;
            background-color: #111;
            padding: 3px 9px;
            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 section.visual {
    width: 100%;
    height: 100vh;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    opacity: 0; }
    main section.visual:before {
      content: "";
      display: block;
      position: fixed;
      top: 0;
      left: 0;
      -webkit-transform: translate3d(0, 0, -1px);
      transform: translate3d(0, 0, -1px);
      width: 100%;
      height: 100%;
      background-image: url(../images/visual.jpg);
      background-repeat: no-repeat;
      background-position: center;
      background-size: cover;
      -webkit-background-size: cover;
      background-size: cover;
      z-index: 0; }
    main section.visual .title {
      text-align: left;
      padding: 32px;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: flex-start;
      align-items: stretch;
      z-index: 1; }
      main section.visual .title h1 {
        color: #FFF;
        font-family: minerva-modern, sans-serif;
        font-size: 2.8rem;
        font-weight: 700;
        line-height: 100%;
        letter-spacing: 0rem;
        transition: all 1s ease-in;
        opacity: 0; }
      main section.visual .title h2 {
        color: #FFF;
        font-family: minerva-modern, sans-serif;
        font-size: 2rem;
        font-weight: 700;
        line-height: 100%;
        letter-spacing: 0.15rem;
        text-align: justify;
        transition: all 1s ease-in 0.5s;
        opacity: 0; }
    main section.visual.active .title h1 {
      margin-top: 0px;
      opacity: 1; }
    main section.visual.active .title h2 {
      margin-top: 0px;
      opacity: 1; }
    main section.visual.hide:before {
      opacity: 0; }
  main section.look {
    width: 100%;
    padding: 234px 0 164px 0;
    background-color: #FFF;
    position: relative;
    z-index: 1; }
    main section.look .look1 {
      width: 996px;
      margin: 0 auto 218px auto; }
      main section.look .look1 .wrap {
        width: 100%;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: row;
        justify-content: space-between;
        align-items: center; }
        main section.look .look1 .wrap .p1 {
          width: 500px;
          transition: all 0.5s ease-in 0s;
          opacity: 0; }
        main section.look .look1 .wrap .p2 {
          width: 400px;
          transition: all 0.5s ease-in 0.5s;
          opacity: 0; }
      main section.look .look1.active .wrap .p1, main section.look .look1.active .wrap .p2 {
        opacity: 1; }
    main section.look .look2 {
      width: 900px;
      margin: 0 auto 181px auto;
      transition: all 0.5s ease-in 0s;
      opacity: 0; }
      main section.look .look2 .photo {
        margin: 0 auto; }
      main section.look .look2.active {
        opacity: 1; }
    main section.look .look3 {
      width: 100%;
      margin: 0 auto 228px auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: row;
      justify-content: flex-start;
      align-items: flex-start; }
      main section.look .look3 .left {
        width: 50%;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-end; }
        main section.look .look3 .left .credits {
          width: 450px; }
      main section.look .look3 .right {
        width: 50%; }
        main section.look .look3 .right .credits {
          padding-left: 60px; }
    main section.look .look4 {
      width: 996px;
      margin: 0 auto 218px auto; }
      main section.look .look4 .wrap {
        width: 100%;
        padding-top: 200px;
        transition: all 1.5s ease-in 0s;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: row;
        justify-content: space-between;
        align-items: center; }
        main section.look .look4 .wrap .p1 {
          width: 500px;
          transition: all 0.5s ease-in 0s;
          opacity: 0; }
        main section.look .look4 .wrap .p2 {
          width: 400px;
          transition: all 0.5s ease-in 0.5s;
          opacity: 0; }
      main section.look .look4.active .wrap {
        padding-top: 0px; }
        main section.look .look4.active .wrap .p1, main section.look .look4.active .wrap .p2 {
          opacity: 1; }
    main section.look .look5 {
      width: 996px;
      padding: 120px 0 0 60px;
      margin: 0 auto 177px auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start;
      transition: all 1s ease-in 0s; }
      main section.look .look5 .p1 {
        width: 800px;
        margin: 0 0 240px 0;
        align-self: flex-end;
        transition: all 0.5s ease-in 0s;
        opacity: 0; }
      main section.look .look5 .p2 {
        width: 500px;
        margin: 0;
        transition: all 0.5s ease-in 1s;
        opacity: 0; }
      main section.look .look5.active {
        padding: 0 0 0 60px; }
        main section.look .look5.active .p1, main section.look .look5.active .p2 {
          opacity: 1; }
    main section.look .look6 {
      width: 800px;
      padding: 0px;
      margin: 0px auto 220px auto; }
      main section.look .look6 .p1 {
        width: 100%;
        margin: 0 auto 40px auto;
        align-self: flex-end;
        transition: all 0.5s ease-in 0s;
        opacity: 0; }
      main section.look .look6 .p2 {
        width: 100%;
        margin: 0 auto;
        transition: all 0.5s ease-in 0.5s;
        opacity: 0; }
      main section.look .look6.active .p1, main section.look .look6.active .p2 {
        opacity: 1; }
    main section.look .look7 {
      width: 1086px;
      margin: 0 auto 282px auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: row;
      justify-content: space-between;
      align-items: flex-start; }
      main section.look .look7 .left {
        width: 500px;
        transition: all 0.5s ease-in 0s;
        opacity: 0; }
      main section.look .look7 .right {
        width: 500px;
        transition: all 0.5s ease-in 0.5s;
        opacity: 0; }
      main section.look .look7.active .left, main section.look .look7.active .right {
        opacity: 1; }
    main section.look article {
      position: relative;
      overflow: hidden; }
      main section.look article.deco1 {
        width: 100%;
        height: calc(100vw * 0.44);
        margin: 0 auto 209px auto;
        overflow: hidden; }
        main section.look article.deco1 img {
          width: 100%;
          height: auto;
          position: absolute;
          left: 0px;
          top: 0px; }
          main section.look article.deco1 img:last-child {
            display: none; }
      main section.look article.deco2 {
        width: 485px;
        margin: 0 auto 318px auto; }
      main section.look article.deco3 {
        width: 100%;
        height: calc(100vw * 0.44);
        margin: 0 auto; }
        main section.look article.deco3 img {
          width: 100%;
          height: auto;
          position: absolute;
          left: 0px;
          top: 0px; }
          main section.look article.deco3 img:last-child {
            display: none; }

footer {
  width: 100%;
  padding: 0 0 150px 0;
  background-color: #FFF;
  position: relative;
  z-index: 5; }
  footer h2 {
    width: 201px;
    margin: 0 auto 55px auto; }
    footer h2 a {
      height: 62px;
      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 ul {
    width: 570px;
    margin: 0 auto 211px auto;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    justify-content: space-between;
    align-items: center; }
    footer ul li {
      width: 264px; }
      footer ul li a span {
        color: #FFF;
        font-family: minerva-modern, 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 ul li a span:hover {
          color: #FFF;
          background-color: #999; }
      footer 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: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", 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; }
  header {
    padding: 16px;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start; }
    header h1 a strong {
      color: #111;
      font-family: minerva-modern, sans-serif;
      font-size: 0.9rem;
      font-weight: 700;
      line-height: 100%;
      letter-spacing: 0rem;
      margin-bottom: 1px; }
    header h1 a span {
      color: #111;
      font-family: minerva-modern, sans-serif;
      font-size: 0.7rem;
      font-weight: 700;
      line-height: 100%;
      letter-spacing: 0rem; }
    header .link a {
      color: #FFF;
      font-family: minerva-modern, sans-serif;
      font-size: 0.9rem;
      font-weight: 700;
      line-height: 100%;
      letter-spacing: 0rem; }
  main .credits {
    padding: 17px 0 0 0; }
    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 {
          color: #111;
          font-family: minerva-modern, sans-serif;
          font-size: 0.8rem;
          font-weight: 400;
          line-height: 1.2rem;
          letter-spacing: 0rem; }
          main .credits .credit dl dt strong {
            font-weight: 700;
            display: inline-block; }
            main .credits .credit dl dt strong + span {
              margin: 0 0 0 7px; }
        main .credits .credit dl dd {
          margin: 0 0 0 25px; }
          main .credits .credit dl dd a {
            color: #FFF;
            font-family: minerva-modern, sans-serif;
            font-size: 0.8rem;
            font-weight: 700;
            line-height: 100%;
            letter-spacing: 0rem;
            padding: 2px 8px; }
            main .credits .credit dl dd a:hover {
              color: #FFF;
              background-color: #111; }
  main section.visual:before {
    background-image: url(../images_sp/visual_sp.jpg); }
  main section.visual .title {
    padding: 16px;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch; }
    main section.visual .title h1 {
      color: #FFF;
      font-family: minerva-modern, sans-serif;
      font-size: 1.4rem;
      font-weight: 700;
      line-height: 100%;
      letter-spacing: 0rem; }
    main section.visual .title h2 {
      color: #FFF;
      font-family: minerva-modern, sans-serif;
      font-size: 1rem;
      font-weight: 700;
      line-height: 100%;
      letter-spacing: 0.06rem;
      text-align: justify; }
  main section.look {
    width: 100%;
    padding: 20px 0 75px 0; }
    main section.look .look1 {
      width: 100%;
      padding: 0 19px;
      margin: 0 auto 54px auto; }
      main section.look .look1 .wrap {
        width: 100%;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: flex-start;
        align-items: center; }
        main section.look .look1 .wrap .p1 {
          width: 100%;
          margin-bottom: 21px; }
        main section.look .look1 .wrap .p2 {
          width: 100%;
          padding: 0 36px 0 31px;
          transition: all 0.5s ease-in 1s; }
    main section.look .look2 {
      width: 100%;
      margin: 0 auto 50px auto;
      transition: all 0.5s ease-in 0.5s; }
      main section.look .look2 .credits {
        padding: 17px 38px 0 38px; }
    main section.look .look3 {
      width: 100%;
      padding: 0 19px;
      margin: 0 auto 50px auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start; }
      main section.look .look3 .left {
        width: 100%;
        margin: 0 auto 50px auto;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-end; }
        main section.look .look3 .left .credits {
          width: 100%;
          padding: 17px 19px 0 19px; }
      main section.look .look3 .right {
        width: 100%; }
        main section.look .look3 .right .credits {
          width: 100%;
          padding: 17px 19px 0 19px; }
    main section.look .look4 {
      width: 100%;
      padding: 0 19px;
      margin: 0 auto 50px auto; }
      main section.look .look4 .wrap {
        padding-top: 50px;
        display: flex;
        flex-wrap: nowrap;
        flex-direction: column;
        justify-content: space-between;
        align-items: center; }
        main section.look .look4 .wrap .p1 {
          width: 100%;
          margin: 0 auto 18px auto; }
        main section.look .look4 .wrap .p2 {
          width: 100%;
          padding: 0 35px;
          transition: all 0.5s ease-in 1s; }
      main section.look .look4.active .wrap {
        padding-top: 0px; }
    main section.look .look5 {
      width: 100%;
      padding: 40px 0 0 0;
      margin: 0 auto 75px auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start; }
      main section.look .look5 .p1 {
        width: 100%;
        margin: 0 auto 22px auto; }
      main section.look .look5 .p2 {
        width: 100%;
        padding: 0 38px;
        margin: 0; }
      main section.look .look5 .credits {
        padding: 17px 38px 0 38px; }
      main section.look .look5.active {
        padding: 0px; }
    main section.look .look6 {
      width: 100%;
      padding: 0 19px;
      margin: 0px auto 50px auto; }
      main section.look .look6 .p1 {
        width: 100%;
        margin: 0 auto 17px auto; }
      main section.look .look6 .p2 {
        width: 100%; }
      main section.look .look6 .credits {
        padding: 17px 19px 0 19px; }
    main section.look .look7 {
      width: 100%;
      padding: 0 38px;
      margin: 0 auto 75px auto;
      display: flex;
      flex-wrap: nowrap;
      flex-direction: column;
      justify-content: space-between;
      align-items: flex-start; }
      main section.look .look7 .left {
        width: 100%;
        margin: 0 auto 20px auto; }
      main section.look .look7 .right {
        width: 100%; }
    main section.look article.deco1 {
      width: 100%;
      height: calc(100vw * 0.55);
      margin: 0 auto 75px auto; }
      main section.look article.deco1 img:first-child {
        display: none; }
      main section.look article.deco1 img:last-child {
        display: block; }
    main section.look article.deco2 {
      width: 200px;
      margin: 0 auto 75px auto; }
    main section.look article.deco3 {
      width: 100%;
      height: calc(100vw * 0.55);
      margin: 0 auto; }
      main section.look article.deco3 img:first-child {
        display: none; }
      main section.look article.deco3 img:last-child {
        display: block; }
  footer {
    width: 100%;
    background-color: #FFF;
    padding: 0 0 65px 0;
    position: relative;
    z-index: 1; }
    footer h2 {
      width: 119px;
      margin: 0 auto 32px auto; }
      footer h2 a {
        height: 36px; }
    footer ul {
      width: 100%;
      padding: 0 19px;
      margin: 0 auto 95px auto; }
      footer ul li {
        width: calc(50% - 9px); }
        footer ul li a span {
          color: #FFF;
          font-family: minerva-modern, sans-serif;
          font-size: 0.9rem;
          font-weight: 700;
          line-height: 100%;
          letter-spacing: 0rem;
          height: 30px; }
          footer ul li a span:hover {
            background-color: #111; }
        footer ul li:nth-child(2) span:before {
          content: '';
          margin: 0 6px 0 0;
          width: 14px;
          height: 14px;
          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: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
      font-size: 0.7rem;
      font-weight: 400;
      line-height: 100%;
      letter-spacing: 0rem;
      padding: 25px 0 0 0;
      border-top: solid 1px #111; }
  .pgtop {
    width: 20px;
    margin: 0 -10px 0 0;
    right: 50%;
    bottom: 16px; }
    .pgtop a {
      height: 20px; }
      .pgtop a:hover {
        opacity: 1; } }
