@charset "utf-8";

body {
  font: 14px/180% "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  -webkit-text-size-adjust: 100%;
  color: #000;
  background: #000
}

body::before {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100vw;
  height: 100vh;
  background: url(../img/fv.jpg) no-repeat;
  background-size: 1550px;
  background-position: top center;
  content: "";
  transition: 0.2s easeInOutSine;
}

@media screen and (max-width:1050px) {
  body::before {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100vw;
    height: 100vh;
    background: url(../img/fv.jpg) no-repeat;
    background-size: 148% auto;
    background-position: top center;
    content: "";
    transition: 0.2s;
  }
}

@media screen and (max-width:700px) {
  body::before {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100vw;
    height: 100vh;
    background: url(../img/fv_sp.jpg) no-repeat;
    background-size: 100% auto;
    background-position: top right;
    content: "";
    transition: 0.2s;
  }
}

div,
p {
  margin: 0;
  padding: 0;
}

ul,
li {
  list-style: none;
  margin: 0;
  padding: 0
}

img {
  vertical-align: top;
  border: 0;
}

hr {
  border: none;
  border-bottom: 1px solid #555;
  background: #000;
  margin: 0 auto;
}

.wrap {
  margin: 0 auto;
  padding: 0;
  text-align: center;
  overflow: hidden;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

.cs {
  margin: 25% auto 0;
  text-align: center;
  font-size: 140%;
  letter-spacing: 0.1em;
}

.pt40 {
  padding-top: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}


/* アンカー */
a,
a:link {
  color: #ffe800;
  text-decoration: underline;
}

a:hover {
  color: #ffe800;
  text-decoration: underline;
}

a:focus {
  outline: none;
}

a.info,
a.info:link {
  color: #fff;
  text-decoration: underline;
}

a.info:hover {
  color: #fff;
  text-decoration: underline;
}

/* @end */

/* トップに戻る */
.pagetop {
  display: none;
  position: fixed;
  bottom: 36px;
  right: 36px;
  z-index: 2000;
}

.pagetop a {
  display: block;
  text-align: center;
  color: #000;
  font-size: 12px;
  text-decoration: none;
  padding: 5px 12px 3px;
  height: 28px;
  background-color: rgba(255, 255, 255, 0.6);
  border-radius: 0;
}

.pagetop a:hover {
  background-color: rgba(255, 255, 255, 1);
}

/* @end */

/* header */
header {
  width: 100%;
}

.top_pc_img {
  width: 1030px;
  margin: 0 auto;
}

.top_pc_img ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  line-height: 0;
}

.top_pc_link li:first-child {
  width: 672px;
}

.top_pc_link li:nth-child(2) {
  width: 84px;
}

.top_pc_link li:nth-child(3) {
  width: 294px;
}

.top_pc_btn {
  position: relative;
}

.top_pc_btn .scale {
  position: absolute;
  max-width: 750px;
  top: 2%;
  left: 5.5%;
  padding: 0 8%;
}

.top_pc_btn .scale a img {
  transition-duration: .4s;
}

.top_pc_btn .scale a img:hover {
  transform: scale(1.1);
}

.btm_pc_btn {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.8));
  padding-bottom: 100px;
}

.btm_pc_btn .scale {
  max-width: 750px;
  margin: 0 auto;
}

.btm_pc_btn .scale a img {
  transition-duration: .4s;
}

.btm_pc_btn .scale a img:hover {
  transform: scale(1.1);
}


.top_sp_img {
  display: none;
}

.top_sp_btn {
  position: relative;
}

.top_sp_btn .scale {
  position: absolute;
  top: 2%;
  left: 5%;
  padding: 0;
  width: 90%;
}

.top_sp_btn .scale a img {
  transition-duration: .4s;
}

.top_sp_btn .scale a img:hover {
  transform: scale(1.1);
}

.btm_sp_btn .scale {
  width: 90%;
  padding: 0 5% 8%;
}

.btm_sp_btn .scale a img {
  transition-duration: .4s;
}

.btm_sp_btn .scale a img:hover {
  transform: scale(1.1);
}

.top_info {
  position: relative;
}

.top_info p {
  color: #666;
  font-size: 13px;
  line-height: 130%;
  text-align: left;
}

.top_info p a {
  color: #666 !important;
}

.top_info p.sponsorship {
  position: absolute;
  top: 205px;
  left: 90px;
}

.top_info p.infomail {
  position: absolute;
  top: 225px;
  left: 90px;
}

/* @end */

/* main */
.main_pc_img {
  width: 1030px;
  margin: 0 auto;
}

.main_sp_img {
  display: none;
}

/* @end */


.bg {
  background: #000;
}

