* {
  padding: 0vw;
  margin: 0vw;
}

body {
  background-color: #221202;
}

h1, h2, h3, h4, h5, h6, p, li, a {
  font-family: dnp-shuei-shogomincho-std, serif;
  font-weight: 700;
  font-style: normal;
  color: #fff9e6;
}

a {
  text-decoration: none;
}

* {
  padding: 0vw;
  margin: 0vw;
}

body {
  background-color: #221202;
}

h1, h2, h3, h4, h5, h6, p, li, a {
  font-family: dnp-shuei-shogomincho-std, serif;
  font-weight: 700;
  font-style: normal;
  color: #fff9e6;
}

a {
  text-decoration: none;
}

@media screen and (min-width: 960px) {
  header {
    width: 100vw;
    height: 100vh;
    position: relative;
    overflow: hidden;
    margin-bottom: 25vh;
    background-image: url(/2021/background_desktop.jpg);
    background-size: cover;
    transition: 2s;
  }
  header h1 {
    font-size: 2.9282576867vw;
    line-height: 100%;
  }
  header h2 {
    font-size: 1.6105417277vw;
    line-height: 2.1229868228vw;
  }
  header h3 {
    font-size: 1.2445095168vw;
    line-height: 100%;
    margin-bottom: 0.7vh;
  }
  header p {
    font-size: 1.6105417277vw;
    line-height: 2.1229868228vw;
  }
  header span {
    font-size: 1.2445095168vw;
  }

  #date, #circle {
    position: absolute;
  }

  #title {
    position: absolute;
    top: 9.765625vh;
    left: 5.4904831625vw;
  }
  #title h1 {
    font-size: 2.9282576867vw;
    line-height: 100%;
  }
  #title h3 {
    font-size: 1.6105417277vw;
    line-height: 100%;
    margin-bottom: 1.4322916667vh;
  }

  #date {
    top: 79.4270833333vh;
    left: 5.4904831625vw;
  }

  #date::after {
    width: 0.05vw;
    height: 7.1614583333vh;
    margin-top: 0.6510416667vh;
    content: "";
    position: absolute;
    bottom: -10.6770833333vh;
    left: 50%;
    background-color: #fff9e6;
    animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;
  }
  @keyframes sdl {
    0% {
      transform: scale(1, 0);
      transform-origin: 0 0;
    }
    50% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
    50.1% {
      transform: scale(1, 1);
      transform-origin: 0 100%;
    }
    100% {
      transform: scale(1, 0);
      transform-origin: 0 100%;
    }
  }

  #circle {
    width: 29.2825768668vw;
    height: 29.2825768668vw;
    border-radius: 50%;
    background-color: #fff9e6;
    top: 19.0104166667vh;
    left: 47.2181551977vw;
  }

  nav {
    display: none;
  }

  aside {
    width: 13.5431918009vw;
    height: 100vh;
    overflow: hidden;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 99;
    background-color: #221202;
    box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.64);
  }
  aside li {
    width: 100%;
    position: absolute;
    top: 24.7395833333vh;
    left: 1.4641288433vw;
    list-style: none;
  }
  aside ul {
    font-size: 1.2811127379vw;
    line-height: 105%;
    margin-bottom: 3.90625vh;
    left: 15%;
  }
  aside ul::after {
    width: 100%;
    height: 0.3660322108vh;
    content: "";
    display: block;
    position: relative;
    left: -4%;
    z-index: -1;
    transition: 0.2s ease-out;
    animation: sdh 1s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }
  aside ul:hover::after {
    left: -10%;
  }
  aside ul.green::after {
    background-color: #729930;
  }
  aside ul.pink::after {
    background-color: #c08096;
  }
  aside ul.orange::after {
    background-color: #bd481f;
  }
  aside .underconstruction {
    background-color: #221202;
    opacity: 0.3;
  }

  #logo {
    width: 5.1244509517vw;
    height: 5.1244509517vw;
    position: relative;
    top: 7.8125vh;
    left: 0;
    right: 0;
    margin: auto;
    border-radius: 50%;
    background-color: #fff9e6;
  }
  #logo img {
    width: 4.9048316252vw;
    height: 4.9048316252vw;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }

  main {
    overflow: hidden;
  }

  #main, footer {
    width: 75.4026354319vw;
    position: relative;
    left: 5.4904831625vw;
  }

  #main {
    overflow: visible;
  }

  main section {
    width: 100%;
    height: 80vh;
    position: relative;
  }
  main section h1 {
    font-size: 2.8550512445vw;
    line-height: 125%;
  }
  main section h1::after {
    width: 75.4026354319vw;
    height: 0.5490483163vw;
    content: "";
    display: block;
    position: relative;
    left: -1.0980966325vw;
  }
  main section h1.active::after {
    animation: sdh 1.5s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }
  main section p {
    font-size: 0.9516837482vw;
    line-height: 1.5373352855vw;
  }
  main section .disc {
    width: 24.8901903367vw;
    position: absolute;
    top: 13.0208333333vh;
  }
  main section .circle {
    width: 29.2825768668vw;
    height: 29.2825768668vw;
    background-color: #3c2105;
    border-radius: 50%;
    position: absolute;
    top: 0;
    z-index: -99;
  }
  main section .c-left {
    left: 0;
  }
  main section .c-right {
    right: 0;
  }
  main section .rectangle {
    width: 50%;
    height: 2.196193265vw;
    background-color: #221202;
    position: absolute;
    top: 32.5520833333vh;
    left: 0;
    transition: 0.5s ease-out;
  }
  main section .rectangle h2 {
    font-size: 1.4641288433vw;
    line-height: 2.196193265vw;
    position: absolute;
    top: 0;
    left: 0;
  }
  main section .rectangle h2::after {
    width: 120%;
    height: 0.1464128843vw;
    content: "";
    display: block;
    position: relative;
    left: -5%;
    transition: 0.7s ease-out;
  }
  main section .rectangle h2:hover::after {
    width: 160%;
  }
  main section .rectangle h2.active::after {
    animation: sdh 1.5s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }
  main section h1.green::after {
    background-color: #729930;
  }
  main section h1.pink::after {
    background-color: #c08096;
  }
  main section h1.orange::after {
    background-color: #bd481f;
  }
  main section h2.green::after {
    background-color: #729930;
  }
  main section h2.pink::after {
    background-color: #c08096;
  }
  main section h2.orange::after {
    background-color: #bd481f;
  }
  main section .rectangle {
    background-color: transparent;
  }

  #video h1 {
    font-size: 6.6666666667vw;
  }

  #about h1 {
    font-size: 2.196193265vw;
  }

  footer {
    height: 19.53125vh;
    margin-top: 6.5104166667vh;
  }
  footer h1, footer p {
    font-size: 1.4641288433vw;
    line-height: 110%;
    margin-bottom: 1.8301610542vw;
  }
  footer h1::after {
    width: 30%;
    height: 0.1464128843vw;
    content: "";
    background-color: #bd481f;
    display: block;
    position: relative;
    left: -1%;
    transition: 0.7s ease-out;
  }
  footer h1:hover::after {
    width: 50%;
  }
  footer h1.active::after {
    animation: sdh 1s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }

  #copylight {
    margin: 6.6666666667vw 0;
  }
}
@media screen and (max-width: 960px) {
  header {
    width: 100vw;
    height: 100vh;
    position: relative;
    overflow: hidden;
    margin-bottom: 10vh;
    background-image: url(/2021/background.jpg);
    background-size: cover;
  }
  header h1 {
    font-size: 7.2vw;
    line-height: 100%;
  }
  header h2 {
    font-size: 4.5333333333vw;
    line-height: 7.7333333333vw;
  }
  header h3 {
    font-size: 3.4666666667vw;
    line-height: 100%;
    margin-bottom: 0.7vh;
  }
  header p {
    font-size: 4.5333333333vw;
    line-height: 5.8666666667vw;
  }
  header span {
    font-size: 3.4666666667vw;
  }

  #date, #circle {
    position: absolute;
  }

  #title {
    position: absolute;
    top: 9.6vw;
    left: 8vw;
  }
  #title h1 {
    font-size: 7.2vw;
    line-height: 100%;
  }
  #title h3 {
    font-size: 3.4666666667vw;
    line-height: 100%;
    margin-bottom: 1.2vw;
  }

  #date {
    top: 80.35982009vh;
    left: 8vw;
  }

  #date::after {
    width: 0.25vw;
    height: 14.9333333333vw;
    margin-top: 1.3333333333vw;
    content: "";
    position: absolute;
    bottom: -16.2666666667vw;
    left: 50%;
    background-color: #fff9e6;
    animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;
  }
  @keyframes sdl {
    0% {
      transform: scale(1, 0);
      transform-origin: 0 0;
    }
    50% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
    50.1% {
      transform: scale(1, 1);
      transform-origin: 0 100%;
    }
    100% {
      transform: scale(1, 0);
      transform-origin: 0 100%;
    }
  }

  #circle {
    width: 106.6666666667vw;
    height: 106.6666666667vw;
    border-radius: 50%;
    background-color: #fff9e6;
    top: 11.844077961vh;
    left: 30.9333333333vw;
  }

  nav #title {
    position: absolute;
    top: 9.6vw;
    left: 8vw;
  }
  nav #title h1 {
    font-size: 7.2vw;
    line-height: 100%;
  }
  nav #title h3 {
    font-size: 3.4666666667vw;
    line-height: 100%;
    margin-bottom: 1.2vw;
  }
  nav li {
    position: absolute;
    top: 29.6vw;
    left: 8vw;
    list-style: none;
  }
  nav ul {
    font-size: 8vw;
    line-height: 75%;
    margin-bottom: 9vw;
  }
  nav ul::after {
    width: 89.04vw;
    height: 2.6666666667vw;
    content: "";
    display: block;
    position: relative;
    left: -2.52vw;
    z-index: -1;
  }
  nav ul:hover::after {
    animation: sdh 1s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }
  nav ul.green::after {
    background-color: #729930;
  }
  nav ul.pink::after {
    background-color: #c08096;
  }
  nav ul.orange::after {
    background-color: #bd481f;
  }
  nav input[type=checkbox] {
    display: none;
  }
  nav label {
    width: 18.6666666667vw;
    height: 18.6666666667vw;
    position: fixed;
    bottom: 9.3333333333vw;
    left: 72vw;
    border-radius: 50%;
    background-color: #fff9e6;
    cursor: pointer;
    box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.64);
    z-index: 99;
    transition: 0.7s ease-out;
  }
  nav label img {
    width: 17.8666666667vw;
    height: 17.8666666667vw;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }
  nav label div::before, nav label div::after {
    content: "";
    transition: 0.7s ease-out;
  }
  nav section {
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    background-color: #221202;
    position: fixed;
    top: 531vw;
    left: 0vw;
    z-index: 90;
    transition: 0.7s ease-out;
  }
  nav .underconstruction {
    height: 8vw;
    margin-bottom: 9vw;
    background-color: #221202;
    opacity: 0.5;
  }
  nav input[type=checkbox]:checked ~ section {
    top: 0;
  }
  nav input[type=checkbox]:checked ~ label {
    box-shadow: none;
  }
  nav input[type=checkbox]:checked ~ label img {
    opacity: 0;
  }
  nav input[type=checkbox]:checked ~ label div::before, nav input[type=checkbox]:checked ~ label div::after {
    background-color: #221202;
    width: 70%;
    height: 0.5vw;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    content: "";
  }
  nav input[type=checkbox]:checked ~ label div::before {
    transform: rotate(-45deg);
  }
  nav input[type=checkbox]:checked ~ label div::after {
    transform: rotate(45deg);
  }

  aside {
    display: none;
  }

  main {
    overflow: hidden;
  }

  #main, footer {
    width: 84vw;
    margin: 0 auto;
  }

  #main {
    overflow: visible;
  }

  main section {
    width: 100%;
    height: 80vh;
    position: relative;
  }
  main section h1 {
    font-size: 10.4vw;
    line-height: 75%;
    position: absolute;
    top: 19.7901049475vh;
  }
  main section h1::after {
    width: 89.04vw;
    height: 2.6666666667vw;
    content: "";
    display: block;
    position: relative;
    left: -2.52vw;
    z-index: -1;
  }
  main section h1.active::after {
    animation: sdh 1.5s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }
  main section p {
    font-size: 3.4666666667vw;
    line-height: 5.6vw;
  }
  main section .disc {
    width: 58.6666666667vw;
    margin-top: 8.8vw;
    position: relative;
    top: 53.3333333333vw;
    z-index: 1;
  }
  main section .circle {
    width: 106.6666666667vw;
    height: 106.6666666667vw;
    background-color: #3c2105;
    border-radius: 50%;
    position: absolute;
    top: 0;
    z-index: -99;
  }
  main section .c-left {
    left: -61.3333333333vw;
  }
  main section .c-right {
    right: -61.3333333333vw;
  }
  main section .rectangle {
    width: 66.6666666667vw;
    height: 33.3333333333vw;
    position: absolute;
    top: 71.7333333333vw;
    right: 0;
    transition: 0.5s ease-out;
  }
  main section .rectangle h2 {
    font-size: 4.2666666667vw;
    line-height: 6.4vw;
    position: absolute;
    bottom: 2.6666666667vw;
    right: 19.2vw;
    border-bottom: 0.5vw solid #fff9e6;
    transition: 0.5s ease-out;
  }
  main section .rectangle > div {
    width: 16vw;
    height: 6.4vw;
    position: absolute;
    bottom: 2.6666666667vw;
    right: 3.2vw;
    border-bottom: 0.5vw solid #fff9e6;
    transition: 0.5s ease-out;
  }
  main section .rectangle > div div {
    width: 5.3333333333vw;
    height: 0.5vw;
    position: absolute;
    bottom: 0.8vw;
    right: -0.2vw;
    background-color: #fff9e6;
    transform: rotate(30deg);
  }
  main section h1.green::after {
    background-color: #729930;
  }
  main section h1.pink::after {
    background-color: #c08096;
  }
  main section h1.orange::after {
    background-color: #bd481f;
  }
  main section .rectangle.green {
    background-color: #729930;
  }
  main section .rectangle.pink {
    background-color: #c08096;
  }
  main section .rectangle.orange {
    background-color: #bd481f;
  }
  main section .rectangle:hover h2 {
    right: 11.2vw;
  }
  main section .rectangle:hover > div {
    width: 8vw;
  }

  #video h1 {
    font-size: 6.6666666667vw;
  }

  #about h1 {
    font-size: 8vw;
  }

  footer {
    height: 40vw;
    margin-top: 13.3333333333vw;
  }
  footer h1, footer p {
    font-size: 2.6666666667vw;
    line-height: 75%;
    margin-bottom: 4vw;
  }
  footer h1::after {
    width: 50%;
    height: 0.6666666667vw;
    content: "";
    background-color: #bd481f;
    display: block;
    position: relative;
    z-index: -1;
    left: -2%;
    transition: 0.7s ease-out;
  }
  footer h1:hover::after {
    width: 75%;
  }
  footer h1.active::after {
    animation: sdh 1.5s cubic-bezier(1, 0, 0, 1);
  }
  @keyframes sdh {
    0% {
      transform: scale(0, 1);
      transform-origin: 0 0;
    }
    100% {
      transform: scale(1, 1);
      transform-origin: 0 0;
    }
  }

  #copylight {
    margin: 6.6666666667vw 0;
  }
}

/*# sourceMappingURL=stylesheet.css.map */
