@charset "UTF-8";
*, *::before, *::after {
  box-sizing: border-box;
}

img {
  width: 100%;
}

a:hover img {
  opacity: 0.6;
  cursor: pointer;
}

/*----------------------------------------------------------------------------*/
#loader img {
  width: 266px;
}

.pc {
  display: block;
}
@media screen and (max-width: 677px) {
  .pc {
    width: 100%;
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 677px) {
  .sp {
    width: 100%;
    display: block;
  }
}

/* ルートの文字サイズを10pxに設定 */
html {
  font-size: 62.5%;
}

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

body {
  animation: bodyFadeIn 2s ease 0s 1 normal;
  font-family: "Sawarabi Mincho", serif;
  font-weight: 600;
  font-style: normal;
  -webkit-animation: bodyFadeIn 2s ease 0s 1 normal;
  overflow-x: hidden;
}

body {
  display: block;
  z-index: -1;
  width: 100%;
  background: url("../../_img/bg.jpg") no-repeat center top #FFF;
  font-size: 1.6em;
  background-size: cover;
  color: #000;
  background-attachment: fixed;
}
@media screen and (max-width: 677px) {
  body {
    width: 100%;
    background: none;
  }
}
@media screen and (max-width: 677px) {
  body::before {
    width: 100%;
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-image: url(../../_img/bg_sp.jpg);
    background-size: cover;
  }
}

#wrapper {
  max-width: 1200px;
  margin: 0 auto;
  opacity: 0;
}
@media screen and (max-width: 677px) {
  #wrapper {
    width: 100%;
    overflow: hidden;
  }
}

#vote #wrapper, #thanks #wrapper {
  max-width: 1000px;
  margin: 0 auto;
}

header {
  width: 100%;
  height: auto;
  padding-bottom: 89%;
  position: relative;
  margin: 0 auto 3rem;
  z-index: 0;
}
@media screen and (max-width: 677px) {
  header {
    width: 100%;
    padding-bottom: 150%;
  }
}
header img {
  width: 100%;
}
header h1 {
  font-size: 0;
}
header #title {
  width: 50%;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2%;
  margin: 0 auto;
  z-index: 5;
}
@media screen and (max-width: 677px) {
  header #title {
    width: 100%;
    width: 70%;
    bottom: 28%;
    left: -15%;
  }
}
header #logo {
  width: 24%;
  position: absolute;
  right: 5%;
  top: 52%;
  z-index: 5;
}
@media screen and (max-width: 677px) {
  header #logo {
    width: 100%;
    width: 28%;
    top: 40%;
    right: -2%;
  }
}
header #day {
  width: 40%;
  position: absolute;
  left: 2%;
  top: 2%;
  z-index: 7;
}
@media screen and (max-width: 677px) {
  header #day {
    width: 100%;
    width: 96%;
    top: auto;
    bottom: 2%;
  }
}
header #chara1 {
  width: 60%;
  position: absolute;
  left: 0;
  right: 0;
  top: 4%;
  margin: 0 auto;
  z-index: 4;
}
@media screen and (max-width: 677px) {
  header #chara1 {
    width: 100%;
    top: 0%;
    width: 70%;
  }
}
header #chara2 {
  width: 38%;
  position: absolute;
  right: 8%;
  top: 1%;
  z-index: 3;
}
@media screen and (max-width: 677px) {
  header #chara2 {
    width: 100%;
    top: 1%;
    width: 44%;
    right: 2%;
  }
}
header #chara3 {
  width: 36%;
  position: absolute;
  left: -5%;
  top: 38%;
  margin: 0 auto;
  z-index: 2;
}
@media screen and (max-width: 677px) {
  header #chara3 {
    width: 100%;
    top: 1%;
    width: 43%;
    left: -2%;
  }
}

