*, ::before, ::after {
  box-sizing: border-box;
  background-repeat: no-repeat
}

::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit
}

:where(:root) {
  cursor: default;
  line-height: 1.5;
  overflow-wrap: break-word;
  tab-size: 4;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-text-size-adjust: 100%
}

:where(body) {
  margin: 0
}

:where(h1) {
  font-size: 2em;
  margin: .67em 0
}

:where(dl, ol, ul) :where(dl, ol, ul) {
  margin: 0
}

:where(hr) {
  color: inherit;
  height: 0
}

:where(nav) :where(ol, ul) {
  list-style-type: none;
  padding: 0
}

:where(nav li)::before {
  content: "​";
  float: left
}

:where(pre) {
  font-family: monospace, monospace;
  font-size: 1em;
  overflow: auto
}

:where(abbr[title]) {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

:where(b, strong) {
  font-weight: bolder
}

:where(code, kbd, samp) {
  font-family: monospace, monospace;
  font-size: 1em
}

:where(small) {
  font-size: 80%
}

:where(audio, canvas, iframe, img, svg, video) {
  vertical-align: middle
}

:where(iframe) {
  border-style: none
}

:where(svg:not([fill])) {
  fill: currentColor
}

:where(table) {
  border-collapse: collapse;
  border-color: inherit;
  text-indent: 0
}

:where(button, input, select) {
  margin: 0
}

:where(button, [type=button i], [type=reset i], [type=submit i]) {
  -webkit-appearance: button
}

:where(fieldset) {
  border: 1px solid #a0a0a0
}

:where(progress) {
  vertical-align: baseline
}

:where(textarea) {
  margin: 0;
  resize: vertical
}

:where([type=search i]) {
  -webkit-appearance: textfield;
  outline-offset: -2px
}

::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
  height: auto
}

::-webkit-input-placeholder {
  color: inherit;
  opacity: .54
}

::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

:where(dialog) {
  background-color: #fff;
  border: solid;
  color: #000;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: fit-content
}

:where(dialog:not([open])) {
  display: none
}

:where(details>summary:first-of-type) {
  display: list-item
}

:where([aria-busy=true i]) {
  cursor: progress
}

:where([aria-controls]) {
  cursor: pointer
}

:where([aria-disabled=true i], [disabled]) {
  cursor: not-allowed
}

:where([aria-hidden=false i][hidden]) {
  display: initial
}

:where([aria-hidden=false i][hidden]:not(:focus)) {
  clip: rect(0, 0, 0, 0);
  position: absolute
}

.font-poiret, .footer, .event-content .event-title-number, .menu-title .is-large {
  font-family: "Poiret One", sans-serif;
  font-weight: 400
}

.font-notosans, body, .font-notosans\:bold {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal
}

.font-notosans\:bold {
  font-weight: 700
}

body:not(.is-touch) .menu-button:hover {
  opacity: .7;
  transition: opacity .2s ease-out
}

