body {
  font-size: 20px;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
  font-weight: 400;
  color: #fff;
  line-height: 1.6;
  background: url(../images/bg.jpg) repeat-y center top #000;
  text-align: left;
  -webkit-text-size-adjust: 100%;
  word-break: break-word;
  min-width: 750px;
  margin: 0;
  padding: 0; }

a {
  color: #fff;
  text-decoration: underline;
  transition: all 0.3s; }

a:hover {
  text-decoration: none;
  filter: brightness(1.2); }

.js-modal-btn {
  cursor: pointer;
  transition: all 0.3s; }
  .js-modal-btn:hover {
    filter: brightness(1.2); }

p {
  margin: 20px 0; }

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

#allwrap {
  overflow: hidden; }

/*------------------------------------------*/
header {
  position: fixed;
  top: 0;
  left: 0;
  background: #000;
  width: 100%;
  height: 170px;
  margin: 0;
  padding: 0;
  z-index: 1000; }
  header::before {
    content: "";
    display: block;
    width: 100%;
    height: 17px;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.7));
    position: absolute;
    bottom: -3px;
    left: 0;
    pointer-events: none; }
  header::after {
    content: "";
    display: block;
    width: 100%;
    height: 17px;
    background: url(../images/hr.png) repeat-x center center;
    position: absolute;
    bottom: -8px;
    left: 0; }
  header a:hover {
    filter: none; }
  header img {
    vertical-align: middle; }
  header .inner {
    align-items: center;
    justify-content: space-between;
    padding: 0 95px 0 30px;
    width: 750px;
    height: 90px;
    display: flex;
    box-sizing: border-box;
    margin: 0 auto;
    position: relative; }
  header .sns {
    display: flex;
    justify-content: space-between;
    align-items: center; }
    header .sns a {
      display: block;
      margin-right: 20px; }

.menubtn {
  background: #C80000;
  position: absolute;
  top: 0;
  right: 0;
  width: 90px;
  height: 90px;
  cursor: pointer; }

.menubtn .icon {
  width: 42px;
  height: 32px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

.menubtn span {
  background: #fff;
  width: 42px;
  height: 4px;
  display: block;
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  transition: all 0.3s ease 0s; }

.menubtn span:nth-of-type(1) {
  top: 2px; }

.menubtn span:nth-of-type(2) {
  top: 16px; }

.menubtn span:nth-of-type(3) {
  top: 30px; }

.menubtn.active span:nth-of-type(1), .menubtn.active span:nth-of-type(1) {
  transform: translate(-50%, -50%) rotate(-135deg);
  top: 50%; }

.menubtn.active span:nth-of-type(2), .menubtn.active span:nth-of-type(2) {
  opacity: 0;
  left: 100%; }

.menubtn.active span:nth-of-type(3), .menubtn.active span:nth-of-type(3) {
  transform: translate(-50%, -50%) rotate(135deg);
  top: 50%; }

#mainmenu {
  background: #C80000;
  height: 80px; }
  #mainmenu ul {
    width: 750px;
    height: 80px;
    margin: 0 auto;
    padding: 0;
    display: table; }
    #mainmenu ul li {
      display: table-cell;
      vertical-align: middle;
      list-style: none;
      position: relative;
      margin: 0;
      padding: 0; }
      #mainmenu ul li::after {
        content: "";
        width: 1px;
        height: 45px;
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
        display: block;
        background: rgba(255, 255, 255, 0.5); }
      #mainmenu ul li:last-child::after {
        display: none; }
  #mainmenu a {
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1.2;
    text-decoration: none;
    text-align: center;
    font-weight: bold; }

#localmenu {
  background: #C80000;
  height: 80px; }
  #localmenu ul {
    width: 750px;
    height: 80px;
    margin: 0 auto;
    padding: 0;
    display: block; }
    #localmenu ul li {
      float: right;
      vertical-align: middle;
      list-style: none;
      position: relative;
      margin: 0 10px 0 0;
      padding: 10px 0 20px; }
  #localmenu a {
    height: 50px;
    line-height: 1.2;
    display: block;
    text-decoration: none;
    text-align: center;
    font-weight: bold;
    background: #fff;
    color: #C80000;
    padding: 10px 20px 0;
    box-sizing: border-box;
    position: relative; }
    #localmenu a::before {
      content: "";
      display: block;
      border-top: 7px solid transparent;
      border-right: 20px solid #C80000;
      position: absolute;
      bottom: 10px;
      left: 50%;
      margin-left: -35px; }
    #localmenu a::after {
      content: "";
      display: block;
      width: 50px;
      height: 3px;
      background: #C80000;
      position: absolute;
      bottom: 10px;
      left: 50%;
      margin-left: -15px; }

