@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700&display=swap");
/* 共通
-------------------------------------------- */
.snsList {
  padding-bottom: 1rem;
  margin-bottom: 0;
}

.bold {
  font-weight: 700;
}

.bluearchive {
  font-family: "Noto Sans JP", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Verdana", sans-serif;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: .02em;
  color: #000000;
}
.bluearchive a {
  color: #ff0000;
  text-decoration: none;
  font-weight: 700 !important;
}
.bluearchive_yokoku {
  display: block;
  width: 100%;
  background: #cc0000;
  line-height: 0;
}

/* PC
-------------------------------------------- */
@media screen and (min-width: 751px), print {
  .sp {
    display: none;
  }

  #wrapper {
    min-width: inherit;
  }

  #bg_wrapper #wrapper2 {
    max-width: none;
  }

  nav.submenu.open {
    left: calc(50% - 500px) !important;
  }
}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  nav.submenu.open {
    left: 0 !important;
  }
}
@media screen and (min-width: 751px), print {
  .sp {
    display: none;
  }

  #bg_wrapper {
    background: linear-gradient(to bottom, #cbe4ff, #6ecdef);
    position: relative;
  }
  #bg_wrapper::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("../img/bluarc2508_texture.png");
    background-position: center top;
    background-repeat: repeat;
    mix-blend-mode: soft-light;
  }

  #wrapper2.container {
    position: relative;
    z-index: 10;
  }

  .bluearchive {
    font-size: 16px;
    margin: 0 auto;
    position: relative;
    min-height: 1220px;
  }
  .bluearchive_yokoku {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 53px;
  }
  .bluearchive_yokoku img {
    width: 75.5px;
  }
  .bluearchive_main {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 0;
    text-align: center;
  }
  .bluearchive_main_kv {
    max-width: 781px;
    width: 100%;
    margin-top: 130px;
  }
  .bluearchive_main_ex {
    max-width: 785px;
    width: 100%;
    margin-top: 110px;
  }
  .bluearchive_copy {
    margin: 140px 0 100px;
    text-align: center;
  }
}
/* SP
-------------------------------------------- */
@media screen and (max-width: 750px) {
  .pc {
    display: none;
  }

  .snsList ul {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .snsList ul li,
  .snsList ul a,
  .snsList ul img {
    display: block;
    width: 70px;
    height: 40px;
    font-size: 1em;
    line-height: 0;
    vertical-align: bottom;
  }

  #bg_wrapper {
    background: linear-gradient(to bottom, #cbe4ff, #6ecdef);
    position: relative;
  }
  #bg_wrapper::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("../img/bluarc2508_texture.png");
    background-position: center top;
    background-repeat: repeat;
    background-size: 49.2vw auto;
    mix-blend-mode: soft-light;
  }

  #wrapper2.container {
    position: relative;
    z-index: 10;
  }

  .bluearchive {
    font-size: 3.2vw;
    margin: 0 auto;
    position: relative;
  }
  .bluearchive_yokoku {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 6.6666666667vw;
  }
  .bluearchive_yokoku img {
    width: 9.6vw;
  }
  .bluearchive_main {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 0;
    text-align: center;
    line-height: 0;
    margin-bottom: 13.3333333333vw;
  }
  .bluearchive_main_kv {
    width: 93.7333333333vw;
    margin-top: 12vw;
  }
  .bluearchive_main_ex {
    width: 96vw;
    margin-top: 13.3333333333vw;
  }
  .bluearchive_copy {
    margin: 17.3333333333vw 0 13.3333333333vw;
    text-align: center;
    font-size: 2.6666666667vw;
  }
}