@keyframes slideAnimeLink {
  from {
    opacity: 0;
    transform: translateY(20px)
  }
  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.delay-anime1 {
  animation-delay: 0.23s
}

.delay-anime2 {
  animation-delay: 0.26s
}

.delay-anime3 {
  animation-delay: 0.29s
}

.delay-anime4 {
  animation-delay: 0.32s
}

.delay-anime5 {
  animation-delay: 0.35s
}

.delay-anime6 {
  animation-delay: 0.38s
}

.delay-anime7 {
  animation-delay: 0.41s
}

.delay-anime8 {
  animation-delay: 0.44s
}

.delay-anime9 {
  animation-delay: 0.47s
}

.delay-anime10 {
  animation-delay: 0.5s
}

.delay-anime11 {
  animation-delay: 0.53s
}

.delay-anime12 {
  animation-delay: 0.56s
}

.delay-anime13 {
  animation-delay: 0.59s
}

.delay-anime14 {
  animation-delay: 0.62s
}

.delay-anime15 {
  animation-delay: 0.65s
}

.header {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  width: min(540px, 100%);
  height: min(25vw, 135px);
  box-sizing: border-box;
  overflow: hidden;
  pointer-events: none;
  z-index: 5
}

.mainvisual {
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
  position: relative;
  background-size: 100% auto;
  padding-top: min(68.0555555556vw, 367.5px)
  padding-bottom: 50px;
}

.is-offline .mainvisual {
  background-image: url(https://reality-notice.wrightflyer.net/b316ecc9b64d6125e7e332be71d8da1a2e607b40.png?t=1657258216);
  padding-top: min(68.0555555556vw, 367.5px);
  padding-bottom: 50px;
}

@media(min-width: 541px) {
  .mainvisual {
    background-size: 540px auto
  }
}

.mainvisual img {
  padding-left: min(2.2222222222vw, 12px);
  padding-right: min(2.2222222222vw, 12px)
}

.event {
  margin-top: min(8.8888888889vw, 48px)
}

.event-indent {
  padding-left: min(4.4444444444vw, 24px);
  padding-right: min(4.4444444444vw, 24px)
}

.event-indent>*:last-child {
  margin-bottom: min(6.6666666667vw, 36px)
}

h3, h5, p, .event-content-gradation, .event-movie, .event-image {
  margin-top: min(5.5555555556vw, 30px)
}

h2 {
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  font-size: min(7.7777777778vw, 42px);
  line-height: 1.357;
  margin-top: min(3.0555555556vw, 16.5px);
  width: 100%
}

h3 {
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  text-align: center;
  font-size: min(5vw, 27px);
  width: 100%
}

h3::before, h3::after {
  content: "";
  display: block;
  height: 1px;
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%)
}

h4 {
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  font-size: min(5vw, 27px);
  text-align: center
}

h5 {
  color: #975fe0;
  font-size: inherit
}

h5::before {
  content: "■"
}

h5+p {
  margin-top: 0
}

.event-content {
  margin-top: min(11.1111111111vw, 60px);
  font-size: min(3.8888888889vw, 21px);
  background-color: #fff;
  border-right: 2px solid #975fe0;
  border-bottom: 4px solid #975fe0;
  line-height: 2
}

.is-cp .event-content:first-child {
  margin-top: min(16.1111111111vw, 87px)
}

.event-content .event-title-number {
  width: min(17.7777777778vw, 96px);
  height: min(16.6666666667vw, 90px);
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: min(10vw, 54px);
  color: #fff;
  margin-top: max(-2.2222222222vw, -12px);
  margin-left: max(-2.2222222222vw, -12px);
  margin-right: min(3.8888888889vw, 21px);
  border-top: min(8.8888888889vw, 48px) solid rgba(0, 0, 0, 0);
  border-style: solid;
  border-width: min(8.8888888889vw, 48px);
  border-left: min(8.8888888889vw, 48px) solid rgba(0, 0, 0, 0)
}

.event-content:nth-of-type(1) .event-title-number::before {
  content: "01"
}

.event-content:nth-of-type(2) .event-title-number::before {
  content: "02"
}

.event-content:nth-of-type(3) .event-title-number::before {
  content: "03"
}

.event-content:nth-of-type(4) .event-title-number::before {
  content: "04"
}

.event-content:nth-of-type(5) .event-title-number::before {
  content: "05"
}

.event-content:nth-of-type(6) .event-title-number::before {
  content: "06"
}

.event-content:nth-of-type(7) .event-title-number::before {
  content: "07"
}

.event-content:nth-of-type(8) .event-title-number::before {
  content: "08"
}

.event-content:nth-of-type(9) .event-title-number::before {
  content: "09"
}

.event-content:nth-of-type(10) .event-title-number::before {
  content: "10"
}

.event-content:nth-of-type(11) .event-title-number::before {
  content: "11"
}

.event-content:nth-of-type(12) .event-title-number::before {
  content: "12"
}

.event-content:nth-of-type(13) .event-title-number::before {
  content: "13"
}

.event-content:nth-of-type(14) .event-title-number::before {
  content: "14"
}

.event-content:nth-of-type(15) .event-title-number::before {
  content: "15"
}

.event-content:nth-of-type(16) .event-title-number::before {
  content: "16"
}

.event-content:nth-of-type(17) .event-title-number::before {
  content: "17"
}

.event-content:nth-of-type(18) .event-title-number::before {
  content: "18"
}

.event-content:nth-of-type(19) .event-title-number::before {
  content: "19"
}

.event-content:nth-of-type(20) .event-title-number::before {
  content: "20"
}

.event-content:nth-of-type(3n + 1) {
  border-right-color: #9a92f3;
  border-bottom-color: #9a92f3
}

.event-content:nth-of-type(3n + 1) .event-title-number {
  background-color: #cccbfa;
  border-right-color: #9a92f3;
  border-bottom-color: #9a92f3
}

.event-content:nth-of-type(3n + 2) {
  border-right-color: #ef6cd3;
  border-bottom-color: #ef6cd3
}

.event-content:nth-of-type(3n + 2) .event-title-number {
  background-color: #fad6fb;
  border-right-color: #e5abf6;
  border-bottom-color: #e5abf6
}

.event-content:nth-of-type(3n + 3) {
  border-right-color: #22bad3;
  border-bottom-color: #22bad3
}

.event-content:nth-of-type(3n + 3) .event-title-number {
  background-color: #bee8f5;
  border-right-color: #9bcfea;
  border-bottom-color: #9bcfea
}

.event-content-gradation {
  margin-left: 0;
  margin-right: 0;
  background: linear-gradient(169.04deg, rgba(208, 207, 255, 0.4) 0%, rgba(190, 232, 245, 0.4) 52.55%, rgba(255, 209, 240, 0.4) 100%);
  background-color: #fff;
  padding: min(4.4444444444vw, 24px) min(4.4444444444vw, 24px) min(6.6666666667vw, 36px)
}

.event-title {
  display: flex;
  font-size: min(7.7777777778vw, 42px);
  line-height: 1.5
}

.event-movie {
  position: relative;
  height: 0;
  padding-top: 56.25%;
  width: 100%
}

.event-movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}


