@charset "UTF-8";
@import url(reset.css);
/*-------------------------------------------------
 common
-------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Righteous&display=swap");
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@100;300;400;500;700;800;900&display=swap");
@font-face {
  font-family: 'futura-r';
  src: url(../fonts/texgyreadventor_regular_macroman/texgyreadventor-regular-webfont.woff) format("woff"), url(../fonts/texgyreadventor_regular_macroman/texgyreadventor-regular-webfont.ttf) format("truetype"); }
@font-face {
  font-family: 'futura-b';
  src: url(../fonts/texgyreadventor_bold_macroman/texgyreadventor-bold-webfont.woff) format("woff"), url(../fonts/texgyreadventor_bold_macroman/texgyreadventor-bold-webfont.ttf) format("truetype"); }
html, body {
  font-size: 14px;
  line-height: 1.5;
  font-weight: 300;
  background-color: #ffffff;
  font-family: 'Righteous', cursive, 'M PLUS 1p', "ヒラギノ角ゴシック", Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", "Meiryo", sans-serif;
  color: #333;
  margin: 0;
  padding: 0; }

* {
  list-style-type: none; }

canvas {
  width: 100%; }

img {
  max-width: 100%;
  height: auto; }

a {
  color: #333;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  text-decoration: none; }

.pc {
  display: block; }

.sp {
  display: none; }

/* ローディング画面 */
#loading {
  width: 100vw;
  height: 100vh;
  -webkit-transition: all 1s;
  transition: all 1s;
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999; }
  #loading img {
    width: 250px;
    display: block;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }

.loaded {
  opacity: 0;
  visibility: hidden; }

/*essect*/
.effect {
  -webkit-transition: ease 1.5s;
  transition: ease 1.5s;
  opacity: 0;
  -webkit-transform: translateY(20px) translateX(20px);
          transform: translateY(20px) translateX(20px); }

.effect.fadein {
  opacity: 1;
  -webkit-transform: translateY(0px);
          transform: translateY(0px); }

.effectLeft {
  -webkit-transition: ease 1s;
  transition: ease 1s;
  opacity: 0;
  -webkit-transform: translateX(-50px);
          transform: translateX(-50px); }

.effectLeft.fadein {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0); }

.effect2 {
  -webkit-transition: ease 1s;
  transition: ease 1s;
  -webkit-transform: translateX(-1000px);
          transform: translateX(-1000px);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

.effect2.trans {
  -webkit-transform: translateX(0px);
          transform: translateX(0px);
  background: linear-gradient(217deg, rgba(255, 0, 0, 0.8), rgba(255, 0, 0, 0) 70.71%), linear-gradient(127deg, rgba(0, 255, 0, 0.8), rgba(0, 255, 0, 0) 70.71%), linear-gradient(336deg, rgba(0, 0, 255, 0.8), rgba(0, 0, 255, 0) 70.71%); }

.effect2.trans.trans2 {
  -webkit-transform: translateX(1000px);
          transform: translateX(1000px); }

.effect2.trans.trans2 ~ img {
  visibility: visible !important; }

.effectImg {
  -webkit-animation: profile 2s linear infinite;
          animation: profile 2s linear infinite; }

@-webkit-keyframes profile {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); } }

@keyframes profile {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg); }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg); } }
/* modal */
.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%; }

.modal__bg {
  background: rgba(0, 0, 0, 0.8);
  height: 100vh;
  position: absolute;
  width: 100%; }

.modal__content {
  left: 50%;
  padding: 40px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  height: 90%; }

.video, .images {
  height: auto;
  width: 100%; }

.batsu {
  display: block;
  width: 50px;
  height: 50px;
  position: relative;
  margin-left: auto; }

.batsu::before, .batsu::after {
  content: "";
  display: block;
  width: 100%;
  height: 6px;
  background: #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transform-origin: 0% 50%;
          transform-origin: 0% 50%;
  position: absolute;
  top: calc(14% - 5px);
  left: 0%; }

.batsu::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transform-origin: 100% 50%;
          transform-origin: 100% 50%;
  left: auto;
  right: 14%; }

/*カーソル*/
#cursor {
  pointer-events: none;
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50px;
  border: 1px solid #333;
  text-align: center;
  line-height: 30px;
  z-index: 2;
  background: none;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  opacity: 0; }