#bmenu {
  position: absolute;
  top: 90px;
  left: 0;
  background: #000;
  width: 100%;
  z-index: 1100;
  display: none; }
  #bmenu::before {
    content: "";
    width: 50vw;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: #C80000; }
  #bmenu .bmenu_inner {
    position: relative;
    z-index: 10;
    display: flex;
    width: 750px;
    justify-content: space-between;
    align-items: center;
    padding: 40px 0;
    margin: 0 auto; }
  #bmenu ul {
    margin: 0;
    padding: 0;
    width: 50%;
    box-sizing: border-box;
    padding: 0 80px; }
    #bmenu ul li {
      margin: 0;
      padding: 0;
      list-style: none;
      border-top: 1px solid #fff; }
      #bmenu ul li:last-child {
        border-bottom: 1px solid #fff; }
  #bmenu a {
    text-decoration: none;
    font-weight: bold;
    font-size: 25px;
    display: block;
    text-align: center;
    padding: 5px 0; }

/*------------------------------------------*/
#mv,
#entry,
#app {
  position: relative; }
  #mv::after,
  #entry::after,
  #app::after {
    content: "";
    display: block;
    width: 100vw;
    height: 17px;
    background: url(../images/hr.png) repeat-x center center;
    position: absolute;
    bottom: -8px;
    left: 50%;
    margin: 0 0 0 -50vw;
    z-index: 100; }

#mv {
  margin-top: 175px;
  background: url(../images/mv_bg.jpg) no-repeat center center #000;
  height: 788px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%; }
  #mv img {
    vertical-align: top; }
  #mv h1 {
    margin: 0;
    padding: 0; }
  #mv .btn {
    display: flex;
    margin-top: -10px; }

#entry {
  width: auto; }
  #entry a {
    background: url(../images/entry_bg.png) repeat-x center center #000;
    height: 211px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%; }

#app {
  background: url(../images/app_bg.jpg) no-repeat center center #000;
  height: 766px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%; }

/*------------------------------------------*/
#contents {
  display: block; }
  #contents section {
    padding: 90px 0 70px;
    position: relative; }
    #contents section::after {
      content: "";
      display: block;
      width: 100vw;
      height: 17px;
      background: url(../images/hr.png) repeat-x center center;
      position: absolute;
      bottom: -8px;
      left: 50%;
      margin: 0 0 0 -50vw; }

#competirionmodel_contents {
  display: block;
  background: url("../images/competitionmodel/bg.png") repeat-y center top #000;
  padding: 175px 0 20px;
  position: relative; }
  #competirionmodel_contents::after {
    content: "";
    display: block;
    width: 100vw;
    height: 17px;
    background: url(../images/hr.png) repeat-x center center;
    position: absolute;
    bottom: -8px;
    left: 50%;
    margin: 0 0 0 -50vw; }
  #competirionmodel_contents section {
    width: 750px;
    text-align: center; }
  #competirionmodel_contents #movie {
    position: relative; }
    #competirionmodel_contents #movie .movie {
      position: absolute;
      top: 199px;
      left: 90px;
      width: 570px; }

section {
  width: 675px;
  margin: 0 auto; }

.gotop {
  position: fixed;
  bottom: 20px;
  right: 0; }

h2 {
  text-align: center;
  margin: 0 0 50px; }

h3 {
  font-size: 25px;
  font-weight: normal;
  margin: 0 0 15px;
  text-align: center; }

/*------------------------------------------*/
#point {
  text-align: center;
  width: 750px; }
  #point ol {
    margin: 0;
    padding: 0; }
    #point ol li {
      margin: -40px 0 0 0;
      padding: 0;
      list-style: none; }

#schedule figure {
  margin: -160px -35px 0;
  text-align: center; }
