@import url(sanitize.css);
@font-face {
  font-family: "KleeOne";
  src: url(font/KleeOne-Regular.ttf);
}

* {
  margin: 0;
  border: 0;
  padding: 0;
  color: #dcdcdc;
  font-family: "KleeOne";
}

.novel-text {
  font-size: 1vw;
  color: #dcdcdc;
  line-height: 2;
  opacity: 0.4;
}

@media screen and (max-width: 550px) {
  .novel-text {
    display: none;
  }
}

body {
  background-color: #000000;
  background-blend-mode: lighten;
  background-size: cover;
  margin-bottom: 2rem;
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media screen and (max-width: 900px) {
  .flex {
    display: inline-block;
  }
}

.logo {
  padding: 2vw 0 0 7vw;
  position: relative;
  z-index: 1;
  margin: 0;
  line-height: 1.1;
}

.logo .md-red {
  font-size: 3vw;
  color: #a82c2c;
  font-family: "New Tegomin", serif;
}

.logo .sm-white {
  font-size: 2vw;
  color: #dcdcdc;
}

.logo .lg-lightred {
  font-size: 4vw;
  color: #dd3b1b;
  font-family: "New Tegomin", serif;
}

.logo .lg-red {
  font-size: 4vw;
  color: #a82c2c;
  font-family: "New Tegomin", serif;
}

.logo .lg-white {
  font-size: 4vw;
  color: #dcdcdc;
  font-family: "New Tegomin", serif;
}

h3 {
  font-size: 3vw;
  color: #dd3b1b;
  text-align: center;
}

@media screen and (max-width: 550px) {
  h3 {
    font-size: 1.5rem;
  }
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

#Audio-Control {
  overflow: hidden;
  margin-left: 85vw;
}

@media screen and (max-width: 900px) {
  #Audio-Control {
    margin-left: 80vw;
  }
}

@media screen and (max-width: 550px) {
  #Audio-Control {
    margin-left: 60vw;
  }
}

#Audio-Control button {
  border: 1px solid #ccc;
  width: 40px;
  float: left;
  padding: 5px 0;
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
}

#Audio-Control button.on {
  border-left: none;
}

#Audio-Control button.off {
  border-right: none;
}

#Audio-Control button.active {
  background: #ccc;
  color: #000000;
}

#Audio-Control button:not(.active):hover {
  background: rgba(204, 204, 204, 0.3);
}

header .header-img {
  background-image: url(img/header.jpg);
  -webkit-filter: opacity(80%);
          filter: opacity(80%);
  background-size: cover;
  position: relative;
  padding-bottom: 4vw;
  z-index: -1;
}

@media screen and (max-width: 550px) {
  header .header-img {
    height: 250px;
  }
}

header .header-img::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 0.6);
}

header .header-img h2 {
  font-size: 4vw;
  margin: 14vw 0 0 0;
  text-align: center;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 550px) {
  header .header-img h2 {
    font-size: 6vw;
  }
}

header .header-img h2 span {
  font-size: 5vw;
  font-family: "New Tegomin", serif;
  color: #a82c2c;
}

@media screen and (max-width: 550px) {
  header .header-img h2 span {
    font-size: 7vw;
  }
}

header .header-img .novel-text {
  margin: 10vw 0 0 9vw;
  position: relative;
  z-index: 1;
}

.story {
  position: relative;
}

.story h3 {
  margin: 7vw 0 0 0;
}

@media screen and (max-width: 550px) {
  .story h3 {
    margin-top: 24vw;
  }
}

.story .story-text {
  font-size: 1.5vw;
  text-align: center;
  margin: 3.5vw 0 0 0;
  line-height: 1.6;
}

@media screen and (max-width: 550px) {
  .story .story-text {
    font-size: 1rem;
  }
}

.story .story-text span {
  font-size: 1.5vw;
  font-family: "New Tegomin", serif;
  color: #a82c2c;
}

@media screen and (max-width: 550px) {
  .story .story-text span {
    font-size: 1rem;
  }
}

.story img {
  position: absolute;
  -webkit-filter: opacity(20%);
          filter: opacity(20%);
  z-index: -1;
  top: 3.5vw;
  left: 18vw;
  width: 42%;
  height: 60%;
}

.story .ticket-link {
  margin: 4vw 0 0 0;
  text-align: center;
  z-index: 50;
}

.story .ticket-link a {
  display: inline-block;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(218, 16, 16, 0.5)), to(rgba(218, 16, 16, 0.5))), url(img/link.jpg);
  background: linear-gradient(rgba(218, 16, 16, 0.5), rgba(218, 16, 16, 0.5)), url(img/link.jpg);
  background-size: cover;
  font-size: 1.5vw;
  text-decoration: none;
  padding: 1vw 1.5vw;
  color: #000000;
  font-weight: bold;
}