#load {
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50px;
  text-align: center;
  line-height: 30px;
  z-index: 2;
  pointer-events: none;
  background: none;
  opacity: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  -webkit-transform: translate(-23px, -23px);
          transform: translate(-23px, -23px); }

#cursor.active {
  -webkit-transform: scale(1.8) !important;
          transform: scale(1.8) !important; }

.sk-chase {
  width: 108px;
  height: 108px;
  position: relative;
  -webkit-animation: sk-chase 2.5s infinite linear both;
          animation: sk-chase 2.5s infinite linear both; }

.sk-chase-dot {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-animation: sk-chase-dot 2.0s infinite ease-in-out both;
          animation: sk-chase-dot 2.0s infinite ease-in-out both; }

.sk-chase-dot:before {
  content: '';
  display: block;
  width: 25%;
  height: 25%;
  background-color: #fff;
  border-radius: 100%;
  -webkit-animation: sk-chase-dot-before 2.0s infinite ease-in-out both;
          animation: sk-chase-dot-before 2.0s infinite ease-in-out both; }

.sk-chase-dot:nth-child(1) {
  -webkit-animation-delay: -1.1s;
          animation-delay: -1.1s; }

.sk-chase-dot:nth-child(2) {
  -webkit-animation-delay: -1.0s;
          animation-delay: -1.0s; }

.sk-chase-dot:nth-child(3) {
  -webkit-animation-delay: -0.9s;
          animation-delay: -0.9s; }

.sk-chase-dot:nth-child(4) {
  -webkit-animation-delay: -0.8s;
          animation-delay: -0.8s; }

.sk-chase-dot:nth-child(5) {
  -webkit-animation-delay: -0.7s;
          animation-delay: -0.7s; }

.sk-chase-dot:nth-child(6) {
  -webkit-animation-delay: -0.6s;
          animation-delay: -0.6s; }

.sk-chase-dot:nth-child(1):before {
  -webkit-animation-delay: -1.1s;
          animation-delay: -1.1s; }

.sk-chase-dot:nth-child(2):before {
  -webkit-animation-delay: -1.0s;
          animation-delay: -1.0s; }

.sk-chase-dot:nth-child(3):before {
  -webkit-animation-delay: -0.9s;
          animation-delay: -0.9s; }

.sk-chase-dot:nth-child(4):before {
  -webkit-animation-delay: -0.8s;
          animation-delay: -0.8s; }

.sk-chase-dot:nth-child(5):before {
  -webkit-animation-delay: -0.7s;
          animation-delay: -0.7s; }

.sk-chase-dot:nth-child(6):before {
  -webkit-animation-delay: -0.6s;
          animation-delay: -0.6s; }

@-webkit-keyframes sk-chase {
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); } }

@keyframes sk-chase {
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); } }
@-webkit-keyframes sk-chase-dot {
  80%, 100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); } }
@keyframes sk-chase-dot {
  80%, 100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); } }
@-webkit-keyframes sk-chase-dot-before {
  50% {
    -webkit-transform: scale(0.4);
            transform: scale(0.4); }
  100%, 0% {
    -webkit-transform: scale(1);
            transform: scale(1); } }
@keyframes sk-chase-dot-before {
  50% {
    -webkit-transform: scale(0.4);
            transform: scale(0.4); }
  100%, 0% {
    -webkit-transform: scale(1);
            transform: scale(1); } }
.marquee {
  position: relative;
  overflow: hidden;
  --offset: 20vw;
  --move-initial: calc(-25% + var(--offset));
  --move-final: calc(-50% + var(--offset));
  z-index: 998; }

.marquee__inner {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-animation: marquee 10s linear infinite;
          animation: marquee 10s linear infinite; }

.marquee span {
  font-size: 10vw;
  padding: 0 3vw;
  font-size: 50vh;
  color: #fff; }

@-webkit-keyframes marquee {
  0% {
    -webkit-transform: translate3d(var(--move-initial), 0, 0);
            transform: translate3d(var(--move-initial), 0, 0); }
  100% {
    -webkit-transform: translate3d(var(--move-final), 0, 0);
            transform: translate3d(var(--move-final), 0, 0); } }

@keyframes marquee {
  0% {
    -webkit-transform: translate3d(var(--move-initial), 0, 0);
            transform: translate3d(var(--move-initial), 0, 0); }
  100% {
    -webkit-transform: translate3d(var(--move-final), 0, 0);
            transform: translate3d(var(--move-final), 0, 0); } }
.ripples {
  display: block; }

main::before, #loading::before {
  -webkit-animation: grain 8s steps(10) infinite;
          animation: grain 8s steps(10) infinite;
  background-image: url(../img/noise.png);
  content: '';
  height: 300%;
  left: -50%;
  opacity: 0.6;
  position: fixed;
  top: -100%;
  width: 300%; }