section {
  width: 100%;
  margin: 0 auto 12rem;
  padding: 0;
  position: relative;
  background: url(../../_img/table_cmn.png) center top repeat-y;
  background-size: 100% auto;
}
@media screen and (max-width: 677px) {
  section {
    width: 100%;
    width: 96%;
    margin: 0 auto 6rem;
  }
}
section::before {
  content: "";
  width: 100%;
  height: auto;
  padding-top: 5%;
  background: url(../../_img/table_header.png) no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: -50px;
}
@media screen and (max-width: 677px) {
  section::before {
    width: 100%;
    top: -4.5vw;
  }
}
section::after {
  content: "";
  width: 100%;
  height: auto;
  padding-top: 5%;
  background: url(../../_img/table_footer.png) no-repeat;
  background-size: 100% auto;
  position: absolute;
  bottom: -50px;
}
@media screen and (max-width: 677px) {
  section::after {
    width: 100%;
    bottom: -4.5vw;
  }
}
section h2 {
  width: 97.7%;
  margin: 1rem auto;
  background: #ff62a5;
  padding: 1.5rem 0;
  color: #FFF;
}
@media screen and (max-width: 677px) {
  section h2 {
    width: 100%;
    width: 97.7%;
    padding: 1rem 0;
  }
}
section h2 img {
  width: 60%;
  margin: 1rem auto 0;
}
@media screen and (max-width: 677px) {
  section h2 img {
    width: 100%;
    width: 100%;
    margin: 0 auto;
  }
}
section h3 {
  margin: 3rem 0;
}
@media screen and (max-width: 677px) {
  section h3 {
    width: 100%;
    margin: 1.2rem 0;
  }
}
section h3 span {
  font-weight: 900;
  background: #000;
  color: #FFF;
  padding: 1rem;
  border: 2px solid #FFF;
  outline: solid 2px #000;
  font-size: 2.5rem;
  line-height: 3rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 677px) {
  section h3 span {
    width: 100%;
    font-size: 1.6rem;
    border: 1px solid #FFF;
    outline: solid 1px #000;
  }
}
section p.name {
  width: 80%;
  margin: -2.6rem auto 0;
  display: block;
  font-weight: 900;
  text-align: center;
  background: #000;
  color: #FFF;
  padding: 0.5rem;
  border: 2px solid #FFF;
  outline: solid 2px #000;
  font-size: 2.1rem;
  line-height: 3rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 677px) {
  section p.name {
    width: 100%;
    width: 80%;
    margin: -1.8rem auto 0;
    border: 1px solid #FFF;
    outline: solid 1px #000;
  }
}
section ul.charaList {
  width: 90%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
}
section ul.charaList li {
  width: 48%;
  margin: 1% 1% 4%;
  padding-bottom: 8rem;
  position: relative;
}
@media screen and (max-width: 677px) {
  section ul.charaList li {
    width: 100%;
    width: 48%;
    padding-bottom: 6rem;
  }
}
section ul.charaList li p.name {
  font-size: 1.4rem;
  line-height: 1.4;
}
section ul.charaList li img {
  position: relative;
  z-index: 0;
}
section ul.charaList li p.caption {
  width: 95%;
  margin: 0 auto;
  font-size: 1.9rem;
  line-height: 2.6rem;
  margin-top: 1rem;
}
@media screen and (max-width: 677px) {
  section ul.charaList li p.caption {
    width: 100%;
    font-size: 1.4rem;
    line-height: 1.7rem;
    margin-top: 1rem;
  }
}
section ul.charaList.notVote {
  pointer-events: none;
}

#comics p.name {
  margin: 2rem auto;
}
@media screen and (max-width: 677px) {
  #comics p.name {
    width: 100%;
    width: 94%;
    font-size: 1.8rem;
    line-height: 1.4;
  }
}

#comics ul.charaList li {
  padding-bottom: 0;
}
@media screen and (max-width: 677px) {
  #comics ul.charaList li {
    width: 100%;
    width: 31.33%;
  }
}