.is-online {
  background-color: #975fe0
}

.is-limited {
  background-color: #ef6cd3
}

.event-detail {
  text-align: center;
  margin-top: 8px;
  margin-bottom: min(6.6666666667vw, 36px)
}


.event-comment {
  margin-top: 0
}

.about {
  background-image: url(https://reality-notice.wrightflyer.net/bae25857f90fc640c9e272002d0f4edd0a82adfe.svg?t=1657256752);
  background-size: min(94.4444444444vw, 510px);
  background-position: center min(6.6666666667vw, 36px);
  margin-top: min(24px, 72px)
}

.is-cp .about {
  background-position: center min(1.1111111111vw, 6px);
  padding-bottom: min(13.3333333333vw, 72px)
}

.about-title, .about-title-sub {
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0)
}

.about-title {
  text-align: center;
  font-size: min(11.1111111111vw, 60px);
  line-height: 1.3
}

.about-title-sub {
  text-align: center;
  font-size: min(4.4444444444vw, 24px);
  margin-top: min(5.5555555556vw, 30px);
  line-height: 1.7
}

.about-text {
  margin-top: min(7.7777777778vw, 42px);
  line-height: 2
}

.footer {
  position: relative;
  margin: 0 auto;
  margin-top: min(13.3333333333vw, 72px);
  padding: 2.7777777778vw;
  font-size: 4.4444444444vw
}

@media(min-width: 541px) {
  .footer {
    padding: 42px;
    font-size: 24px
  }
}

.footer.is-visible {
  opacity: 1
}

.footer a {
  text-decoration: none;
  color: #594b42
}

.footer-links {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 1.1111111111vw
}

@media(min-width: 541px) {
  .footer-links {
    row-gap: 6px
  }
}

.footer-links span {
  display: block
}

.footer-copy {
  margin-top: min(4.4444444444vw, 24px)
}

.button {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(56.1111111111vw, 303px);
  height: min(11.1111111111vw, 60px);
  margin: min(4.4444444444vw, 24px) auto 0;
  padding-left: min(5.5555555556vw, 30px);
  padding-right: min(5.5555555556vw, 30px);
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  color: #fff;
  text-decoration: none;
  text-align: center;
  font-weight: 700;
  border-radius: min(7.7777777778vw, 42px);
  box-shadow: 2px 4px 4px rgba(34, 186, 211, .2)
}