@-webkit-keyframes grain {
  0%, 100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  10% {
    -webkit-transform: translate(-5%, -10%);
            transform: translate(-5%, -10%); }
  20% {
    -webkit-transform: translate(-15%, 5%);
            transform: translate(-15%, 5%); }
  30% {
    -webkit-transform: translate(7%, -25%);
            transform: translate(7%, -25%); }
  40% {
    -webkit-transform: translate(-5%, 25%);
            transform: translate(-5%, 25%); }
  50% {
    -webkit-transform: translate(-15%, 10%);
            transform: translate(-15%, 10%); }
  60% {
    -webkit-transform: translate(15%, 0%);
            transform: translate(15%, 0%); }
  70% {
    -webkit-transform: translate(0%, 15%);
            transform: translate(0%, 15%); }
  80% {
    -webkit-transform: translate(3%, 35%);
            transform: translate(3%, 35%); }
  90% {
    -webkit-transform: translate(-10%, 10%);
            transform: translate(-10%, 10%); } }

@keyframes grain {
  0%, 100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  10% {
    -webkit-transform: translate(-5%, -10%);
            transform: translate(-5%, -10%); }
  20% {
    -webkit-transform: translate(-15%, 5%);
            transform: translate(-15%, 5%); }
  30% {
    -webkit-transform: translate(7%, -25%);
            transform: translate(7%, -25%); }
  40% {
    -webkit-transform: translate(-5%, 25%);
            transform: translate(-5%, 25%); }
  50% {
    -webkit-transform: translate(-15%, 10%);
            transform: translate(-15%, 10%); }
  60% {
    -webkit-transform: translate(15%, 0%);
            transform: translate(15%, 0%); }
  70% {
    -webkit-transform: translate(0%, 15%);
            transform: translate(0%, 15%); }
  80% {
    -webkit-transform: translate(3%, 35%);
            transform: translate(3%, 35%); }
  90% {
    -webkit-transform: translate(-10%, 10%);
            transform: translate(-10%, 10%); } }
/*----------------- contents -----------------*/
/*-------------------------------------------------
 top
-------------------------------------------------*/
#top {
  background: url(../img/top_bg.jpg) no-repeat 50% 50%;
  color: #fff;
  height: 100vh;
  position: relative;
  overflow: hidden; }
  #top #topAction {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 9999; }
  #top .border {
    border: 5vw #fff solid;
    position: absolute;
    top: 0;
    left: 0;
    width: 90vw;
    height: 100%;
    -webkit-box-shadow: 10px 10px 10px 10px rgba(0, 0, 0, 0.5);
            box-shadow: 10px 10px 10px 10px rgba(0, 0, 0, 0.5); }
  #top article {
    padding: 255px; }
    #top article .title {
      font-size: 23vw;
      -webkit-transform: rotate(25deg);
              transform: rotate(25deg);
      width: 3000px;
      margin-left: -24vw;
      line-height: 2em;
      -webkit-transition: 0.2s;
      transition: 0.2s; }
    #top article .text {
      font-size: 3vw;
      -webkit-transform: rotate(25deg) translate(-20vw, -20vw);
              transform: rotate(25deg) translate(-20vw, -20vw); }
    #top article #pixiview {
      position: absolute;
      z-index: 100;
      top: 0;
      left: 0;
      overflow-x: hidden; }