/* list */
.list_bg {
  z-index: 5;
  position: -webkit-sticky;
  /* Safari */
  position: sticky;
  top: 0;
  background: #000;
  width: 100%;
  margin: 0 auto;
}

.list_wrap {
  z-index: 100 !important;
  position: -webkit-sticky;
  /* Safari */
  position: sticky;
}

.list_bg2 {
  width: 100%;
  height: 25vw;
  z-index: 4;
  background: url(../img/list.jpg) no-repeat;
  background-size: 100%;
  background-position: top center;
}

@media screen and (max-width:1000px) {
  .list_bg2 {
    width: 100%;
    height: 33vw;
    z-index: 4;
    background: url(../img/list.jpg) no-repeat;
    background-size: 130% auto;
    background-position: top center;
    content: "";
    transition: 0.1s;
  }
}

@media screen and (max-width:700px) {
  .list_bg2 {
    width: 100%;
    height: 85vw;
    z-index: 4;
    background: url(../img/list_sp.jpg) no-repeat;
    background-size: 100% auto;
    background-position: top center;
    content: "";
    transition: 0.1s;
  }

  .list_wrap {
    z-index: 100 !important;
    position: -webkit-sticky;
    /* Safari */
    position: sticky;
    margin-top: -6vw;
  }
}

@media screen and (max-width:375px) {
  .list_wrap {
    z-index: 100 !important;
    position: -webkit-sticky;
    /* Safari */
    position: sticky;
    margin-top: -120px;
  }
}

.blur {
  -ms-filter: blur(0);
  filter: blur(0);
  opacity: 1;
  transition: all 1s ease-in-out;
  will-change: transform;
}

.blur.active {
  -ms-filter: blur(1px);
  filter: blur(1px);
  opacity: 0.2;
  transition: all 1s ease-in-out;
  will-change: transform;
}



.list_title img {
  margin: 0 auto 20px !important;
}

.list_top_bg {
  margin: 0 auto 2.5% !important;
  max-width: 880px;
  width: 100%;
  background: #fff;
  margin: 0 auto;
}