@media screen and (max-width: 550px) {
  .story .ticket-link a {
    font-size: 1rem;
    padding: 0.5rem 0.75rem;
  }
}

.story .ticket-link a:hover {
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(146, 6, 6, 0.178)), to(rgba(146, 6, 6, 0.466))), url(img/link.jpg);
  background: linear-gradient(rgba(146, 6, 6, 0.178), rgba(146, 6, 6, 0.466)), url(img/link.jpg);
  color: #dcdcdc;
}

.story .novel-text {
  text-align: right;
  z-index: 2;
  margin: 0 2rem 0 0;
}

.mission {
  position: relative;
}

.mission h3 {
  margin: 0 0 0 0;
}

@media screen and (max-width: 550px) {
  .mission h3 {
    margin-top: 24vw;
  }
}

.mission .mission-text {
  font-size: 1.5vw;
  text-align: center;
  margin: 4vw 0 0 0;
  line-height: 1.6;
}

@media screen and (max-width: 550px) {
  .mission .mission-text {
    font-size: 1rem;
  }
}

.mission .mission-text p:last-child {
  margin-top: 3rem;
}

@media screen and (max-width: 900px) {
  .mission .mission-text p:last-child {
    margin-top: 2vw;
  }
}

.mission .mission-text span {
  font-size: 1.5vw;
  font-family: "New Tegomin", serif;
  color: #a82c2c;
}

@media screen and (max-width: 550px) {
  .mission .mission-text span {
    font-size: 1rem;
  }
}

.mission img {
  position: absolute;
  -webkit-filter: opacity(70%);
          filter: opacity(70%);
  z-index: -1;
  top: 3vw;
  left: calc((100% - 42%) / 2);
  width: 42%;
  height: 50%;
}

.mission .novel-text {
  margin: -2rem 0 0 2rem;
}

.mission .novel-text .right {
  text-align: right;
  margin: 0 2rem 0 0;
}

.ticket {
  position: relative;
  margin-top: -13vw;
}

@media screen and (max-width: 550px) {
  .ticket {
    margin-top: 24vw;
  }
}

.ticket h3 {
  margin: 0 0 0 0;
}

.ticket table {
  display: inline-block;
  margin: 4.5vw 15vw 0 15vw;
}

@media screen and (max-width: 900px) {
  .ticket table {
    margin: 4.5vw 7vw 0 7vw;
    text-align: center;
  }
}

.ticket table tr {
  display: inline-block;
}

.ticket table tr:nth-child(2) {
  margin: 0 12vw;
}

@media screen and (max-width: 900px) {
  .ticket table tr:nth-child(2) {
    margin: 0 3vw 0 3vw;
  }
}

.ticket table tr:last-child {
  margin: 0.5vw 7.5vw;
}

@media screen and (max-width: 900px) {
  .ticket table tr:last-child {
    margin: 0.5vw 0.5vw 0 0.5vw;
  }
}

.ticket table tr:last-child td {
  margin: 0.5vw 0 0 6vw;
}

@media screen and (max-width: 550px) {
  .ticket table tr:last-child td {
    margin: 0.5vw 0vw 0 1vw;
  }
}

.ticket table tr:last-child td:nth-child(2) {
  margin-left: 10vw;
}

@media screen and (max-width: 550px) {
  .ticket table tr:last-child td:nth-child(2) {
    margin-left: 2vw;
  }
}

.ticket table td {
  font-size: 1.5vw;
  text-align: right;
  display: inline-block;
  margin: 1.6vw 0 0 6vw;
}

@media screen and (max-width: 900px) {
  .ticket table td {
    margin: 1.6vw 0 0 3vw;
  }
}

@media screen and (max-width: 550px) {
  .ticket table td {
    font-size: 1rem;
  }
}

.ticket table th {
  display: inline-block;
  font-size: 2vw;
  color: #dd3b1b;
}

.ticket table th:first-child {
  margin: 0 13vw;
}

.ticket table th:nth-child(2) {
  margin: 0 7.5vw;
}

.ticket table:nth-child(2) td span {
  font-size: 1.2vw;
  margin-left: 3vw;
}

@media screen and (max-width: 550px) {
  .ticket table:nth-child(2) td span {
    font-size: 0.8rem;
  }
}

.ticket table:nth-child(2) td:nth-child(2) {
  margin-left: 14.5vw;
}

.ticket img {
  position: absolute;
  -webkit-filter: opacity(50%);
          filter: opacity(50%);
  z-index: -1;
  top: 0vw;
  left: calc((100% - 65%) / 2);
  width: 65%;
  height: 73%;
}

.ticket .ticket-link {
  margin: 2.5vw 0 0 0;
  text-align: center;
}