#work {
  padding: 20vh 0 50vh;
  width: 90%;
  max-width: 1500px;
  margin: 0 auto;
  position: relative;
  overflow: visible; }
  #work h2 {
    text-align: right;
    font-size: 72px;
    position: -webkit-sticky;
    position: sticky;
    top: 20vh; }
  #work ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end; }
    #work ul li {
      text-align: center;
      width: 100%;
      position: relative;
      margin-bottom: 10%; }
      #work ul li a {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 99; }
      #work ul li a:hover + dl dd {
        -webkit-text-stroke: 1px #333;
        color: #fff; }
      #work ul li a:hover + dl img {
        -webkit-transform: scale(1.03);
                transform: scale(1.03); }
      #work ul li dl dt {
        margin-bottom: 15px; }
        #work ul li dl dt img {
          -webkit-transition: 0.5s;
          transition: 0.5s; }
      #work ul li dl dd {
        font-size: 22px;
        line-height: 1em;
        -webkit-transition: 0.5s;
        transition: 0.5s; }
        #work ul li dl dd span {
          font-size: 12px;
          color: #777; }
    #work ul li:nth-child(1) {
      max-width: 1000px;
      width: 65%; }
    #work ul li:nth-child(2) {
      max-width: 350px;
      -webkit-transform: translateY(120px);
              transform: translateY(120px);
      width: 30%; }
    #work ul li:nth-child(3) {
      width: 100%;
      max-width: 1000px;
      margin-top: 50px; }
    #work ul li:nth-child(4) {
      max-width: 1000px;
      width: 65%; }
    #work ul li:nth-child(5) {
      max-width: 400px;
      -webkit-transform: translateY(-120px);
              transform: translateY(-120px);
      width: 30%; }
    #work ul li:nth-child(6) {
      width: 50%; }
    #work ul li:nth-child(7) {
      max-width: 1000px;
      width: 65%; }
    #work ul li:nth-child(8) {
      max-width: 300px;
      width: 30%;
      -webkit-transform: translateY(120px);
              transform: translateY(120px); }

#btn article {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 50vh 0;
  font-size: clamp(18px, 12.5vw, 140px);
  line-height: 1em; }
  #btn article a:hover {
    -webkit-text-stroke: 2px #333;
    color: #fff; }
  #btn article span {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
    display: inline-block;
    -webkit-animation: fuwa 2s infinite linear alternate;
    animation: fuwa 2s infinite linear alternate; }

@-webkit-keyframes fuwa {
  0% {
    -webkit-transform: translate(0, 0), rotate(90deg); }
  50% {
    -webkit-transform: translate(5px, 5px), rotate(90deg);
    margin-bottom: -5px; }
  100% {
    -webkit-transform: translate(0, 0), rotate(90deg); } }
#about article {
  width: 90%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 50vh 0 0; }
#about .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; }
  #about .box .boxL {
    width: 50%;
    text-align: center; }
    #about .box .boxL h2 {
      font-size: 72px; }
    #about .box .boxL h3 {
      font-size: 24px; }
      #about .box .boxL h3 a img {
        height: 30px;
        margin-left: 10px; }
  #about .box .boxR {
    width: 40%;
    position: relative;
    z-index: 2; }
    #about .box .boxR .photo {
      position: relative;
      z-index: 2; }
      #about .box .boxR .photo .on {
        position: relative;
        z-index: 2; }
      #about .box .boxR .photo .bg {
        display: block;
        width: 700px;
        position: absolute;
        bottom: -110px;
        right: -110px;
        z-index: 1; }
#about .summary {
  line-height: 1.5em;
  text-align: left;
  padding: 0;
  margin: 30px auto 0;
  font-family: 'M PLUS 1p', "ヒラギノ角ゴシック", Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", "Meiryo", sans-serif;
  font-weight: 400;
  max-width: 600px;
  color: #777; }
#about .skill {
  max-width: 600px;
  margin-top: 30px; }
  #about .skill h3 {
    font-size: 16px;
    text-align: center; }
  #about .skill ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 15px; }
    #about .skill ul li {
      width: 9%;
      margin-left: 20px;
      margin-bottom: 10px; }
    #about .skill ul li:nth-child(1) {
      width: 40px;
      margin-left: 0; }
    #about .skill ul li:nth-child(2) {
      width: 40px; }
    #about .skill ul li:nth-child(3) {
      width: 40px; }
    #about .skill ul li:nth-child(4) {
      width: 50px; }
    #about .skill ul li:nth-child(5) {
      width: 40px; }
    #about .skill ul li:nth-child(6) {
      width: 40px; }
    #about .skill ul li:nth-child(7) {
      width: 30px; }
    #about .skill ul li:nth-child(8) {
      width: 40px; }
    #about .skill ul li:nth-child(9) {
      width: 40px; }
    #about .skill ul li:nth-child(10) {
      width: 40px; }
    #about .skill ul li:nth-child(11) {
      width: 40px; }
    #about .skill ul li:nth-child(12) {
      width: 40px; }