.list_top {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.list_top div {
  width: 50%;
}

.list_top div img {
  width: 100%;
}

@media screen and (max-width:1000px) {
  .list_top_bg {
    width: 92%;
  }
}

@media screen and (max-width:700px) {
  .list_top div {
    width: 100%;
  }

  .list_top_bg {
    background: none;
  }
}

.list_top2_bg {
  width: 100%;
  margin: 0 auto 2.5%;
  text-align: center;
  background: #fff;
  max-width: 880px;
}

.list_top2_bg img {
  width: 100%;
  max-width: 880px;
}

@media screen and (max-width:700px) {
  .list_top2_bg {
    background: none;
  }
}

@media screen and (max-width:1000px) {
  .list_top2_bg {
    width: 92%;
  }
}

.list {
  width: 880px;
  margin: 0 auto;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.list li {
  margin-bottom: 4%;
  background: #fff;
  width: 48%;
}

.list li img {
  width: 100%;
}

@media screen and (max-width:1000px) {
  .list {
    width: 92%;
  }
}

@media screen and (max-width:700px) {
  .list li {
    width: 100%;
    background: none;
  }
}


.list a img,
.list_top,
.list_top2 {
  opacity: 1;
  -webkit-opacity: 1;
  -moz-opacity: 1;
  filter: alpha(opacity=100);
  /* IE lt 8 */
  -ms-filter: "alpha(opacity=100)";
  /* IE 8 */
}

.list a:hover img,
.list_bnr a:hover img,
.list_top:hover,
.list_top2:hover {
  opacity: 0.7;
  -webkit-opacity: 0.7;
  -moz-opacity: 0.7;
  filter: alpha(opacity=70);
  /* IE lt 8 */
  -ms-filter: "alpha(opacity=70)";
  /* IE 8 */
  transition: opacity 0.4s ease;
  -webkit-transition: opacity 0.4s ease;
  -moz-transition: opacity 0.4s ease;
  -o-transition: opacity 0.4s ease;
  -ms-transition: opacity 0.4s ease;
}

.list_bnr {
  padding-top: 2%;
  padding-bottom: 30px;
}

/* @end */

/* footer */
footer {
  background: #000 !important;
  width: 100%;
}

.footer {
  width: 760px;
  margin: 0 auto;
  color: #fff;
  padding: 10px 0 50px;
}

.footer h1 {
  text-align: left;
  margin: 0 auto 2%;
  font-size: 140%;
}

.footer h2 {
  text-align: left;
  margin: 3% 0 1.2% -7px;
  font-size: 120%;
}

.footer h3 {
  text-align: left;
  margin: 0 auto 2%;
  padding-top: 5%;
  font-size: 140%;
  border: none;
  border-top: 1px solid #808080;
}

.about,
.contact {
  margin: 0 auto;
  padding-bottom: 2%;
}

.about p {
  text-align: justify;
  font-size: 90%;
  line-height: 170%;
  margin-bottom: 1.5%;
}

.contact p:last-child {
  text-align: justify;
}

.contact p {
  text-align: left;
  font-size: 90%;
  line-height: 170%;
  margin-bottom: 1.5%;
}

.info_txt br.none {
  display: none;
}

.copy {
  background: #2c1e1c;
  height: 50px;
}

.copy p {
  width: 960px;
  margin: 0 auto;
  padding-top: 10px;
  color: #fff;
  font-size: 80%;
  letter-spacing: 0.1em;
  text-align: center;
}

.copy_cs {
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 0;
}

.copy_cs div {
  width: 100%;
  height: 50px;
}

.copy_cs p {
  margin: 0 auto;
  padding-bottom: 10px;
  color: #fff;
  font-size: 80%;
  letter-spacing: 0.1em;
  text-align: center;
}

.wrap_cs {
  background-color: rgba(0, 0, 0, 0.8);
  width: 100vw;
  height: 100vh;

}

.wrap_cs p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  text-align: center;
  width: 100%;
  font-size: 120%;
  line-height: 4em;
}

/* @end */

/* アコーディオン */
dl.acc dt {
  background: #000 url(../img/open.png) right 15px no-repeat;
  background-size: 40px 40px;
  border: none;
  border-top: 1px solid #808080;
  font-size: 140%;
  font-weight: bold;
  text-align: left;
  padding: 3% 0 1% 0.5%;
  cursor: pointer;
}

.acc dt.active {
  background: #000 url(../img/close.png) right 15px no-repeat;
  background-size: 40px 40px;
}

.acc dd {
  display: none;
  padding: 0;
  margin: 2% 0 5.5% 0;
  border-top: 1px dotted #444;
}

.acc dd .acc_txt {
  margin-top: 3.5%;
  font-size: 100%;
}

.acc dd p {
  text-align: justify;
  font-size: 90%;
  line-height: 170%;
  margin-bottom: 1.5%;
}

/* アコーディオン end */



/* 1050px以下 */
@media screen and (max-width:1050px) {
  img {
    width: 100%;
  }

  /* header */
  .top_pc_img {
    width: 100%;
  }

  .top_pc_link li:first-child {
    width: 64%;
  }

  .top_pc_link li:nth-child(2) {
    width: 8%;
  }

  .top_pc_link li:nth-child(3) {
    width: 28%;
  }

  .top_info p {
    font-size: 1.2vw;
    line-height: 130%;
  }

  .top_info p.sponsorship {
    position: absolute;
    top: 77.4%;
    left: 8.5%;
  }

  .top_info p.infomail {
    position: absolute;
    top: 85%;
    left: 8.5%;
  }

  .top_pc_btn .scale {
    position: absolute;
    top: 2%;
    left: 0;
    padding: 0 15%;
  }

  /* @end */
  /* main */
  .main_pc_img {
    width: 100%;
  }

  /* @end */
  /* list */
  .list_bnr img {
    width: 600px;
  }

  /* @end */
}

/* 1050px以下 end */


/* 960px以下 */
@media screen and (max-width:960px) {

  /* トップに戻る */
  .pagetop {
    bottom: 0;
    right: 0;
  }

  .pagetop a,
  .pagetop a:hover {
    display: block;
    text-align: center;
    color: #000;
    font-size: 12px;
    text-decoration: none;
    padding: 5px 12px 3px;
    height: 28px;
    background-color: rgba(255, 255, 255, 0.7);
    border-radius: 0;
  }

  /* @end */
  .copy p {
    width: 100%;
  }

}

/* 960px以下 end */



/* 820px以下 */
@media screen and (max-width:820px) {

  /* footer */
  .footer {
    width: 90%;
    padding: 5% 5%;
  }

  /* @end */
}

/* 820px以下 end */


/* 700px以下 */
@media screen and (max-width:700px) {
  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  /* header */
  .top_pc_img {
    display: none;
  }

  .top_sp_img {
    display: block;
    width: 100%;
  }

  .top_sp_bg {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.8));
  }

  /* @end */
  .note br {
    display: none;
  }

  .note br.block {
    display: block !important;
  }

  /* @end */
  /* main */
  .main_pc_img {
    display: none;
  }

  .main_sp_img {
    display: block;
    background: rgba(0, 0, 0, 0.8);
    padding-top: 7%;
  }

  .top_sp_link li:first-child {
    width: 15%;
  }

  .top_sp_link li:nth-child(2) {
    width: 15%;
  }

  .top_sp_link li:nth-child(3) {
    width: 70%;
  }

  .top_sp_img p.sponsorship,
  .top_sp_img p.infomail {
    font-size: 2.5vw !important;
  }

  .top_sp_img ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    font-size: 0;
    line-height: 0;
    width: 100%;
  }

  .top_sp_img ul li {
    margin: 0;
    padding: 0;
    font-size: 0;
    line-height: 0;
    display: 0;
  }

  .top_pc_link li:first-child {
    width: 15%;
  }

  .top_pc_link li:nth-child(2) {
    width: 15%;
  }

  .top_pc_link li:nth-child(3) {
    width: 70%;
  }

  .top_sp_img p {
    font-size: 12px;
    line-height: 130%;
    color: #fff;
    margin-top: 8px;
  }

  .top_sp_img p a {
    color: #fff !important;
  }

  .info_txt br.none {
    display: block;
  }

  a img,
  .list_top:hover {
    border-style: none;
    opacity: 1;
    -webkit-opacity: 1;
    -moz-opacity: 1;
    filter: alpha(opacity=100);
    /* IE lt 8 */
    -ms-filter: "alpha(opacity=100)";
    /* IE 8 */
  }

  /* @end */
  /* アコーディオン */
  dl.acc dt {
    background: #000 url(../img/open.png) right 10px no-repeat;
  }

  .acc dt.active {
    background: #000 url(../img/close.png) right 10px no-repeat;
  }

  /* @end */

  /* list */
  .list_title {
    margin: 0 auto;
  }

  .list_title img {
    margin: 0 auto !important;
  }

  .list a:hover img,
  .list_bnr a:hover img,
  .list_top:hover,
  .list_top2:hover {
    opacity: 1;
    -webkit-opacity: 1;
    -moz-opacity: 1;
    filter: alpha(opacity=100);
    /* IE lt 8 */
    -ms-filter: "alpha(opacity=100)";
    /* IE 8 */
  }

  .list_bnr {
    padding: 1% 0 10%;
  }

  .list_bnr img {
    width: 91.5%;
  }

  .list_top_bg,
  .list_top2_bg {
    margin: 0 auto 6% !important;
  }

  .list li {
    margin-bottom: 6.5%;
  }

  /* @end */
}