.button.is-icon::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: min(5.5555555556vw, 30px);
  transform: translateY(-50%);
  -webkit-mask-image: url(../images/icon_new_window.svg);
  mask-image: url(../images/icon_new_window.svg);
  -webkit-mask-size: min(3.3333333333vw, 18px) min(3.3333333333vw, 18px);
  mask-size: min(3.3333333333vw, 18px) min(3.3333333333vw, 18px);
  width: min(3.3333333333vw, 18px);
  height: min(3.3333333333vw, 18px);
  margin-left: min(1.6666666667vw, 9px);
  background-color: #fff;
  z-index: 2
}

.button.button-twolines {
  width: min(82.2222222222vw, 444px);
  flex-direction: column;
  line-height: 1.25;
  height: min(15.5555555556vw, 84px);
  padding-left: min(12.7777777778vw, 69px);
  padding-right: min(12.7777777778vw, 69px)
}

.button.button-twolines.is-icon::before {
  right: min(6.6666666667vw, 36px)
}

.button.is-gray {
  background: #a6a09c
}

.button.is-white {
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  overflow: hidden
}

.button.is-white::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  margin: 1px;
  background: #fff;
  border-radius: min(7.7777777778vw, 42px)
}

.button.is-white .button-text {
  display: block;
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0)
}

.button.is-white.is-icon::before {
  background-color: #22bad3
}

.button .button-text {
  font-size: min(4.4444444444vw, 24px);
  margin-top: 0;
  z-index: 2;
  pointer-events: none
}

.button-square {
  position: relative;
  display: flex;
  align-items: center;
  width: min(44.4444444444vw, 240px);
  height: min(17.7777777778vw, 96px);
  padding-left: min(3.8888888889vw, 21px);
  padding-right: min(3.8888888889vw, 21px);
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  text-decoration: none;
  font-weight: 700;
  border-radius: min(1.1111111111vw, 6px);
  box-shadow: 2px 4px 4px rgba(34, 186, 211, .2);
  overflow: hidden
}

.button-square::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  margin: 1px;
  background: #fff;
  border-radius: min(1.1111111111vw, 6px);
  box-shadow: 0 0 6px 3px rgba(132, 56, 207, .3) inset
}

.button-square::after {
  position: absolute;
  content: "";
  display: block;
  right: max(-1.6666666667vw, -9px);
  bottom: max(-1.6666666667vw, -9px);
  width: min(10vw, 54px);
  height: min(7.7777777778vw, 42px);
  background-image: url(../images/mark_triangle.svg);
  background-size: 100% auto;
  background-position: right bottom;
  border-bottom-right-radius: min(1.1111111111vw, 6px)
}

.button-square .button-text {
  display: block;
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  z-index: 2;
  font-size: min(4.4444444444vw, 24px);
  pointer-events: none
}

.button-square .button-text::after {
  position: absolute;
  content: "";
  display: block;
  right: min(1.1111111111vw, 6px);
  bottom: min(1.1111111111vw, 6px);
  width: min(1.9444444444vw, 10.5px);
  height: min(2.5vw, 13.5px);
  background-image: url(../images/icon_button_arrow.svg);
  background-size: 100% auto;
  background-position: right bottom
}

