@charset "UTF-8";
form {
  background-color: #171717;
  font-weight: 500;
  margin: 8vw -8vw 0;
  padding: 10.6vw 8vw;
  position: relative;
}
@media (min-width: 835px) {
  form {
    margin: 72px 0 0;
    padding: 82px 72px 56px;
  }
}

.form__ttl,
.form__txt {
  position: absolute;
  top: 0;
  left: 2.6vw;
  color: #ff00ff;
  font-size: 3.7vw;
  font-weight: 500;
  line-height: 10.6vw;
}
@media (min-width: 835px) {
  .form__ttl,
.form__txt {
    font-size: 1rem;
    left: 32px;
    line-height: 82px;
  }
}

.form__txt {
  position: absolute;
  left: auto;
  right: 2.6vw;
  font-size: 3.2vw;
}
@media (min-width: 835px) {
  .form__txt {
    font-size: 0.75rem;
    right: 32px;
  }
}

@media (min-width: 835px) {
  .form__row {
    align-items: center;
    display: flex;
  }
}
.form__row + dl {
  margin-top: 5.3vw;
}
@media (min-width: 835px) {
  .form__row + dl {
    margin-top: 30px;
  }
}
.form__row dt {
  font-size: 4vw;
  line-height: 1;
  width: 100%;
}
@media (min-width: 835px) {
  .form__row dt {
    font-size: 1rem;
    width: 190px;
  }
}
.form__row strong {
  color: #ff00ff;
  font-size: 3.2vw;
  margin-left: 0.5em;
}
@media (min-width: 835px) {
  .form__row strong {
    font-size: 0.75rem;
  }
}
@media (min-width: 835px) {
  .form__row dd {
    width: calc(100% - 190px);
  }
}
.form__row span {
  display: block;
  font-size: 3.2vw;
  line-height: 1;
  margin-top: 2vw;
}
@media (min-width: 835px) {
  .form__row span {
    font-size: 0.875rem;
    margin: 0;
  }
}
.form__row input,
.form__row select {
  border: none;
  border-radius: 0;
  color: #000;
  display: block;
  font-size: 3.4vw;
  height: 10.6vw;
  margin-top: 2vw;
  padding: 0 1em;
  width: 100%;
}
@media (min-width: 835px) {
  .form__row input,
.form__row select {
    font-size: 0.875rem;
    height: 40px;
    margin: 0;
  }
}
.form__row select {
  width: 38vw;
}
@media (min-width: 835px) {
  .form__row select {
    width: 160px;
  }
}
.form__row.-name {
  display: flex;
  flex-wrap: wrap;
}
.form__row.-name dd {
  width: calc(50% - 1.3vw);
}
@media (min-width: 835px) {
  .form__row.-name dd {
    position: relative;
    width: calc(50% - 101px);
  }
}
.form__row.-name dd + dd {
  margin-left: auto;
}
@media (min-width: 835px) {
  .form__row.-name span {
    position: absolute;
    top: -22px;
    left: 0;
  }
}
.form__row.-post dd {
  align-items: center;
  display: flex;
}
.form__row.-post dd input {
  width: 26.6vw;
}
@media (min-width: 835px) {
  .form__row.-post dd input {
    width: 94px;
  }
}
.form__row.-post dd span {
  margin: 0 1.3vw;
}
@media (min-width: 835px) {
  .form__row.-post dd span {
    margin: 0 10px;
  }
}

.form__btn {
  display: flex;
  justify-content: space-between;
  margin-top: 8vw;
}
@media (min-width: 835px) {
  .form__btn {
    margin-top: 60px;
    justify-content: center;
  }
}
.form__btn input {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 4vw;
  font-weight: bold;
  height: 13.3vw;
  padding: 0;
  width: calc(50% - 1.3vw);
}
@media (min-width: 835px) {
  .form__btn input {
    font-size: 1.25rem;
    height: 70px;
    margin: 0 10px;
    width: 284px;
  }
}
.form__btn [type=submit] {
  background-color: #ff00ff;
}
.form__btn [type=reset] {
  border: 0.2vw solid #ff00ff;
  color: #ff00ff;
}
@media (min-width: 835px) {
  .form__btn [type=reset] {
    border-width: 1px;
  }
}