.ticket .ticket-link a {
  display: inline-block;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(218, 16, 16, 0.5)), to(rgba(218, 16, 16, 0.5))), url(img/link.jpg);
  background: linear-gradient(rgba(218, 16, 16, 0.5), rgba(218, 16, 16, 0.5)), url(img/link.jpg);
  background-size: cover;
  font-size: 1.5vw;
  text-decoration: none;
  padding: 1vw 2vw;
  color: #000000;
  font-weight: bold;
}

@media screen and (max-width: 550px) {
  .ticket .ticket-link a {
    font-size: 1rem;
  }
}

.ticket .ticket-link a:hover {
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(146, 6, 6, 0.178)), to(rgba(146, 6, 6, 0.466))), url(img/link.jpg);
  background: linear-gradient(rgba(146, 6, 6, 0.178), rgba(146, 6, 6, 0.466)), url(img/link.jpg);
  color: #dcdcdc;
}

.ticket .ticket-text {
  font-size: 1.2vw;
  text-align: center;
  margin: 1.5vw 0 0 0;
  line-height: 2;
}

@media screen and (max-width: 550px) {
  .ticket .ticket-text {
    font-size: 1rem;
  }
}

@media screen and (max-width: 900px) {
  .ticket .ticket-text p {
    margin-right: 1rem;
    margin-left: 1rem;
  }
}

.ticket .ticket-text p:last-child {
  margin-top: 3rem;
}

@media screen and (max-width: 900px) {
  .ticket .ticket-text p:last-child {
    margin-top: 2vw;
  }
}

.ticket .novel-text {
  margin: 2vw 0 0 2rem;
}

@media screen and (max-width: 550px) {
  .access {
    margin-top: 44vw;
  }
}

.access h3 {
  margin: -22vw 0 0 0;
}

.access .access-text {
  font-size: 1.5vw;
  text-align: center;
  margin: 4vw 0 0 0;
  line-height: 1.6;
}

@media screen and (max-width: 550px) {
  .access .access-text {
    font-size: 1rem;
  }
}

.access .access-text p {
  margin-top: 0.5vw;
}

.access .access-img {
  margin-top: 2vw;
}

@media screen and (max-width: 900px) {
  .access .access-img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    width: 100%;
    text-align: center;
    margin: 2rem auto 0 auto;
  }
}

.access .map iframe {
  width: 29vw;
  height: 25vw;
}

@media screen and (max-width: 900px) {
  .access .map iframe {
    width: 40vw;
  }
}

@media screen and (max-width: 550px) {
  .access .map iframe {
    width: 60vw;
  }
}

.access img {
  width: 35vw;
  -webkit-filter: opacity(55%);
          filter: opacity(55%);
}

@media screen and (max-width: 900px) {
  .access img {
    margin: 1rem auto 0 auto;
    width: 45vw;
  }
}

@media screen and (max-width: 550px) {
  .access img {
    width: 60vw;
  }
}

.access .novel-text {
  text-align: right;
  z-index: 2;
  margin: -8vw 2rem 0 0;
}

@media screen and (max-width: 550px) {
  .caution {
    margin-top: 24vw;
  }
}

.caution .novel-text p {
  text-align: left;
  z-index: 2;
  margin: 0rem 0 0 2rem;
}

.caution h3 {
  margin-top: 2vw;
}

.caution .caution-text {
  margin: 1vw auto 0 auto;
  font-size: 1.5vw;
  text-align: center;
  line-height: 1.8;
  background-image: url(img/fire.jpg);
  background-size: cover;
  background-color: rgba(0, 0, 0, 0.8);
  background-blend-mode: darken;
}

@media screen and (max-width: 900px) {
  .caution .caution-text {
    margin: 1vw 4vw 0 4vw;
  }
}

@media screen and (max-width: 550px) {
  .caution .caution-text {
    font-size: 1rem;
  }
}

.caution .caution-text p {
  margin: 1vw 0 0 0;
  padding: 6vw 0;
  display: inline-block;
  text-align: left;
}

.caution .caution-text p span {
  display: block;
  margin: 1vw 0 2vw 0;
}

.command {
  position: relative;
  background-color: rgba(170, 170, 170, 0);
}

@media screen and (max-width: 550px) {
  .command {
    margin-top: 24vw;
  }
}

.command .novel-text {
  text-align: left;
  line-height: 5;
  margin: -4vw 2rem 0 0;
}

.command img {
  width: 70vw;
  position: absolute;
  -webkit-filter: opacity(20%);
          filter: opacity(20%);
  z-index: -1;
  top: 12vw;
  left: calc((100% - 70%) / 2);
}

.command .background-black {
  display: none;
}

.command .command-text p {
  font-family: "New Tegomin", serif;
  font-size: 1.2vw;
}