.button-square-container {
  margin-top: min(4.1666666667vw, 22.5px);
  padding-left: min(4.4444444444vw, 24px);
  padding-right: min(4.4444444444vw, 24px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(2.2222222222vw, 12px)
}

.section {
  position: relative;
  margin-left: min(4.4444444444vw, 24px);
  margin-right: min(4.4444444444vw, 24px);
  opacity: 1
}

.section.is-visible {
  animation-name: slideAnimeLink;
  animation-duration: .6s;
  animation-fill-mode: forwards
}

.section-title {
  width: min(85vw, 459px);
  margin: min(13.3333333333vw, 72px) auto 0;
  text-align: center
}

.section-title-sub {
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  display: inline-block;
  margin: 0 auto;
  font-size: min(4.4444444444vw, 24px);
  font-weight: 700
}

.section-image {
  margin-top: min(6.6666666667vw, 36px)
}

.section-table {
  margin-top: min(6.6666666667vw, 36px);
  width: 100%
}

.section-table tr {
  border-top: 1px solid #fff
}

.section-table tr:last-child {
  border-bottom: 1px solid #fff
}

.section-table th, .section-table td {
  padding-top: min(3.3333333333vw, 18px);
  padding-bottom: min(3.3333333333vw, 18px);
  font-size: min(4.4444444444vw, 24px)
}

.section-table th {
  padding-right: min(6.6666666667vw, 36px);
  text-align: left;
  white-space: nowrap;
  color: #975fe0
}

.section-button {
  margin-top: min(6.6666666667vw, 36px)
}

.section-banner {
  margin-top: min(13.3333333333vw, 72px)
}

@keyframes slideAnimeLink {
  from {
    opacity: 0;
    transform: translateY(40px)
  }
  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.application {
  margin-top: min(7.7777777778vw, 42px);
  border: 1px solid #3acddd;
  border-image: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%);
  border-image-slice: 1
}

.application-inner {
  padding: min(4.4444444444vw, 24px)
}

.application-info {
  display: flex
}

.application-info::before {
  content: "";
  display: block;
  background-image: url(../images/app_icon.svg);
  background-size: 100%;
  background-position: left center;
  width: min(12.5vw, 67.5px);
  height: min(12.5vw, 67.5px);
  margin-right: min(2.2222222222vw, 12px)
}

.application-banner {
  display: flex;
  justify-content: space-between
}

.application-banner img {
  width: auto;
  height: min(12.7777777778vw, 69px);
  margin-top: min(4.4444444444vw, 24px)
}

.info {
  margin-top: min(13.3333333333vw, 72px);
  padding: min(4.4444444444vw, 24px);
  background-color: rgba(255, 255, 255, .8)
}

.info-title {
  font-weight: 700;
  font-size: min(4.4444444444vw, 24px);
  margin-bottom: min(4.4444444444vw, 24px);
  text-align: center
}

.info-close {
  margin-top: min(3.3333333333vw, 18px);
  margin-left: min(4.4444444444vw, 24px);
  margin-right: min(4.4444444444vw, 24px);
  padding: min(2.2222222222vw, 12px);
  background-color: rgba(89, 75, 66, .8);
  color: #fff
}

.info-close-title {
  margin-bottom: min(0.5555555556vw, 3px)
}

.info-close-text {
  margin-top: 0;
  text-align: center
}

.photo {
  margin-top: min(13.3333333333vw, 72px);
  margin-bottom: min(13.3333333333vw, 72px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  position: relative;
  background: linear-gradient(95.93deg, #cccbfa 0%, #bee8f5 100%)
}

.photo::before, .photo::after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  background: linear-gradient(98.36deg, #3ACDDD 0%, #985FE0 50.51%, #975FE0 50.52%, #EF6CD3 100%)
}

.photo::before {
  top: 0
}

.photo::after {
  bottom: 0;
  transform: scale(-1, 1)
}

.photo img {
  height: auto;
  padding: 0
}

.photo img:nth-child(6) {
  grid-column: 2/4;
  grid-row: 2/4
}

.photo img:nth-child(10) {
  grid-column: 1/3;
  grid-row: 5/7
}

.photo img:nth-child(18) {
  grid-column: 2/4;
  grid-row: 8/10
}

.photo img:nth-child(22) {
  grid-column: 1/3;
  grid-row: 11/13
}

.social {
  margin-top: min(13.3333333333vw, 72px);
  text-align: center
}

.social-title {
  text-align: center
}

.social-link {
  display: inline-grid;
  grid-template-columns: repeat(3, min(8.8888888889vw, 48px));
  justify-items: center;
  align-items: center;
  gap: min(11.1111111111vw, 60px);
  margin-top: min(6.6666666667vw, 36px)
}

.social-link-twitter {
  width: min(8.8888888889vw, 48px);
  height: min(7.2222222222vw, 48px)
}

.social-link-discord {
  width: min(8.8888888889vw, 48px);
  height: min(6.9444444444vw, 48px)
}

.social-link-youtube {
  width: min(8.8888888889vw, 48px);
  height: min(7.2222222222vw, 39px)
}

.ripple {
  position: relative;
  overflow: hidden
}

.ripple .ripple-active {
  position: absolute;
  pointer-events: none;
  background: rgba(190, 232, 245, .6);
  border-radius: 50%;
  transform: scale(0);
  animation: ripple .8s;
  z-index: 2
}

@keyframes ripple {
  to {
    opacity: 0;
    transform: scale(2)
  }
}

* {
  margin: 0
}

body {
  position: relative;
  width: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #594b42;
  font-size: min(3.8888888889vw, 21px);
  top: var(--scrollY)
}

@media(min-width: 541px) {
  body::before, body::after {
    content: "";
    z-index: -1;
    width: 100%;
    height: 100%;
    bottom: 0;
    position: fixed
  }
  body::before {
    background-image: url(https://reality-notice.wrightflyer.net/505e1f1ddcd632b0a025f1fd6ec7b52a7880e092.svg?t=1657104485);
    background-size: 68.4444444444vw auto;
    left: 0;
    background-position: left bottom
  }
  body::after {
    background-image: url(https://reality-notice.wrightflyer.net/6a7ff5d1699b6ec6f04816e3a83184a678c572f2.svg?t=1657104485);
    background-size: 40.5185185185vw auto;
    right: 0;
    background-position: right bottom
  }
}

body.is-fixed {
  height: 100vh;
  overflow: hidden;
  position: fixed
}

@media(min-width: 541px) {
  .bg::before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    height: 100vh;
    background-image: url(../images/bg_pc_pattern.png);
    background-size: 640px auto;
    background-position: center;
    background-repeat: repeat
  }
}

main {
  overflow: hidden
}

@media(min-width: 541px) {
  main::before, main::after {
    content: "";
    z-index: -1;
    width: 100%;
    height: 100%;
    top: 0;
    position: fixed
  }
  main::before {
    background-image: url();
    background-size: 47.4074074074vw auto;
    left: 0;
    background-position: left top
  }
  main::after {
    background-image: url();
    background-size: 64.3703703704vw auto;
    right: 0;
    background-position: right top
  }
}

.container {
  min-height: 100vh;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 85px #ccb0f1;
  width: min(540px, 100%);
  transition: filter .3s ease-out
}

.container::before {
  content: "";
  display: block;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(540px, 100%);
  height: 100%;
  background-image: url(	https://reality-notice.wrightflyer.net/82231c30192c9a926fa13a118f5f63bf6fb2d2c1.png?t=1657104050), url(https://reality-notice.wrightflyer.net/0268c3f9d212af79a50e89e56933e277fc9fefa1.png?t=1657104050);
  background-size: min(540px, 100%) auto;
  background-position: center top;
  background-repeat: repeat-y;
  background-color: #fff
}

.container.is-offline::before {
  background-image: url(https://reality-notice.wrightflyer.net/82231c30192c9a926fa13a118f5f63bf6fb2d2c1.png?t=1657104050), url(https://reality-notice.wrightflyer.net/0268c3f9d212af79a50e89e56933e277fc9fefa1.png?t=1657104050)
}

img {
  width: 100%;
  height: auto
}

a {
  color: #22bad3
}

body:not(.is-touch) a:hover {
  opacity: .7;
  transition: opacity .2s ease-out
}

.text-link-icon::after {
  content: "";
  display: inline-block;
  background-image: url(../images/icon_new_window.svg);
  background-size: min(3.0555555556vw, 16.5px);
  background-position: center;
  width: min(3.0555555556vw, 16.5px);
  height: min(3.0555555556vw, 16.5px);
  margin-left: min(2.2222222222vw, 12px)
}

p {
  margin-top: min(4.4444444444vw, 24px);
  line-height: 2
}

.color-strong {
  color: #ff24c5
}

.color-gray {
  color: #8c7e74
}

.is-small {
  font-size: min(3.3333333333vw, 18px)
}

.is-shadow {
  box-shadow: 2px 4px 4px rgba(34, 186, 211, .2)
}

.is-bold {
  font-weight: 700
}

.is-block {
  display: block
}