#btn2 article {
  text-align: right;
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 100px 0;
  font-size: 36px; }

#contact {
  margin-top: 50px; }
  #contact article {
    text-align: center;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 25vh 0 20vh; }
    #contact article h2 {
      font-size: 10vw; }
    #contact article h3 {
      font-size: 3vw; }
    #contact article a {
      max-width: 1200px;
      width: 90%;
      margin: 100px auto;
      display: block;
      position: relative;
      display: inline-block;
      -webkit-transition: .5s;
      transition: .5s;
      padding-bottom: 10px; }
    #contact article a::after {
      position: absolute;
      bottom: 0;
      left: 0;
      content: '';
      width: 0;
      height: 2px;
      background-color: #333;
      -webkit-transition: .5s;
      transition: .5s; }
    #contact article a:hover::after {
      width: 100%; }
    #contact article .comment {
      font-size: 5vw; }
      #contact article .comment span {
        display: inline-block;
        -webkit-animation: buru 0.5s infinite linear alternate;
        animation: buru 0.5s infinite linear alternate; }

@-webkit-keyframes buru {
  0% {
    -webkit-transform: translate(0, 0) rotate(0); }
  39% {
    -webkit-transform: translate(0, 0) rotate(0); }
  40% {
    -webkit-transform: translate(0, 0) rotate(-3deg); }
  70% {
    -webkit-transform: translate(0, -1px) rotate(0deg); }
  100% {
    -webkit-transform: translate(0, 0) rotate(3deg); } }
@keyframes buru {
  0% {
    -webkit-transform: translate(0, 0) rotate(0);
            transform: translate(0, 0) rotate(0); }
  39% {
    -webkit-transform: translate(0, 0) rotate(0);
            transform: translate(0, 0) rotate(0); }
  40% {
    -webkit-transform: translate(0, 0) rotate(-5deg);
            transform: translate(0, 0) rotate(-5deg); }
  70% {
    -webkit-transform: translate(0, -2px) rotate(0deg);
            transform: translate(0, -2px) rotate(0deg); }
  100% {
    -webkit-transform: translate(0, 0) rotate(5deg);
            transform: translate(0, 0) rotate(5deg); } }