section#rule .inner, section#ruleDetail .inner {
  width: 90%;
  margin: 0 auto;
  font-size: 21px;
  padding: 3rem 0;
  position: relative;
}
@media screen and (max-width: 677px) {
  section#rule .inner, section#ruleDetail .inner {
    width: 100%;
    width: 90%;
    font-size: 1.4rem;
    padding: 1rem 0;
  }
}
section#rule .inner P, section#ruleDetail .inner P {
  margin-bottom: 1rem;
}
section#rule .inner p.strong1, section#ruleDetail .inner p.strong1 {
  font-size: 2.2rem;
}
@media screen and (max-width: 677px) {
  section#rule .inner p.strong1, section#ruleDetail .inner p.strong1 {
    width: 100%;
    font-size: 3vw;
  }
}
section#rule .inner p.caution, section#ruleDetail .inner p.caution {
  font-size: 1.6rem;
}
@media screen and (max-width: 677px) {
  section#rule .inner p.caution, section#ruleDetail .inner p.caution {
    width: 100%;
    font-size: 3vw;
  }
}
section#rule .inner .pict, section#ruleDetail .inner .pict {
  width: 60%;
  margin: 2rem auto;
}
@media screen and (max-width: 677px) {
  section#rule .inner .pict, section#ruleDetail .inner .pict {
    width: 100%;
    width: 90%;
    margin: 2rem auto;
  }
}
section#rule .inner h4, section#ruleDetail .inner h4 {
  border-bottom: 1px solid #000;
  margin: 2rem 0;
}
section#rule .inner .chara, section#ruleDetail .inner .chara {
  width: 45%;
  position: absolute;
  right: 0;
  top: 50px;
}
@media screen and (max-width: 677px) {
  section#rule .inner .chara, section#ruleDetail .inner .chara {
    width: 100%;
    width: 80%;
    margin: 0 auto;
    position: static;
  }
}
section#rule .inner #sendBtn, section#ruleDetail .inner #sendBtn {
  width: 350px;
  margin: 3rem 0;
  text-decoration: none;
  padding: 1.5rem 2rem;
}
@media screen and (max-width: 677px) {
  section#rule .inner #sendBtn, section#ruleDetail .inner #sendBtn {
    width: 100%;
    width: 70%;
    margin: 2rem auto 0;
    padding: 1rem 2rem;
  }
}
section#rule .inner .textBlock, section#ruleDetail .inner .textBlock {
  width: 52%;
}
@media screen and (max-width: 677px) {
  section#rule .inner .textBlock, section#ruleDetail .inner .textBlock {
    width: 100%;
    width: 100%;
  }
}
section#rule .inner p span, section#ruleDetail .inner p span {
  color: #ff00f0;
  font-weight: bold;
}
section#rule .inner #present, section#ruleDetail .inner #present {
  width: 80%;
  margin: 0 auto 2rem;
}
@media screen and (max-width: 677px) {
  section#rule .inner #present, section#ruleDetail .inner #present {
    width: 100%;
    width: 100%;
  }
}