.header {
  background-color: #2f2f2f;
  padding-bottom: 1.6vw;
}
@media (min-width: 835px) {
  .header {
    padding: 0 100px 24px;
    text-align: center;
  }
}

.lower__caution {
  line-height: 1.8;
}
@media (min-width: 835px) {
  .lower__caution {
    line-height: 2.2;
  }
}
.lower__caution dt {
  color: #ff00ff;
  font-size: 4vw;
  font-weight: 900;
  margin-top: calc(8vw - 0.4em);
}
@media (min-width: 835px) {
  .lower__caution dt {
    font-size: 1.0625rem;
    margin-top: calc(60px - 0.6em);
  }
}
.lower__caution dd {
  color: #bebebe;
  font-size: 3.4vw;
  font-weight: 500;
  margin-left: 0.5em;
  text-indent: -0.5em;
}
@media (min-width: 835px) {
  .lower__caution dd {
    font-size: 0.875rem;
  }
}
.lower__caution dd:before {
  content: "・";
}
.lower__caution dd:last-child {
  margin-bottom: -0.4em;
}
@media (min-width: 835px) {
  .lower__caution dd:last-child {
    margin-bottom: -0.6em;
  }
}

.lower__btn {
  margin-top: 10.6vw;
}
@media (min-width: 835px) {
  .lower__btn {
    margin: 80px auto 0;
    width: 260px;
  }
}
.lower__btn a {
  border: 0.2vw solid #fff;
  color: #fff;
  display: block;
  font-size: 4.5vw;
  letter-spacing: 0.1em;
  line-height: 8.5vw;
  padding-bottom: 0.5vw;
  position: relative;
  text-align: center;
}
@media (min-width: 835px) {
  .lower__btn a {
    border-width: 1px;
    font-size: 18px;
    line-height: 50px;
    padding: 0 15px 2px 0;
  }
}
.lower__btn .c-arwbtn {
  position: absolute;
  top: 50%;
  right: 3.2vw;
  height: 4.6vw;
  transform: translateY(-50%);
  width: 4.6vw;
}
@media (min-width: 835px) {
  .lower__btn .c-arwbtn {
    height: 24px;
    right: 15px;
    width: 24px;
  }
}
.lower__btn .c-arwbtn:before, .lower__btn .c-arwbtn:after {
  background-color: #fff;
}

.onpu__left:before, .onpu__left:after {
  position: absolute;
  top: 0;
  left: 50%;
  content: "";
  transform: translateX(-50%);
  z-index: -1;
}
@media (min-width: 835px) {
  .onpu__left:before, .onpu__left:after {
    left: 0;
    transform: none;
  }
}
.onpu__left:before {
  -webkit-animation: swayOnpu1 15s infinite;
          animation: swayOnpu1 15s infinite;
  background: url(../../assets/img/poster/bg_onpu_02.png) no-repeat center/100%;
  height: 706.2vw;
  width: 100.5vw;
}
@media (min-width: 835px) {
  .onpu__left:before {
    -webkit-animation-name: swayOnpuWide1;
            animation-name: swayOnpuWide1;
    background-image: url(../../assets/img/poster/bg_onpu_l_02.png);
    height: 2091px;
    width: 126px;
  }
}
@-webkit-keyframes swayOnpu1 {
  50% {
    transform: translate(-50%, -1%);
  }
}
@keyframes swayOnpu1 {
  50% {
    transform: translate(-50%, -1%);
  }
}
@-webkit-keyframes swayOnpuWide1 {
  50% {
    transform: translateY(-1%);
  }
}
@keyframes swayOnpuWide1 {
  50% {
    transform: translateY(-1%);
  }
}
.onpu__left:after {
  -webkit-animation: swayOnpu2 10s infinite;
          animation: swayOnpu2 10s infinite;
  background: url(../../assets/img/poster/bg_onpu_01.png) no-repeat center/100%;
  height: 710.1vw;
  width: 104.8vw;
}
@media (min-width: 835px) {
  .onpu__left:after {
    -webkit-animation-name: swayOnpuWide2;
            animation-name: swayOnpuWide2;
    background-image: url(../../assets/img/poster/bg_onpu_l_01.png);
    height: 2221px;
    width: 186px;
  }
}
@-webkit-keyframes swayOnpu2 {
  50% {
    transform: translate(-50%, -2%);
  }
}
@keyframes swayOnpu2 {
  50% {
    transform: translate(-50%, -2%);
  }
}
@-webkit-keyframes swayOnpuWide2 {
  50% {
    transform: translateY(-2%);
  }
}
@keyframes swayOnpuWide2 {
  50% {
    transform: translateY(-2%);
  }
}