@media screen and (max-width: 640px) {
  html, body {
    font-size: 12px;
    line-height: 1.5;
    font-weight: 300;
    background-color: #ffffff;
    font-family: 'Righteous', cursive, 'M PLUS 1p', "ヒラギノ角ゴシック", Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", "Meiryo", sans-serif;
    color: #333;
    margin: 0;
    padding: 0; }

  .pc {
    display: none; }

  .sp {
    display: inherit; }

  img {
    max-width: 100%;
    height: auto; }

  /* modal */
  .modal {
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%; }

  .modal__bg {
    background: rgba(0, 0, 0, 0.8);
    height: 100vh;
    position: absolute;
    width: 100%; }

  .modal__content {
    left: 50%;
    padding: 40px;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    height: 90%; }

  .video, .images {
    height: auto;
    width: 100%; }

  .batsu {
    display: block;
    width: 50px;
    height: 50px;
    position: relative;
    margin-left: auto; }

  .batsu::before, .batsu::after {
    content: "";
    display: block;
    width: 100%;
    height: 6px;
    background: #fff;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transform-origin: 0% 50%;
            transform-origin: 0% 50%;
    position: absolute;
    top: calc(14% - 5px);
    left: 0%; }

  .batsu::after {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
    -webkit-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
    left: auto;
    right: 14%; }

  #cursor, #load {
    display: none; }

  /*-------------------------------------------------
   top
  -------------------------------------------------*/
  #top {
    background: url(../img/top_bg.jpg) no-repeat 50% 50%;
    color: #fff;
    height: 100vh;
    position: relative;
    overflow: hidden; }
    #top #topAction {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 9999; }
    #top .border {
      border: 5vw #fff solid;
      position: absolute;
      top: 0;
      left: 0;
      width: 90vw;
      height: 100%;
      -webkit-box-shadow: 10px 10px 10px 10px rgba(0, 0, 0, 0.5);
              box-shadow: 10px 10px 10px 10px rgba(0, 0, 0, 0.5); }
    #top article {
      padding: 255px;
      overflow-x: hidden; }
      #top article .title {
        font-size: 18vw;
        -webkit-transform: rotate(90deg);
                transform: rotate(90deg);
        width: 900px;
        margin-left: -95vw;
        margin-top: -20vw;
        line-height: 5em; }
      #top article .text {
        font-size: 5vw;
        -webkit-transform: rotate(90deg) translate(-50vw, 100vw);
                transform: rotate(90deg) translate(-50vw, 100vw);
        width: 400px; }
      #top article #pixiview {
        position: absolute;
        z-index: 100;
        top: 0;
        left: 0;
        overflow-x: hidden; }

  #work {
    padding: 20vh 0 50vh;
    width: 90%;
    max-width: 1500px;
    margin: 0 auto;
    position: relative;
    overflow: visible; }
    #work h2 {
      text-align: right;
      font-size: 60px;
      position: -webkit-sticky;
      position: sticky;
      top: 20vh; }
    #work ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-pack: distribute;
          justify-content: space-around;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-align: end;
          -ms-flex-align: end;
              align-items: flex-end; }
      #work ul li {
        text-align: center;
        width: 100%;
        position: relative;
        margin-bottom: 10%; }
        #work ul li a {
          display: block;
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          z-index: 99; }
        #work ul li a:hover + dl dd {
          -webkit-text-stroke: 1px #333;
          color: #fff; }
        #work ul li a:hover + dl img {
          -webkit-transform: scale(1.03);
                  transform: scale(1.03); }
        #work ul li dl dt {
          margin-bottom: 15px; }
          #work ul li dl dt img {
            -webkit-transition: 0.5s;
            transition: 0.5s; }
        #work ul li dl dd {
          font-size: 22px;
          line-height: 1em;
          -webkit-transition: 0.5s;
          transition: 0.5s; }
          #work ul li dl dd span {
            font-size: 12px;
            color: #777; }
      #work ul li:nth-child(1) {
        max-width: 1000px;
        width: 70%; }
      #work ul li:nth-child(2) {
        max-width: 350px;
        -webkit-transform: translateY(0);
                transform: translateY(0);
        width: 70%; }
      #work ul li:nth-child(3) {
        width: 70%;
        max-width: 1000px;
        margin-top: 0px; }
      #work ul li:nth-child(4) {
        max-width: 1000px;
        width: 70%; }
      #work ul li:nth-child(5) {
        max-width: 400px;
        -webkit-transform: translateY(0);
                transform: translateY(0);
        width: 70%; }
      #work ul li:nth-child(6) {
        width: 70%; }
      #work ul li:nth-child(7) {
        max-width: 1000px;
        width: 70%; }
      #work ul li:nth-child(8) {
        max-width: 300px;
        width: 70%;
        -webkit-transform: translateY(0);
                transform: translateY(0); }
      #work ul li:nth-child(9) {
        max-width: 300px;
        width: 70%;
        -webkit-transform: translateY(0);
                transform: translateY(0); }

  #btn article {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 50vh 0;
    font-size: clamp(18px, 12.5vw, 140px);
    line-height: 1em; }
    #btn article a:hover {
      -webkit-text-stroke: 2px #333;
      color: #fff; }
    #btn article span {
      -webkit-transform: rotate(90deg);
              transform: rotate(90deg);
      display: inline-block;
      -webkit-animation: fuwa 2s infinite linear alternate;
      animation: fuwa 2s infinite linear alternate; }

  @-webkit-keyframes fuwa {
    0% {
      -webkit-transform: translate(0, 0), rotate(90deg); }
    50% {
      -webkit-transform: translate(5px, 5px), rotate(90deg);
      margin-bottom: -5px; }
    100% {
      -webkit-transform: translate(0, 0), rotate(90deg); } }
  #about {
    overflow-x: hidden; }
    #about article {
      width: 90%;
      max-width: 1000px;
      margin: 0 auto;
      padding: 50vh 0 0; }
    #about .box {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
      #about .box .boxL {
        width: 65%;
        text-align: center; }
        #about .box .boxL h2 {
          font-size: 72px; }
        #about .box .boxL h3 {
          font-size: 24px; }
          #about .box .boxL h3 a img {
            height: 25px; }
      #about .box .boxR {
        width: 30%;
        position: relative; }
        #about .box .boxR .photo {
          position: relative;
          z-index: 2;
          -webkit-transform: rotate(5deg);
                  transform: rotate(5deg); }
          #about .box .boxR .photo .on {
            position: relative;
            z-index: 2;
            margin-top: 10vh; }
          #about .box .boxR .photo .bg {
            display: block;
            width: 700px;
            position: absolute;
            bottom: -60px;
            right: -50px;
            z-index: 1; }
    #about .summary {
      line-height: 1.5em;
      text-align: left;
      padding: 0;
      margin: 30px auto 0;
      font-family: 'M PLUS 1p', "ヒラギノ角ゴシック", Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", "Meiryo", sans-serif;
      font-weight: 400;
      max-width: 600px;
      font-size: 10px;
      color: #777; }
    #about .skill.sp {
      display: block; }
    #about .skill {
      max-width: 600px;
      margin-top: 30px;
      width: 100%; }
      #about .skill h4 {
        font-size: 16px;
        text-align: center; }
      #about .skill ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        margin-top: 15px; }
        #about .skill ul li {
          width: 10%;
          margin-left: 10px;
          margin-bottom: 5px; }
        #about .skill ul li:nth-child(1) {
          width: 20px;
          margin-left: 0; }
        #about .skill ul li:nth-child(2) {
          width: 20px; }
        #about .skill ul li:nth-child(3) {
          width: 20px; }
        #about .skill ul li:nth-child(4) {
          width: 25px; }
        #about .skill ul li:nth-child(5) {
          width: 20px; }
        #about .skill ul li:nth-child(6) {
          width: 20px; }
        #about .skill ul li:nth-child(7) {
          width: 15px; }
        #about .skill ul li:nth-child(8) {
          width: 20px; }
        #about .skill ul li:nth-child(9) {
          width: 20px; }
        #about .skill ul li:nth-child(10) {
          width: 20px; }
        #about .skill ul li:nth-child(11) {
          width: 20px; }
        #about .skill ul li:nth-child(12) {
          width: 20px; }

  #btn2 article {
    text-align: right;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 100px 0;
    font-size: 36px; }

  #contact {
    background: #fff;
    margin-top: 50px; }
    #contact article {
      text-align: center;
      width: 90%;
      max-width: 1200px;
      margin: 0 auto;
      padding: 25vh 0 20vh; }
      #contact article h2 {
        font-size: 10vw; }
      #contact article h3 {
        font-size: 3vw; }
      #contact article a {
        max-width: 1200px;
        width: 90%;
        margin: 100px auto;
        display: block;
        position: relative;
        display: inline-block;
        -webkit-transition: .5s;
        transition: .5s;
        padding-bottom: 10px; }
      #contact article a::after {
        position: absolute;
        bottom: 0;
        left: 0;
        content: '';
        width: 0;
        height: 2px;
        background-color: #333;
        -webkit-transition: .5s;
        transition: .5s; }
      #contact article a:hover::after {
        width: 100%; }
      #contact article .comment {
        font-size: 5vw; }
        #contact article .comment span {
          display: inline-block;
          -webkit-animation: buru 0.5s infinite linear alternate;
          animation: buru 0.5s infinite linear alternate; }

  @-webkit-keyframes buru {
    0% {
      -webkit-transform: translate(0, 0) rotate(0); }
    39% {
      -webkit-transform: translate(0, 0) rotate(0); }
    40% {
      -webkit-transform: translate(0, 0) rotate(-3deg); }
    70% {
      -webkit-transform: translate(0, -1px) rotate(0deg); }
    100% {
      -webkit-transform: translate(0, 0) rotate(3deg); } }
  @keyframes buru {
    0% {
      -webkit-transform: translate(0, 0) rotate(0);
              transform: translate(0, 0) rotate(0); }
    39% {
      -webkit-transform: translate(0, 0) rotate(0);
              transform: translate(0, 0) rotate(0); }
    40% {
      -webkit-transform: translate(0, 0) rotate(-5deg);
              transform: translate(0, 0) rotate(-5deg); }
    70% {
      -webkit-transform: translate(0, -2px) rotate(0deg);
              transform: translate(0, -2px) rotate(0deg); }
    100% {
      -webkit-transform: translate(0, 0) rotate(5deg);
              transform: translate(0, 0) rotate(5deg); } } }
/*# sourceMappingURL=style.css.map */