section#read .inner {
  width: 90%;
  margin: 0 auto;
  font-size: 21px;
  padding: 3rem 0;
  position: relative;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 677px) {
  section#read .inner {
    width: 100%;
    width: 90%;
    font-size: 1.4rem;
    padding: 1rem 0;
  }
}
section#read .inner P {
  margin-bottom: 1rem;
}
section#read .inner p.strong1 {
  font-size: 2.2rem;
}
@media screen and (max-width: 677px) {
  section#read .inner p.strong1 {
    width: 100%;
    font-size: 3vw;
  }
}
section#read .inner p.caution {
  font-size: 1.6rem;
}
@media screen and (max-width: 677px) {
  section#read .inner p.caution {
    width: 100%;
    font-size: 3vw;
  }
}
section#read .inner .pict {
  width: 60%;
  margin: 2rem auto;
}
@media screen and (max-width: 677px) {
  section#read .inner .pict {
    width: 100%;
    width: 90%;
    margin: 2rem auto;
  }
}
section#read .inner h4 {
  border-bottom: 1px solid #000;
  margin: 2rem 0;
}
section#read .inner .chara {
  width: 40%;
  margin-right: 3%;
}
@media screen and (max-width: 677px) {
  section#read .inner .chara {
    width: 100%;
    width: 60%;
    margin: 0 auto;
  }
}
section#read .inner #sendBtn {
  width: 350px;
  margin: 3rem 0;
  text-decoration: none;
  padding: 1.5rem 2rem;
}
@media screen and (max-width: 677px) {
  section#read .inner #sendBtn {
    width: 100%;
    width: 70%;
    margin: 2rem auto 0;
    padding: 1rem 2rem;
  }
}
section#read .inner dl#date {
  display: flex;
  flex-wrap: wrap;
  font-size: 2.2rem;
  margin-top: 2rem;
  font-weight: bold;
}
@media screen and (max-width: 677px) {
  section#read .inner dl#date {
    width: 100%;
    font-size: 1.8rem;
  }
}
section#read .inner dl#date dt {
  width: 33%;
  text-align: center;
  color: #FFF;
  background: #ff63a5;
  margin-bottom: 1rem;
  padding: 0 0.5rem;
}
section#read .inner dl#date dd {
  width: 65%;
  margin-bottom: 1rem;
  margin-left: 2%;
}
section#read .inner dl#date dd span {
  font-size: 1.5rem;
}
section#read .inner .textBlock {
  width: 52%;
}
@media screen and (max-width: 677px) {
  section#read .inner .textBlock {
    width: 100%;
    width: 100%;
  }
}
section#read .inner p span {
  color: #ff00f0;
  font-weight: bold;
}

@media (min-width: 600px) {
  section .inner ul.charaList li {
    width: 31%;
  }
  section .inner ul.charaList li p.name {
    font-size: 1.8rem;
  }
}
@media (min-width: 800px) {
  section .inner ul.charaList li {
    width: 23%;
  }
  section .inner ul.charaList li p.name {
    font-size: 2.2rem;
  }
}
@media (min-width: 1100px) {
  section .inner ul.charaList li {
    width: 18%;
  }
  section .inner ul.charaList li p.name {
    font-size: 2rem;
  }
}
/*ボタンのCSS　*/
#sendBtn {
  width: 300px;
  margin: 3rem auto;
  text-decoration: none;
  padding: 1rem 3rem;
  display: block;
  border: 2px solid #fff;
  outline: solid 2px #000;
  background: linear-gradient(to left, #fff6fe, #ff75e7);
}
@media screen and (max-width: 677px) {
  #sendBtn {
    width: 100%;
    width: 80%;
  }
}

#sendBtn.sns {
  width: 450px;
  padding: 1rem 2rem;
}
@media screen and (max-width: 677px) {
  #sendBtn.sns {
    width: 100%;
    width: 90%;
  }
}