#schedule dl {
  line-height: 59px;
  margin: 0 0 25px;
  overflow: hidden;
  text-align: center; }
  #schedule dl dt {
    width: 220px;
    height: 59px;
    border-radius: 29.5px 0px 0px 29.5px;
    background: linear-gradient(#dc0000 0%, #dc0000 27.09%, #f49e29 100%);
    float: left;
    clear: both;
    font-size: 30px;
    margin: 0;
    padding: 0; }
  #schedule dl dd {
    width: 455px;
    height: 59px;
    border-radius: 0px 29.5px 29.5px 0px;
    background: linear-gradient(#ffdc69 0%, #fff 100%);
    float: right;
    margin: 0 0 10px;
    padding: 0;
    color: #000; }
  #schedule dl.app dt {
    width: 410px;
    background: linear-gradient(#0066dc 0%, #0066dc 27.09%, #00b5e0 100%);
    letter-spacing: -0.1em; }
  #schedule dl.app dd {
    width: 265px;
    background: linear-gradient(#a7f1ff 0%, #fff 100%); }
  #schedule dl.final {
    height: 59px;
    background: url(../images/final_bg.png) no-repeat center center;
    display: flex;
    align-items: center;
    justify-content: center; }
    #schedule dl.final dt {
      width: auto;
      background: none;
      margin: 0 25px 0 0; }
    #schedule dl.final dd {
      width: auto;
      background: none;
      color: #fff;
      margin: 0; }
#schedule .btn {
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  padding: 45px 0;
  margin: 40px 0; }
  #schedule .btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 558px;
    height: 97px;
    background: linear-gradient(#960000 0%, #c80000 50%, #960000 100%);
    font-size: 30px;
    font-weight: bold;
    position: relative;
    text-decoration: none;
    margin: 0 auto; }
    #schedule .btn a::after {
      content: "";
      border-left: 23px solid #fff;
      border-top: 12px solid transparent;
      border-bottom: 12px solid transparent;
      position: absolute;
      top: 50%;
      right: 20px;
      display: block;
      width: 0;
      height: 0;
      transform: translateY(-50%); }

#model .movie {
  margin: 0 0 60px; }
#model .btn {
  margin: 0 0 20px; }
  #model .btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    width: 558px;
    height: 121px;
    background: linear-gradient(#960000 0%, #c80000 50%, #960000 100%);
    font-size: 30px;
    font-weight: bold;
    position: relative;
    text-decoration: none;
    margin: 0 auto;
    line-height: 1.2; }
    #model .btn a::before {
      content: "";
      background: url(../images/model.png) no-repeat center center;
      width: 65px;
      height: 90px;
      position: absolute;
      top: 50%;
      left: 20px;
      transform: translateY(-50%); }
    #model .btn a::after {
      content: "";
      background: url(../images/model.png) no-repeat center center;
      width: 65px;
      height: 90px;
      position: absolute;
      top: 50%;
      right: 20px;
      transform: translateY(-50%); }

#outline .lead {
  font-size: 25px;
  text-align: center;
  margin: 0 0 30px; }
#outline .frame {
  background: #fff;
  color: #505050;
  overflow: auto;
  padding: 10px 30px;
  margin: 20px 0;
  height: 980px;
  box-sizing: border-box; }
  #outline .frame a {
    color: #000; }
#outline h3 {
  font-size: 20px;
  font-weight: normal;
  margin: 20px 0 0;
  text-align: left; }
#outline p {
  margin: 0 0 20px; }
#outline .venue {
  background: #E6E6E6;
  padding: 20px;
  margin: 30px 0; }
  #outline .venue h4 {
    background: #D2D2D2;
    margin: 0 0 20px;
    padding: 5px 10px;
    font-weight: normal; }
  #outline .venue dl {
    margin: 20px 0 0;
    padding: 0; }
    #outline .venue dl dt, #outline .venue dl dd {
      margin: 0;
      padding: 0; }
  #outline .venue .map {
    margin: 20px 0 20px; }
    #outline .venue .map iframe {
      width: 100%;
      height: 290px; }