@media screen and (max-width: 550px) {
  .command .command-text p {
    font-size: 1rem;
  }
}

.command .command-text p:nth-child(1) {
  margin: 1vw 0 0 20vw;
}

.command .command-text p:nth-child(2) {
  margin: 5vw 0 0 40vw;
}

.command .command-text p:nth-child(3) {
  margin: 10vw 0 0 70vw;
}

.command .command-text p:nth-child(4) {
  margin: 6vw 0 0 22vw;
}

.command .command-text p:nth-child(5) {
  margin: 7vw 0 0 30vw;
}

.command .command-text p:nth-child(6) {
  margin: 0 0 0 36vw;
}

@media screen and (max-width: 550px) {
  .command .command-text p:nth-child(6) {
    margin-left: 30vw;
  }
}

.command .command-text p span {
  font-family: "New Tegomin", serif;
  color: #a82c2c;
  font-size: 1.8vw;
}

@media screen and (max-width: 550px) {
  .command .command-text p span {
    font-size: 1.2rem;
  }
}

.command .command-text p .large {
  font-size: 3vw;
}

@media screen and (max-width: 550px) {
  .command .command-text p .large {
    font-size: 1.5rem;
  }
}

.command .command-text .change-message {
  font-family: "New Tegomin", serif;
  font-size: 1.5vw;
}

@media screen and (max-width: 550px) {
  .command .command-text .change-message {
    font-size: 1rem;
  }
}

.command .command-text .hidden {
  visibility: hidden;
}

.command input {
  background-color: #a82c2c;
  border: none;
  outline: none;
  width: 20%;
  height: 2rem;
  padding: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 1vw auto 0 auto;
}

@media screen and (max-width: 550px) {
  .command input {
    width: 40vw;
  }
}

@media screen and (max-width: 900px) {
  footer {
    width: 100%;
    text-align: center;
  }
}

footer .logo {
  padding: 0;
  margin-top: 10rem;
  text-align: center;
}

@media screen and (max-width: 550px) {
  footer .logo {
    margin-top: 20vw;
  }
}

footer .footer-text {
  margin: 6vw 4vw 0 0;
}

@media screen and (max-width: 900px) {
  footer .footer-text {
    font-size: 1.5vw;
    margin: 1rem auto 0 auto;
  }
}

@media screen and (max-width: 550px) {
  footer .footer-text {
    font-size: 1rem;
  }
}

footer .footer-text .bold {
  font-weight: bold;
  margin-top: 1vw;
}

@media screen and (max-width: 900px) {
  footer .footer-text .bold {
    margin-top: 1rem;
  }
}

footer .footer-link {
  margin: 6vw 0 0 4vw;
}

@media screen and (max-width: 900px) {
  footer .footer-link {
    margin: 1rem auto 0 auto;
    font-size: 1.5vw;
  }
}

@media screen and (max-width: 550px) {
  footer .footer-link {
    font-size: 1rem;
  }
}

footer .footer-link .tell-link {
  margin-top: 1vw;
}

footer .footer-link .tell-link a {
  display: inline-block;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(218, 16, 16, 0.5)), to(rgba(218, 16, 16, 0.5))), url(img/link.jpg);
  background: linear-gradient(rgba(218, 16, 16, 0.5), rgba(218, 16, 16, 0.5)), url(img/link.jpg);
  background-size: cover;
  font-size: 1.57vw;
  text-decoration: none;
  padding: 1vw 3.5vw;
  color: #000000;
  font-weight: bold;
}

footer .footer-link .tell-link a:hover {
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(146, 6, 6, 0.178)), to(rgba(146, 6, 6, 0.466))), url(img/link.jpg);
  background: linear-gradient(rgba(146, 6, 6, 0.178), rgba(146, 6, 6, 0.466)), url(img/link.jpg);
  color: #dcdcdc;
}

@media screen and (max-width: 900px) {
  footer .footer-link .tell-link a {
    padding: 1vw 4.75vw;
    min-width: 106px;
  }
}

@media screen and (max-width: 550px) {
  footer .footer-link .tell-link a {
    font-size: 1rem;
    padding: 1vw 8vw;
  }
}

footer .footer-link .ticket {
  margin: 0;
  padding: 0;
}

footer .footer-link .ticket p {
  margin-top: 1vw;
}

footer .footer-link .ticket a {
  display: inline;
  margin: 0;
}

@media screen and (max-width: 900px) {
  footer .footer-link .ticket a {
    margin: 1rem 0 0 0;
    padding: 1vw 3vw;
  }
}

footer .copy-write {
  text-align: center;
  margin-top: 10vw;
}

footer .copy-write p {
  font-family: "New Tegomin", serif;
  font-size: 1vw;
}
/*# sourceMappingURL=index.css.map */