a.voteBtn {
  width: 100%;
  text-decoration: none;
  padding: 1rem 3rem;
  position: absolute;
  bottom: 0;
  display: block;
  border: 2px solid #fff;
  outline: solid 2px #000;
  background: linear-gradient(to left, #fff6fe, #d3d3d3);
}
@media screen and (max-width: 677px) {
  a.voteBtn {
    width: 100%;
    padding: 1rem 2rem;
  }
}

a.topBtn {
  width: 100%;
  text-decoration: none;
  padding: 1rem 2rem;
  display: block;
  margin: 0 auto;
  color: #000;
  font-weight: bold;
  letter-spacing: 0.1rem;
  text-align: center;
  border: 2px solid #fff;
  outline: solid 2px #000;
  background: linear-gradient(to left, #ffffff, #b0b0b0);
}

#sendBtn:hover, a.voteBtn:hover {
  color: #FFF;
  background: linear-gradient(to left, #851578, #ff75e7);
}

a.topBtn:hover {
  background: linear-gradient(to left, #8c8c8c, #e2e2e2);
}

/* 投票画面 */
#vote header, #thanks header {
  width: 100%;
  height: auto;
  padding-bottom: 24.6%;
  background: url("../../_img/header_lower.png") no-repeat;
  background-size: 100% auto;
  margin: 0 auto 3rem;
}
@media screen and (max-width: 677px) {
  #vote header, #thanks header {
    width: 100%;
    margin: 0 auto 1rem;
  }
}

section#choose .inner {
  width: 600px;
  margin: 0 auto;
  padding-bottom: 1rem;
}
@media screen and (max-width: 677px) {
  section#choose .inner {
    width: 100%;
    width: 90%;
  }
}
section#choose #random_thanks {
  width: 84%;
  margin: 0 auto -50px;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 677px) {
  section#choose #random_thanks {
    width: 100%;
    width: 130%;
    margin: 0 -15% -3rem;
  }
}
section#choose #pict1 {
  width: 400px;
  margin: 10px auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 677px) {
  section#choose #pict1 {
    width: 100%;
    width: 80%;
  }
}
section#choose #pict1 img {
  width: 100%;
}
section#choose #listTitle {
  text-align: center;
  font-size: 38px;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 3.5rem;
}
section#choose p.name {
  width: 60%;
  margin: -5rem auto 0;
  display: block;
  text-align: center;
  background: #000;
  color: #FFF;
  padding: 1rem 0;
  border: 2px solid #FFF;
  outline: solid 2px #000;
  position: relative;
  z-index: 11;
}
@media screen and (max-width: 677px) {
  section#choose p.name {
    width: 100%;
    width: 70%;
    padding: 1rem;
    margin: -4rem auto 0;
    border: 1px solid #FFF;
    outline: solid 1px #000;
  }
}
section#choose p.charaName {
  font-size: 50px;
  font-weight: bold;
}
section#choose #otherName1 {
  display: none;
  margin-top: 3rem;
}
section#choose #otherName1 input {
  color: #000;
  background: #FFF;
  width: 100%;
  border: 1px solid #000;
  padding: 1rem;
}
section#choose p.caution {
  font-size: 14px;
}
@media screen and (max-width: 677px) {
  section#choose p.caution {
    width: 100%;
    font-size: 3vw;
  }
}
section#choose #shareBtns {
  width: 400px;
  margin: 50px auto 0;
}
section#choose #shareBtns a {
  display: block;
  text-align: center;
}
section#choose #topBtns {
  width: 180px;
  margin: 50px auto 0;
}
@media screen and (max-width: 677px) {
  section#choose #topBtns {
    width: 100%;
    width: 50%;
    margin: 2rem auto 0;
  }
}
section#choose #topBtns a {
  display: block;
  text-align: center;
}

footer {
  text-align: center;
  margin-top: 10rem;
}
@media screen and (max-width: 677px) {
  footer {
    width: 100%;
    margin-top: 1rem;
    font-size: 1rem;
  }
}

footer ul {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  margin-bottom: 2rem;
}

footer ul li {
  width: 100px;
}
@media screen and (max-width: 677px) {
  footer ul li {
    width: 100%;
    width: 14vw;
  }
}

#popup {
  position: relative;
  padding: 10px;
  width: auto;
  max-width: 1000px;
  margin: 0px auto;
}
#popup .bg {
  position: relative;
  z-index: 0;
}
#popup a {
  position: absolute;
  bottom: 12%;
  right: 20%;
  z-index: 1;
}
@media screen and (max-width: 677px) {
  #popup a {
    width: 100%;
    width: 44vw;
    padding: 2vw;
    bottom: 0%;
    right: 10%;
  }
}/*# sourceMappingURL=style.css.map */