@charset "UTF-8";
/* (original_pc.css) */
/* ================= contents =================
[0] reset
[1] base
[2] headerArea
[3] contentsArea
[4] footerArea
============================================ */
/* ============================================
0. reset
============================================ */
/* --------------------------------------------------------------------------------
margin padding
-------------------------------------------------------------------------------- */
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

/* font-family */
body {
  font-family: Tahoma,helvetica,clean,sans-serif; }

/* line-height */
body {
  line-height: 1.45; }

*:first-child + html * {
  letter-spacing: 0; }

/* --------------------------------------------------------------------------------
other
-------------------------------------------------------------------------------- */
ul, ol, li, h1, h2, h3, h4, h5, h6, dl, dt, dd, a {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  font-weight: normal; }

img, iframe {
  border: 0; }

img {
  vertical-align: bottom; }

li {
  list-style: none; }

address {
  font-style: normal;
  font-weight: normal; }

/* --------------------------------------------------------------------------------
table form
-------------------------------------------------------------------------------- */
table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: inherit; }

th, td {
  text-align: left;
  font-style: normal;
  font-weight: normal;
  font-size: inherit; }

fieldset {
  border: 0; }

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit; }

/* --------------------------------------------------------------------------------
block
-------------------------------------------------------------------------------- */
body {
  text-align: left; }

div, span, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, iframe, form, fieldset, legend, blockquote, input, textarea, p, pre {
  text-align: left; }

div {
  margin: 0;
  padding: 0; }

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

img, a img {
  border: none; }

table {
  letter-spacing: 1px; }

iframe {
  border: none; }

strong {
  font-weight: bold; }

/* --------------------------------------------------------------------------------
clearfix
-------------------------------------------------------------------------------- */
.cf_og:after {
  content: "";
  clear: both;
  display: block; }

/* ============================================
 1.base
============================================ */
html, body {
  position: relative;
  width: 100%;
  color: #fff;
  background: #111b38;
  letter-spacing: -.1px;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 500;
  font-family: 'M PLUS Rounded 1c', 'Noto Serif JP',"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
  -webkit-text-size-adjust: 100%; }

a {
  text-decoration: none;
  will-change: transform;
  transition: all 0.3s ease-out;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  transform: translate3d(0, 0, 0);
  opacity: 1;
  color: #fff; }
  a:hover {
    opacity: .7; }

.menu {
  cursor: pointer;
  will-change: transform;
  transition: all 0.3s ease-out;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  transform: translate3d(0, 0, 0);
  opacity: 1; }

.menu.active {
  opacity: .6; }

/* ----------- no-js ----------- */
html#no-js #countdown_time {
  display: none; }

#noscriptBlock {
  width: 520px;
  position: absolute;
  top: 27px;
  left: 27px;
  padding: 10px;
  background: #FFFFFF; }

#noscriptBlock p {
  font-size: 14px;
  background: #FDF3F2;
  color: #D72400;
  border: 1px dotted #F4C3BE;
  padding: 6px 10px;
  line-height: 1.4; }

#container {
  z-index: 100;
  position: relative; }

/* ============================================
 2.headerArea
============================================ */
#headerArea {
  position: fixed;
  top: 0;
  z-index: 100;
  width: 100%;
  height: 70px;
  background: #f246b6; }
  #headerArea .header_inner {
    position: relative;
    max-width: 940px;
    margin: 0 auto; }
  #headerArea .logo {
    padding-top: 7px;
    height: 100%;
    text-align: center; }
    #headerArea .logo img {
      max-width: 170px; }
  #headerArea .menu {
    position: absolute;
    right: 22px;
    top: 20px;
    width: 30px;
    text-align: center; }
    #headerArea .menu img {
      width: 35px; }

/* ============================================
3.contentsArea
============================================ */
#contentArea {
  z-index: 10;
  position: relative;
  margin: 0 auto;
  top: 0;
  width: 100%;
  padding-top: 70px; }
  #contentArea .content_area_inner {
    background: url("../images/bg_.jpg") center top;
    background-size: cover; }
  #contentArea .main-visual {
    position: relative;
    max-width: 940px;
    margin: 0 auto; }
    #contentArea .main-visual .main_img {
      position: relative;
      top: -30px;
      width: 100%; }
    #contentArea .main-visual .txt_catchy {
      position: absolute;
      top: 1px;
      width: 90%;
      left: 5%; }
    #contentArea .main-visual .img_logo {
      position: absolute;
      top: 50%;
      width: 100%; }