#outline .flows {
  background: #E6E6E6;
  padding: 30px 20px;
  margin: 30px 0; }
  #outline .flows h4 {
    font-weight: normal;
    margin: 0 0 10px; }
  #outline .flows ol.flow {
    margin: 0 0 40px 0;
    padding: 0; }
    #outline .flows ol.flow li {
      list-style: none;
      background: #fff;
      margin: 0 0 50px;
      padding: 0 20px 20px;
      position: relative; }
      #outline .flows ol.flow li::after {
        content: "";
        display: block;
        width: 0;
        height: 0;
        border-top: 18px solid #969696;
        border-left: 9px solid transparent;
        border-right: 9px solid transparent;
        position: absolute;
        bottom: -34px;
        left: 50%;
        transform: translateX(-50%); }
      #outline .flows ol.flow li:last-child {
        margin: 0; }
        #outline .flows ol.flow li:last-child::after {
          display: none; }
    #outline .flows ol.flow h4 {
      background: #969696;
      color: #fff;
      padding: 5px 20px;
      margin: 0 -20px 20px; }
    #outline .flows ol.flow p {
      margin: 0; }
  #outline .flows ol.timetable {
    margin: 0 0 0 0;
    padding: 0; }
    #outline .flows ol.timetable li {
      list-style: none;
      background: #fff;
      margin: 0 0 50px;
      padding: 0;
      position: relative;
      display: flex;
      justify-content: space-between;
      align-items: stretch; }
      #outline .flows ol.timetable li::after {
        content: "";
        display: block;
        width: 0;
        height: 0;
        border-top: 18px solid #969696;
        border-left: 9px solid transparent;
        border-right: 9px solid transparent;
        position: absolute;
        bottom: -34px;
        left: 55px;
        transform: translateX(-50%); }
      #outline .flows ol.timetable li:last-child {
        margin: 0; }
        #outline .flows ol.timetable li:last-child::after {
          display: none; }
    #outline .flows ol.timetable .time {
      width: 110px;
      color: #fff;
      background: #969696;
      text-align: center;
      padding: 15px;
      box-sizing: border-box; }
    #outline .flows ol.timetable .text {
      padding: 15px 20px;
      width: calc(100% - 110px); }
      #outline .flows ol.timetable .text em {
        border-bottom: 1px solid #969696;
        display: block;
        padding: 0 0 5px;
        margin: 0  0 10px;
        font-style: normal; }

#info ul.tab {
  display: flex;
  justify-content: space-between;
  margin: 0;
  padding: 0; }
  #info ul.tab li {
    cursor: pointer;
    background: rgba(255, 255, 255, 0.5);
    width: 218px;
    height: 48px;
    position: relative;
    line-height: 48px;
    text-align: center;
    font-size: 19px;
    color: #000;
    list-style: none; }
    #info ul.tab li.active {
      background: linear-gradient(#960000 0%, #e61414 51.72%, #960000 100%);
      color: #fff;
      cursor: default; }
    #info ul.tab li.disabled {
      cursor: default; }
    #info ul.tab li .cs {
      position: absolute;
      top: 0;
      left: 0;
      background: linear-gradient(rgba(150, 0, 0, 0.5) 0%, rgba(230, 20, 20, 0.5) 51.72%, rgba(150, 0, 0, 0.5) 100%);
      color: #fff;
      width: 100%;
      height: 100%; }
#info .tab_contents .tab_content {
  display: none;
  background: #fff;
  color: #505050;
  padding: 30px 20px;
  height: 600px;
  overflow: auto;
  box-sizing: border-box;
  position: relative; }
  #info .tab_contents .tab_content.active {
    display: block; }
  #info .tab_contents .tab_content h3 {
    color: #C80000;
    text-align: left;
    font-weight: bold; }
  #info .tab_contents .tab_content h4 {
    margin: 0;
    font-weight: normal; }
  #info .tab_contents .tab_content p {
    margin: 0  0 20px; }
#info #tab1 .illust {
  position: absolute;
  top: 0;
  right: 0; }

#p-sports {
  text-align: center; }
  #p-sports figure {
    margin: 0 0 40px; }
  #p-sports p {
    font-size: 25px; }

/*------------------------------------------*/
footer {
  padding: 90px 0 50px;
  text-align: center; }
  footer #bnr {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: -30px; }
    footer #bnr a {
      margin-top: 30px; }
      footer #bnr a:first-child {
        margin-right: 30px; }
  footer #gotop {
    padding: 60px 0; }
    footer #gotop a {
      display: block;
      padding: 30px 0 0;
      position: relative;
      text-decoration: none; }
      footer #gotop a::before {
        content: "";
        border-bottom: 25px solid #fff;
        border-left: 12px solid transparent;
        border-right: 12px solid transparent;
        display: block;
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0; }
  footer #contact p {
    margin: 0 0 20px;
    font-size: 25px; }
  footer #contact a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 326px;
    height: 65px;
    background: linear-gradient(#960000 0%, #c80000 50%, #960000 100%);
    font-size: 25px;
    font-weight: bold;
    position: relative;
    text-decoration: none;
    margin: 0 auto; }
    footer #contact a::after {
      content: "";
      border-left: 13px solid #fff;
      border-top: 6px solid transparent;
      border-bottom: 6px solid transparent;
      position: absolute;
      top: 50%;
      right: 20px;
      display: block;
      width: 0;
      height: 0;
      transform: translateY(-50%); }
  footer #caution {
    display: table;
    padding: 30px 0 30px 80px;
    width: auto;
    background: url(../images/caution.png) no-repeat left center;
    text-align: left; }

/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/