@media (min-width: 835px) {
  .onpu__right:before, .onpu__right:after {
    position: absolute;
    top: 0;
    right: 0;
    content: "";
    z-index: -1;
  }
}
@media (min-width: 835px) {
  .onpu__right:before {
    -webkit-animation: swayOnpuWide1 15s infinite;
            animation: swayOnpuWide1 15s infinite;
    background: url(../../assets/img/poster/bg_onpu_r_02.png) no-repeat center/100%;
    height: 2218px;
    width: 242px;
  }
}
@media (min-width: 835px) {
  .onpu__right:after {
    -webkit-animation: swayOnpuWide2 10s infinite;
            animation: swayOnpuWide2 10s infinite;
    background: url(../../assets/img/poster/bg_onpu_r_01.png) no-repeat center/100%;
    height: 2057px;
    width: 229px;
  }
}

.share {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-top: 26.6vw;
}
@media (min-width: 835px) {
  .share {
    position: fixed;
    top: 30px;
    right: 30px;
    display: block;
    margin: 0;
  }
}
.share h2 {
  font-size: 2.6vw;
  font-weight: 900;
  letter-spacing: 0.12em;
}
@media (min-width: 835px) {
  .share h2 {
    font-size: 10px;
  }
}
.share p {
  margin-left: 5.3vw;
}
@media (min-width: 835px) {
  .share p {
    margin: 16px auto 0;
  }
}
.share p.-twitter {
  width: 6.4vw;
}
@media (min-width: 835px) {
  .share p.-twitter {
    width: 26px;
  }
}
.share p.-line {
  width: 6.9vw;
}
@media (min-width: 835px) {
  .share p.-line {
    width: 28px;
  }
}
.share p.-facebook {
  width: 2.6vw;
}
@media (min-width: 835px) {
  .share p.-facebook {
    width: 10px;
  }
}
.share a,
.share img {
  display: block;
}

.upper {
  font-size: 3.7vw;
  font-weight: 500;
  padding-top: 8.6vw;
}
@media (min-width: 835px) {
  .upper {
    font-size: 1.125rem;
    padding-top: 52px;
  }
}

.upper__ttl {
  text-align: center;
}
.upper__ttl span {
  background-color: #ff00ff;
  color: #000;
  display: block;
  font-size: 2.9vw;
  font-weight: bold;
  line-height: 1.65;
}
@media (min-width: 835px) {
  .upper__ttl span {
    font-size: 1rem;
    line-height: 2.15;
    margin: auto;
    max-width: 690px;
  }
}
.upper__ttl img {
  margin-top: 3.3vw;
}
@media (min-width: 835px) {
  .upper__ttl img {
    margin-top: 30px;
    max-width: 680px;
  }
}

.upper__end {
  background-color: #fff;
  color: #000;
  font-size: 4vw;
  font-weight: 900;
  line-height: 1.6;
  margin: 6.6vw -10.7vw 0;
  padding: 2.6vw 0;
  text-align: center;
}
@media (min-width: 835px) {
  .upper__end {
    font-size: 1.75rem;
    margin: 50px 0 0;
    padding: 20px 0;
  }
}