.contentAreaInner {
  position: relative;
  top: 0;
  width: 100%;
  overflow: hidden;
  z-index: -1; }

/*---------------- content base ---------------*/
.box_content {
  margin: 0 auto;
  padding: 20px 0;
  width: 100%; }
  .box_content h2 {
    text-align: center;
    margin: 0 auto;
    width: 86%;
    margin-bottom: 20px;
    max-width: 940px; }
  .box_content .box_content_inner {
    padding: 0;
    width: 100%;
    margin: 0 auto; }

.content_date {
  position: relative;
  top: 0;
  width: 92%;
  margin: -55% auto 0; }
  .content_date .date {
    text-align: center;
    margin-bottom: 30px; }
  .content_date .notice {
    text-align: center;
    margin-bottom: 30px; }
  .content_date .btn_login {
    margin-top: 20px;
    text-align: center;
    margin-bottom: 30px; }
    .content_date .btn_login img {
      width: 70%; }
  .content_date .detail {
    width: 70%;
    text-align: center;
    margin: 0 auto; }
    .content_date .detail p {
      text-align: center;
      margin-left: -28px;
      margin-bottom: 25px; }

#menu_sp {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 200;
  padding: 91px 10px;
  display: none;
  height: 100%; }
  #menu_sp .menu_bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0.75; }
  #menu_sp .transration {
    color: #fff;
    margin-bottom: 20px;
    font-size: 14px;
    font-size: 4.375vw; }
    #menu_sp .transration a {
      font-weight: bold;
      color: #fff; }
  #menu_sp .menu_sp_inner {
    position: relative;
    padding: 0 30px; }
  #menu_sp ul {
    position: relative; }
    #menu_sp ul li {
      line-height: 70px;
      text-align: left;
      font-size: 22px;
      font-size: 6.875vw;
      font-weight: 900;
      color: #fff; }
      #menu_sp ul li img {
        max-width: 200px; }
      #menu_sp ul li span {
        background: rgba(255, 255, 255, 0.7);
        display: block;
        font-size: 18px;
        font-size: 1.5rem;
        text-align: center;
        line-height: 60px; }
      #menu_sp ul li a {
        font-weight: 900;
        display: inline-block;
        color: #fff; }
  #menu_sp .menu_close {
    cursor: pointer;
    position: absolute;
    top: -73px;
    right: 15px;
    width: 40px; }

/* ============================================
 4.footerArea
============================================ */
#footerArea {
  position: relative; }
  #footerArea .copyrights {
    padding-top: 20px;
    padding-bottom: 20px;
    width: 100%;
    text-align: center;
    color: #fff;
    font-size: 8px;
    font-size: 2.5vw;
    line-height: 1; }

.no_pc {
  display: inline; }

.no_sp {
  display: none; }

/* ============================================
 投票エリア
============================================ */
.tohyo_area {
  padding: 0 40px; }
  .tohyo_area .gakkyoku_header {
    font-size: 40px;
    text-align: center;
    letter-spacing: 3px;
    color: #fff;
    border: solid 2px #fff;
    padding: 10px;
    font-family: 'M PLUS Rounded 1c', sans-serif;
    margin-bottom: 20px; }
  .tohyo_area .tracklist {
    display: flex;
    flex-wrap: wrap; }
    .tohyo_area .tracklist .track_box {
      font-size: 11px;
      font-size: 3.4375vw;
      padding-left: 5px;
      width: 100%;
      color: #fff;
      font-family: 'M PLUS Rounded 1c', sans-serif; }
      .tohyo_area .tracklist .track_box label {
        margin: 2px 0;
        padding: 3px 0;
        cursor: pointer;
        display: inline-block; }

.tohyo_bnr {
  margin: 30px auto;
  width: 70%; }
  .tohyo_bnr input {
    max-width: 100%; }

.checkbox-input {
  display: none; }