/* 700px以下 end */

/* 640px以下 */
@media screen and (max-width:640px) {
  .wrap_cs p {
    font-size: 100%;
  }

  /* footer */
  .footer {
    padding: 4% 0 2.5%;
  }

  .footer h1 {
    text-align: center;
    font-size: 130%;
    letter-spacing: 0.1em;
    margin: 8% auto 2%;
  }

  .footer h2 {
    text-align: center;
    font-size: 110%;
    margin: 2% 0 1.2% 0;
  }

  .footer h3 {
    text-align: center;
    margin: 0 auto 2%;
    padding-top: 7%;
    font-size: 110%;
  }

  .about {
    margin: 0 auto 6%;
    padding-bottom: 0.2%;
  }

  .contact {
    margin: 0 auto 6%;
    padding-bottom: 2%;
  }

  .about p,
  .contact p {
    margin-bottom: 2.5%;
  }

  .copy p {
    font-size: 70%;
    letter-spacing: 0.05em;
  }

  /* @end */
  /* アコーディオン */
  dl.acc dt {
    margin-bottom: 2%;
    font-size: 130%;
    letter-spacing: 0.1em;
    text-align: center;
  }

  .acc dd .acc_txt {
    margin-top: 4%;
  }

  .acc dd p {
    padding: 0 1% 4% 0;
  }

  /* end */

}

/* 640px以下 end */


/* 320px以下 */
@media screen and (max-width:320px) {
  .wrap_cs p {
    font-size: 90%;
  }

  /* list */
  /* footer */
  .about,
  .contact {
    margin: 0 auto 9%;
    padding-bottom: 4%;
  }

  .about p,
  .contact p {
    font-size: 85%;
    letter-spacing: -0.05em;
  }

  .copy p {
    letter-spacing: 0.01em;
  }

  /* @end */
  /* アコーディオン */
  dl.acc dt {
    background: #000 url(../img/open.png) right 3px no-repeat;
    padding: 4% 0 0 0.5%;
  }

  .acc dt.active {
    background: #000 url(../img/close.png) right 3px no-repeat;
  }

  .acc dd {
    margin: 5% 0 5.5% 0;
  }

  .acc dd p {
    font-size: 85%;
    letter-spacing: -0.04em;
  }

  /* end */

}

/* 320px以下 end */