.upper__txt {
  background-color: #000;
  background-image: linear-gradient(to left, transparent 40%, #000 40%), linear-gradient(rgba(217, 217, 217, 0.8) 0.2vw, transparent 0.2vw);
  background-size: 0.6vw 100%, 100% 2.5em;
  line-height: 2.5;
  margin-top: 6.6vw;
  padding-bottom: 0.4vw;
}
@media (min-width: 835px) {
  .upper__txt {
    background-image: linear-gradient(to left, transparent 40%, #000 40%), linear-gradient(rgba(217, 217, 217, 0.8) 2px, transparent 2px);
    background-size: 5px 100%, 100% 3.2em;
    line-height: 3.2;
    margin-top: 50px;
    padding-bottom: 2px;
  }
}
.upper__txt strong {
  color: #ff00ff;
  display: inline-block;
  font-weight: 900;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
@media (min-width: 835px) {
  .upper__txt strong {
    letter-spacing: 0;
  }
}

.upper__detail {
  margin-top: 8vw;
}
@media (min-width: 835px) {
  .upper__detail {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: 26px;
  }
}
.upper__detail dt {
  background-color: #2f2f2f;
  font-size: 3.2vw;
  padding: 0.2em 0.8em;
}
@media (min-width: 835px) {
  .upper__detail dt {
    font-size: 0.75rem;
    padding: 0.75em 0;
    text-align: center;
    width: 118px;
  }
}
@media (min-width: 835px) {
  .upper__detail dd {
    width: calc(100% - 132px);
  }
}
.upper__detail dd.-term {
  font-size: 5.6vw;
  font-weight: bold;
  margin: calc(3.2vw - 0.25em) 0 -0.25em;
}
@media (min-width: 835px) {
  .upper__detail dd.-term {
    font-size: 1.75rem;
    line-height: 1;
    margin: 0;
  }
}
.upper__detail dd.-term strong {
  color: #ff00ff;
}
.upper__detail dd.-term span {
  display: inline-block;
  font-size: 4.5vw;
  margin: -0.4em 0 0 0.4em;
  vertical-align: middle;
}
@media (min-width: 835px) {
  .upper__detail dd.-term span {
    font-size: 1.25rem;
  }
}
.upper__detail dd.-chara {
  display: flex;
  flex-wrap: wrap;
}
.upper__detail dd.-chara span {
  margin: calc(3.2vw - 0.25em) 0 -0.25em;
  width: 50%;
}
@media (min-width: 835px) {
  .upper__detail dd.-chara span {
    margin: 0 30px 0 0;
    width: auto;
  }
}
.upper__detail dd.-chara span:before {
  display: inline-block;
  line-height: 0;
  margin-right: 0.5em;
  vertical-align: middle;
  width: 4.5vw;
}
@media (min-width: 835px) {
  .upper__detail dd.-chara span:before {
    width: 24px;
  }
}
.upper__detail dd.-chara span.-hitori:before {
  content: url(../../assets/img/poster/ico_onpu_p.svg);
}
.upper__detail dd.-chara span.-nijika:before {
  content: url(../../assets/img/poster/ico_onpu_y.svg);
}
.upper__detail dd.-chara span.-ryo:before {
  content: url(../../assets/img/poster/ico_onpu_b.svg);
}
.upper__detail dd.-chara span.-ikuyo:before {
  content: url(../../assets/img/poster/ico_onpu_r.svg);
}
@media (min-width: 835px) {
  .upper__detail:first-of-type {
    margin-top: 50px;
  }
}

.upper__note li {
  font-size: 3.4vw;
  line-height: 1.8;
  margin: calc(5.3vw - 0.4em) 0 -0.4em 1.2em;
  text-indent: -1.2em;
}
@media (min-width: 835px) {
  .upper__note li {
    font-size: 0.9375rem;
    margin-top: calc(20px - 0.4em);
  }
}
.upper__note li:before {
  color: #ff00ff;
  content: "●";
  margin-right: 0.2em;
}
.upper__note li:first-child {
  margin-top: calc(8vw - 0.4em);
}
@media (min-width: 835px) {
  .upper__note li:first-child {
    margin-top: calc(50px - 0.4em);
  }
}