.checkbox-parts {
  padding-left: 20px;
  position: relative;
  margin-right: 20px; }

.checkbox-parts::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid #999;
  border-radius: 4px; }

.checkbox-input:checked + .checkbox-parts {
  color: #ff4c74; }

.checkbox-input:checked + .checkbox-parts::after {
  content: "";
  display: block;
  position: absolute;
  top: -5px;
  left: 5px;
  width: 7px;
  height: 14px;
  transform: rotate(40deg);
  border-bottom: 3px solid #ff4c74;
  border-right: 3px solid #ff4c74; }

@media screen and (min-width: 850px) {
  .no_pc {
    display: none; }

  .no_sp {
    display: inline; }

  /* ============================================
   1.base
  ============================================ */
  html, body {
    position: relative;
    width: 100%;
    color: #fff;
    background: #111b38;
    letter-spacing: -.1px;
    font-size: 12px;
    line-height: 1.5;
    font-weight: 500;
    font-family: 'M PLUS Rounded 1c', 'Noto Serif JP',"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
    -webkit-text-size-adjust: 100%; }

  a {
    text-decoration: none;
    will-change: transform;
    transition: all 0.3s ease-out;
    -webkit-transition: all 0.3s ease-out;
    -moz-transition: all 0.3s ease-out;
    -o-transition: all 0.3s ease-out;
    transform: translate3d(0, 0, 0);
    opacity: 1;
    color: #fff; }
    a:hover {
      opacity: .7; }

  .menu {
    cursor: pointer;
    will-change: transform;
    transition: all 0.3s ease-out;
    -webkit-transition: all 0.3s ease-out;
    -moz-transition: all 0.3s ease-out;
    -o-transition: all 0.3s ease-out;
    transform: translate3d(0, 0, 0);
    opacity: 1; }

  .menu.active {
    opacity: .6; }

  /* ----------- no-js ----------- */
  html#no-js #countdown_time {
    display: none; }

  #noscriptBlock {
    width: 520px;
    position: absolute;
    top: 27px;
    left: 27px;
    padding: 10px;
    background: #FFFFFF; }

  #noscriptBlock p {
    font-size: 14px;
    background: #FDF3F2;
    color: #D72400;
    border: 1px dotted #F4C3BE;
    padding: 6px 10px;
    line-height: 1.4; }

  #container {
    z-index: 100;
    position: relative; }

  /* ============================================
   2.headerArea
  ============================================ */
  #headerArea {
    position: fixed;
    top: 0;
    z-index: 100;
    width: 100%;
    height: 100px;
    background: #f246b6; }
    #headerArea .header_inner {
      position: relative;
      max-width: 850px;
      margin: 0 auto; }
    #headerArea .logo {
      padding-top: 12px;
      height: 100%;
      text-align: center; }
      #headerArea .logo img {
        max-width: 250px; }
    #headerArea .menu {
      position: absolute;
      right: 0px;
      top: 25px;
      width: 50px;
      text-align: center; }
      #headerArea .menu img {
        width: 50px; }

  /* ============================================
  3.contentsArea
  ============================================ */
  #contentArea {
    z-index: 10;
    position: relative;
    margin: 0 auto;
    top: 0;
    width: 100%;
    padding-top: 100px; }
    #contentArea .content_area_inner {
      background: url("../images/bg_.jpg") center top;
      background-size: cover; }
    #contentArea .main-visual {
      position: relative;
      max-width: 850px;
      margin: 0 auto; }
      #contentArea .main-visual .main_img {
        width: 100%; }
      #contentArea .main-visual .txt_catchy {
        position: absolute;
        top: 1px;
        width: 90%;
        left: 5%; }
      #contentArea .main-visual .img_logo {
        position: absolute;
        top: 50%;
        width: 100%; }

  .contentAreaInner {
    position: relative;
    top: 0;
    width: 100%;
    overflow: hidden;
    z-index: -1; }

  /*---------------- content base ---------------*/
  .box_content {
    margin: 0 auto;
    padding: 60px 0;
    width: 100%;
    max-width: 850px; }
    .box_content h2 {
      text-align: center;
      margin: 0 auto;
      width: 86%;
      margin-bottom: 20px;
      max-width: 850px; }
    .box_content .box_content_inner {
      padding: 0;
      width: 90%;
      margin: 0 auto; }

  .content_date {
    position: relative;
    top: 0;
    width: 92%;
    margin: -40% auto 0; }
    .content_date .date {
      text-align: center;
      margin-bottom: 50px; }
    .content_date .notice {
      text-align: center;
      margin-bottom: 30px; }
    .content_date .detail {
      width: 70%;
      text-align: center;
      margin: 0 auto; }
      .content_date .detail p {
        text-align: center;
        margin-left: -28px;
        margin-bottom: 25px; }
    .content_date .btn_login {
      margin-top: 30px;
      text-align: center;
      margin-bottom: 50px; }
      .content_date .btn_login img {
        width: 70%; }

  #menu_sp {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 200;
    padding: 91px 10px;
    display: none;
    height: 100%; }
    #menu_sp .menu_bg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: #000;
      opacity: 0.75; }
    #menu_sp .transration {
      color: #fff;
      margin-bottom: 30px;
      padding-top: 40px;
      font-size: 22px;
      font-size: 1.8333333333rem; }
      #menu_sp .transration a {
        font-weight: bold;
        color: #fff; }
    #menu_sp .menu_sp_inner {
      position: relative;
      padding: 0 30px;
      margin: 0 auto;
      max-width: 850px; }
    #menu_sp ul {
      position: relative; }
      #menu_sp ul li {
        line-height: 80px;
        text-align: left;
        font-size: 22px;
        font-size: 1.8333333333rem;
        font-weight: 850;
        color: #fff; }
        #menu_sp ul li img {
          max-width: 250px; }
        #menu_sp ul li span {
          background: rgba(255, 255, 255, 0.7);
          display: block;
          font-size: 18px;
          font-size: 1.5rem;
          text-align: center;
          line-height: 60px; }
        #menu_sp ul li a {
          font-weight: 850;
          display: inline-block;
          color: #fff; }
    #menu_sp .menu_close {
      cursor: pointer;
      position: absolute;
      top: -67px;
      right: 0px;
      width: 50px; }

  /* ============================================
   4.footerArea
  ============================================ */
  #footerArea {
    position: relative; }
    #footerArea .copyrights {
      padding-top: 20px;
      padding-bottom: 40px;
      width: 100%;
      text-align: center;
      color: #fff;
      font-size: 16px;
      font-size: 1.3333333333rem;
      line-height: 1; }

  /* ============================================
 投票エリア
============================================ */
  .tohyo_area {
    padding: 0 40px; }
    .tohyo_area .gakkyoku_header {
      font-size: 40px;
      text-align: center;
      letter-spacing: 3px;
      color: #fff;
      border: solid 2px #fff;
      padding: 10px;
      font-family: 'M PLUS Rounded 1c', sans-serif;
      margin-bottom: 20px; }
    .tohyo_area .tracklist {
      display: flex;
      flex-wrap: wrap; }
      .tohyo_area .tracklist .track_box {
        font-size: 24px;
        font-size: 2rem;
        padding-left: 5px;
        width: 100%;
        color: #fff;
        font-family: 'M PLUS Rounded 1c', sans-serif; }
        .tohyo_area .tracklist .track_box label {
          margin: 5px 0;
          padding: 5px 0;
          cursor: pointer;
          display: inline-block; }

  .tohyo_bnr {
    margin: 30px auto;
    width: 70%; }
    .tohyo_bnr input {
      max-width: 100%; }

  .checkbox-input {
    display: none; }

  .checkbox-parts {
    padding-left: 20px;
    position: relative;
    margin-right: 20px; }

  .checkbox-parts::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 15px;
    height: 15px;
    border: 1px solid #999;
    border-radius: 4px; }

  .checkbox-input:checked + .checkbox-parts {
    color: #ff4c74; }

  .checkbox-input:checked + .checkbox-parts::after {
    content: "";
    display: block;
    position: absolute;
    top: -5px;
    left: 5px;
    width: 7px;
    height: 14px;
    transform: rotate(40deg);
    border-bottom: 3px solid #ff4c74;
    border-right: 3px solid #ff4c74; } }

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