@charset "UTF-8";
/*==================================================*/
/* 前提css */
/*==================================================*/
@import url("//fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap");
@import url("//fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700;900&display=swap");
@import url("//fonts.googleapis.com/css2?family=Ranchers&display=swap");
@import url("//fonts.googleapis.com/css2?family=Dela+Gothic+One&display=swap");
a, article, blockquote, body, caption, dd, div, dl, dt, footer, h1, h2, h3, h4, h5, h6, header, html, iframe, img, li, nav, ol, p, pre, section, small, span, strong, table, td, th, tr, ul, figure {
  background: 0;
  border: 0;
  font-size: 100%;
  line-height: 1;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: bottom; }

a, small, span, strong {
  vertical-align: baseline; }

article, footer, header, nav, section {
  display: block; }

li {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

address, th {
  font-style: normal; }

:focus, a:focus {
  outline: 0; }

br {
  letter-spacing: normal; }

textarea {
  resize: none; }

a {
  text-decoration: none; }

main img {
  height: auto;
  width: 100%; }

/*==================================================*/
/* レスポンシブ用css */
/*==================================================*/
.pc {
  display: block; }
  .pc.inline {
    display: inline; }
  .pc.flex {
    display: flex; }

.sp {
  display: none; }
  .sp.inline {
    display: none; }
  .sp.flex {
    display: none; }

@media (max-width: 320px) {
  .pc {
    display: none; }
    .pc.inline {
      display: none; }
    .pc.flex {
      display: none; }

  .sp {
    display: block; }
    .sp.inline {
      display: inline; }
    .sp.flex {
      display: flex; } }
* {
  font-family: 'Noto Sans JP', sans-serif; }

/* 画面全体の設定 */
img {
  height: auto;
  width: 100%; }

/* -----------------------------------------------------
   PC_menu
----------------------------------------------------- */
.globalNavi {
  font-weight: 900;
  position: relative;
  width: 100%;
  z-index: 1000; }
  .globalNavi.fix {
    position: fixed;
    top: 0; }
  @media (max-width: 768px) {
    .globalNavi {
      display: none; } }
  .globalNavi_list {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    background: rgba(0, 0, 0, 0.7);
    height: 60px;
    padding: 0 25px;
    position: fixed;
    width: 100%; }
    @media (max-width: 1280px) {
      .globalNavi_list {
        height: 4.6875vw; } }
    @media (max-width: 768px) {
      .globalNavi_list {
        background: none; } }
    .globalNavi_list li {
      color: #fff;
      font-family: "Ranchers", cursive;
      font-size: 26px;
      letter-spacing: .05em;
      text-indent: .05em;
      position: relative;
      z-index: 106;
      padding: 0;
      margin: 0; }
      @media (max-width: 1280px) {
        .globalNavi_list li {
          font-size: 1.5625vw; } }
      @media (max-width: 768px) {
        .globalNavi_list li {
          font-size: 20px;
          font-weight: bold;
          padding: 20px 0;
          box-sizing: border-box; } }
      .globalNavi_list li:nth-child(n + 2) {
        margin-left: 50px; }
        @media (max-width: 1480px) {
          .globalNavi_list li:nth-child(n + 2) {
            margin-left: 25px; } }
        @media (max-width: 768px) {
          .globalNavi_list li:nth-child(n + 2) {
            margin-left: 0; } }
      .globalNavi_list li.off {
        opacity: .3; }
      .globalNavi_list li a {
        color: #fff;
        font-family: "Ranchers", cursive;
        transition: all 0.3s; }
        .globalNavi_list li a:hover {
          color: #ffff00; }
        @media (max-width: 768px) {
          .globalNavi_list li a:hover {
            color: #fff; }
          .globalNavi_list li a:active {
            color: #ffff00; } }
      .globalNavi_list li.buy-btn {
        background: #ff0078;
        position: absolute;
        right: 20px; }
        @media (max-width: 768px) {
          .globalNavi_list li.buy-btn {
            position: static;
            right: auto;
            margin-top: 6.5104166667vw; } }
        .globalNavi_list li.buy-btn a {
          box-sizing: border-box;
          display: flex;
          align-items: center;
          font-family: "Noto Sans JP", sans-serif;
          font-weight: 800;
          font-size: 18px;
          padding: 10px 20px;
          width: 100%;
          height: 100%; }
          @media (max-width: 768px) {
            .globalNavi_list li.buy-btn a {
              padding: 0 40px; } }

/* -----------------------------------------------------
   SP_menu
----------------------------------------------------- */
.globalNavi_sp {
  display: none; }
  @media (max-width: 768px) {
    .globalNavi_sp {
      display: block; } }
  .globalNavi_sp .globalNavi_list {
    flex-direction: column;
    height: auto; }
    @media (max-width: 768px) {
      .globalNavi_sp .globalNavi_list {
        padding: 30px 0; } }
  .globalNavi_sp .globalNavi_item {
    margin-right: 0; }
  .globalNavi_sp .globalNavi_item a {
    margin: 0 auto; }

.menu-content {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 100%;
  z-index: 80;
  background-color: #000;
  transition: all 0.5s; }
  @media (max-width: 768px) {
    .menu-content {
      background: rgba(0, 0, 0, 0.9); } }

.menu-btn {
  position: fixed;
  top: 1.3020833333vw;
  right: 1.3020833333vw;
  display: flex;
  height: 11.71875vw;
  width: 11.71875vw;
  justify-content: center;
  align-items: center;
  z-index: 120;
  background: #000;
  border: 1px solid #fff; }

.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
  content: '';
  display: block;
  height: 0.390625vw;
  width: 4.6875vw;
  border-radius: 3px;
  background-color: #ffffff;
  position: absolute;
  transition: all 0.5s; }

.menu-btn span::before {
  bottom: 1.5625vw; }
.menu-btn span::after {
  top: 1.5625vw; }

#menu-btn-check {
  display: none; }

#menu-btn-check:checked ~ .menu-btn span {
  background-color: rgba(255, 255, 255, 0); }

#menu-btn-check:checked ~ .menu-btn span::before {
  bottom: 0;
  transform: rotate(45deg); }

#menu-btn-check:checked ~ .menu-btn span::after {
  top: 0;
  transform: rotate(-45deg); }

#menu-btn-check:checked ~ .menu-content {
  left: 0; }

/* -----------------------------------------------------
   common
----------------------------------------------------- */
.pc {
  display: block; }
  @media (max-width: 768px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media (max-width: 768px) {
    .sp {
      display: block; } }

/* Animation */
.fade_In {
  opacity: 0;
  transform: translate(0, 100px);
  transition: all 1s; }
  .fade_In.active {
    opacity: 1;
    transform: translate(0, 0); }

.zoomIn {
  animation-name: zoomInDown;
  animation-duration: 1.2s; }

.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: .3s; }

.cont-inr {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto; }
  .cont-inr > h2 figure {
    height: 121px;
    width: 100%;
    text-align: center; }
    @media (max-width: 1280px) {
      .cont-inr > h2 figure {
        height: 8.671875vw; } }
    @media (max-width: 768px) {
      .cont-inr > h2 figure {
        height: 14.3229166667vw; } }
    .cont-inr > h2 figure > img {
      height: 100%;
      width: auto; }

#lower h2 figure {
  height: 121px;
  width: 100%;
  text-align: center; }
  @media (max-width: 1280px) {
    #lower h2 figure {
      height: 8.671875vw; } }
  @media (max-width: 768px) {
    #lower h2 figure {
      height: 14.3229166667vw; } }
  #lower h2 figure > img {
    height: 100%;
    width: auto; }

.btn {
  margin: 80px auto 0;
  text-align: center; }
  @media (max-width: 768px) {
    .btn {
      margin: 13.0208333333vw auto 0; } }
  .btn a {
    background: #f8308a;
    border: 3px solid #000;
    border-radius: 100vh;
    box-shadow: 0 0.5208333333vw 0 #000;
    color: #fff;
    display: inline-block;
    font-family: "Dela Gothic One", cursive;
    font-size: 1.875vw;
    margin: 0 auto;
    padding: 1.3020833333vw 5.2083333333vw 1.3020833333vw 2.6041666667vw;
    position: relative;
    transition: all 0.3s; }
    @media (max-width: 768px) {
      .btn a {
        font-size: 4.6875vw;
        padding: 3.2552083333vw 13.0208333333vw 3.2552083333vw 6.5104166667vw; } }
    .btn a span.yellow {
      color: #ffff00;
      font-family: "Dela Gothic One", cursive;
      font-size: 1.875vw; }
      @media (max-width: 768px) {
        .btn a span.yellow {
          font-size: 4.6875vw; } }
    .btn a::after {
      content: "";
      position: absolute;
      background: url("../img/btn_arrow.svg") no-repeat top left;
      background-size: 100%;
      top: 50%;
      margin-top: -0.78125vw;
      height: 1.71875vw;
      width: 1.71875vw;
      right: 2.1354166667vw; }
      @media (max-width: 768px) {
        .btn a::after {
          margin-top: -1.953125vw;
          height: 4.296875vw;
          width: 4.296875vw;
          right: 5.3385416667vw; } }
    .btn a:hover {
      transform: translateY(9px);
      text-decoration: none;
      box-shadow: 0 3px 0 #000;
      transition: all 0.3s; }
      @media (max-width: 768px) {
        .btn a:hover {
          transform: translateY(0); } }
      .btn a:hover::after {
        right: 1.5625vw;
        transition: all 0.3s; }
        @media (max-width: 768px) {
          .btn a:hover::after {
            right: 5.3385416667vw; } }
    @media (max-width: 768px) {
      .btn a:active {
        transform: translateY(9px); }
        .btn a:active::after {
          right: 1.5625vw; } }

.btnArea {
  border: 2px solid #000;
  box-sizing: border-box;
  background: #333;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  position: relative;
  text-decoration: none;
  display: inline-block;
  padding: 30px 80px 30px 30px;
  text-align: center;
  outline: none;
  transition: ease .2s; }
  @media (max-width: 768px) {
    .btnArea {
      padding: 25px 80px 25px 30px; } }
  .btnArea.pnk {
    background: rgba(255, 0, 120, 0.8);
    padding: 30px 70px 30px 30px;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 900;
    font-size: 24px; }
    .btnArea.pnk.border {
      border: 1px solid #fff; }
    .btnArea.pnk:hover {
      background: #ff0078;
      transition: ease .2s; }
      @media (max-width: 768px) {
        .btnArea.pnk:hover {
          background: rgba(255, 0, 120, 0.8); } }
    @media (max-width: 768px) {
      .btnArea.pnk:active {
        transition: ease .2s;
        background: #ff0078; } }
  .btnArea.org {
    background: #ff6000; }
    .btnArea.org:hover {
      background: #ff8a43; }
      @media (max-width: 768px) {
        .btnArea.org:hover {
          background: #ff6000; } }
    @media (max-width: 768px) {
      .btnArea.org:active {
        background: #ff8a43; } }
  .btnArea.purple {
    background: #b504ff; }
    .btnArea.purple:hover {
      background: #cd55ff; }
      @media (max-width: 768px) {
        .btnArea.purple:hover {
          background: #b504ff; } }
    @media (max-width: 768px) {
      .btnArea.purple:active {
        background: #cd55ff; } }
  .btnArea.ps4 {
    font-size: 24px;
    padding: 20px 80px 20px 30px;
    background: #0072ce; }
    @media (max-width: 768px) {
      .btnArea.ps4 {
        font-size: 20px;
        text-align: left;
        width: 100%; } }
    .btnArea.ps4:hover {
      transition: ease .2s;
      background: #008afa; }
      @media (max-width: 768px) {
        .btnArea.ps4:hover {
          background: #0072ce; } }
    @media (max-width: 768px) {
      .btnArea.ps4:active {
        background: #008afa; } }
  .btnArea.ps5 {
    font-size: 24px;
    padding: 20px 80px 20px 30px;
    background: #002fc3; }
    @media (max-width: 768px) {
      .btnArea.ps5 {
        font-size: 20px;
        text-align: left;
        width: 100%; } }
    .btnArea.ps5:hover {
      transition: ease .2s;
      background: #0037e6; }
      @media (max-width: 768px) {
        .btnArea.ps5:hover {
          background: #002fc3; } }
    @media (max-width: 768px) {
      .btnArea.ps5:active {
        background: #0037e6; } }
  .btnArea.Switch {
    font-size: 24px;
    padding: 20px 80px 20px 30px;
    background: #E60012; }
    @media (max-width: 768px) {
      .btnArea.Switch {
        font-size: 20px;
        text-align: left;
        width: 100%; } }
    .btnArea.Switch:hover {
      transition: ease .2s;
      background: #FF4554; }
      @media (max-width: 768px) {
        .btnArea.Switch:hover {
          background: #FF4554; } }
    @media (max-width: 768px) {
      .btnArea.Switch:active {
        background: #FF4554; } }
  .btnArea.XboxOne {
    font-size: 24px;
    padding: 20px 80px 20px 30px;
    background: #6aa607; }
    @media (max-width: 768px) {
      .btnArea.XboxOne {
        font-size: 20px;
        text-align: left;
        width: 100%; } }
    .btnArea.XboxOne:hover {
      transition: ease .2s;
      background: #8bd80a; }
      @media (max-width: 768px) {
        .btnArea.XboxOne:hover {
          background: #6aa607; } }
    @media (max-width: 768px) {
      .btnArea.XboxOne:active {
        background: #8bd80a; } }
  .btnArea.Xbox {
    font-size: 24px;
    padding: 20px 80px 20px 30px;
    background: #107c10; }
    @media (max-width: 768px) {
      .btnArea.Xbox {
        font-size: 20px;
        text-align: left;
        width: 100%; } }
    .btnArea.Xbox:hover {
      transition: ease .2s;
      background: #19b319; }
      @media (max-width: 768px) {
        .btnArea.Xbox:hover {
          background: #107c10; } }
    @media (max-width: 768px) {
      .btnArea.Xbox:active {
        background: #19b319; } }
  .btnArea.steam {
    font-size: 24px;
    padding: 20px 80px 20px 30px;
    background: #230F5C; }
    @media (max-width: 768px) {
      .btnArea.steam {
        font-size: 20px;
        text-align: left;
        width: 100%; } }
    .btnArea.steam:hover {
      transition: ease .2s;
      background: #351592; }
      @media (max-width: 768px) {
        .btnArea.steam:hover {
          background: #230F5C; } }
    @media (max-width: 768px) {
      .btnArea.steam:active {
        background: #351592; } }
  .btnArea::after {
    content: "";
    background: url("../img/btn_arrow.svg") no-repeat;
    background-size: auto;
    position: absolute;
    top: 50%;
    margin-top: -10px;
    right: 20px;
    width: 20px;
    height: 20px;
    transition: all .3s; }
  .btnArea:hover {
    background: #555; }
    .btnArea:hover::after {
      right: 10px; }
      @media (max-width: 768px) {
        .btnArea:hover::after {
          right: 20px; } }
  @media (max-width: 768px) {
    .btnArea:active::after {
      right: 10px; } }

/* -----------------------------------------------------
   header
----------------------------------------------------- */
header {
  background: url("../img/bg_top.jpg") no-repeat top left;
  background-size: 100%;
  box-sizing: border-box;
  height: 62.2395833333vw;
  padding: 0 20px;
  position: relative; }
  @media (max-width: 1280px) {
    header {
      background-size: 100%;
      height: 62.890625vw; } }
  @media (max-width: 768px) {
    header {
      background-size: 150%; } }
  header::before {
    content: "";
    background: url("../img/news/bg_bottom.png") no-repeat bottom center;
    background-size: 100%;
    position: absolute;
    bottom: -0.1em;
    left: 0;
    height: 13.0729166667vw;
    width: 100%; }
    @media (max-width: 1280px) {
      header::before {
        height: 19.609375vw; } }
  header .top_catch {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 2;
    width: 100%;
    max-width: 37.4479166667vw; }
    @media (max-width: 1280px) {
      header .top_catch {
        max-width: 37.65625vw; } }
    @media (max-width: 768px) {
      header .top_catch {
        max-width: 55.9895833333vw; } }
  header figure {
    position: absolute;
    top: 5.8333333333vw;
    left: 0;
    width: 100%;
    max-width: 71.4583333333vw;
    z-index: 1; }
    @media (max-width: 1280px) {
      header figure {
        top: 5.703125vw;
        max-width: 71.484375vw; } }
    @media (max-width: 768px) {
      header figure {
        top: 12.7604166667vw;
        max-width: 100%; } }
  header .top_inr {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    margin: 3.90625vw 0 0 auto;
    position: absolute;
    top: 0;
    right: 20px;
    z-index: 2; }
    @media (max-width: 1280px) {
      header .top_inr {
        margin: 6.25vw 0 0 auto; } }
    @media (max-width: 768px) {
      header .top_inr {
        right: 0;
        left: 0;
        top: 65.1041666667vw;
        margin: 0;
        margin: 0 auto;
        align-items: center; } }
    header .top_inr > .spec {
      width: 100%;
      max-width: 32.3958333333vw; }
      header .top_inr > .spec.pc {
        display: block; }
      header .top_inr > .spec.sp {
        display: none; }
      @media (max-width: 1280px) {
        header .top_inr > .spec {
          max-width: 32.65625vw; } }
      @media (max-width: 768px) {
        header .top_inr > .spec {
          box-sizing: border-box;
          display: flex;
          align-items: center;
          justify-content: center;
          background: #fff;
          border-radius: 50px;
          margin: -10px auto 20px;
          padding: 10px 20px;
          max-width: 95%; }
          header .top_inr > .spec.pc {
            display: none; }
          header .top_inr > .spec.sp {
            display: block; } }
    header .top_inr h1 {
      margin-top: 1.0416666667vw;
      width: 100%;
      max-width: 30.3125vw; }
      @media (max-width: 1280px) {
        header .top_inr h1 {
          margin-top: 1.5625vw;
          max-width: 30.46875vw; } }
      @media (max-width: 768px) {
        header .top_inr h1 {
          max-width: 62.7604166667vw; } }
    header .top_inr .release {
      margin-top: -0.5208333333vw;
      width: 100%;
      max-width: 28.0729166667vw; }
      @media (max-width: 1280px) {
        header .top_inr .release {
          margin-top: -0.78125vw;
          max-width: 28.125vw; } }
      @media (max-width: 768px) {
        header .top_inr .release {
          margin-top: -1.3020833333vw;
          max-width: 72%; } }
    header .top_inr .btn_privilege {
      margin-top: 0.78125vw;
      width: 100%;
      max-width: 28.125vw;
      transition: all 0.3s; }
      header .top_inr .btn_privilege .animated:hover {
        animation-name: pulse;
        animation-duration: 1.3s;
        animation-iteration-count: infinite; }
        @media (max-width: 768px) {
          header .top_inr .btn_privilege .animated:hover {
            animation-name: none;
            animation-duration: 0; } }
      @media (max-width: 768px) {
        header .top_inr .btn_privilege .animated:active {
          animation-name: pulse;
          animation-duration: 1.3s;
          animation-iteration-count: infinite; } }
      @media (max-width: 1280px) {
        header .top_inr .btn_privilege {
          margin-top: 1.171875vw;
          max-width: 28.515625vw; } }
      @media (max-width: 768px) {
        header .top_inr .btn_privilege {
          margin-top: 10px;
          max-width: 60%; } }
    header .top_inr .movie {
      cursor: pointer;
      margin-top: 25px;
      transition: all 0.3s;
      width: 100%;
      max-width: 33.3333333333vw; }
      @media (max-width: 1280px) {
        header .top_inr .movie {
          max-width: 26.5625vw; } }
      @media (max-width: 768px) {
        header .top_inr .movie {
          margin-top: 1.3020833333vw;
          max-width: 90%; } }
      header .top_inr .movie:hover {
        opacity: .8; }
        @media (max-width: 768px) {
          header .top_inr .movie:hover {
            opacity: 1; } }
      @media (max-width: 768px) {
        header .top_inr .movie:active {
          opacity: .8; } }
  header.dlc {
    background: url("../img/dlc/bg_top.jpg") no-repeat top left;
    background-size: cover;
    margin: 0 auto;
    position: relative;
    height: auto;
    width: 100%; }
    @media (max-width: 768px) {
      header.dlc {
        padding: 0 8px; } }
    header.dlc figure {
      position: relative;
      top: 0;
      left: 0;
      right: 0;
      margin: 0 auto;
      text-align: center;
      width: 100%;
      max-width: 99.4791666667vw; }
      @media (max-width: 768px) {
        header.dlc figure {
          max-width: 100%; } }
    header.dlc h1 {
      position: absolute;
      bottom: 3.90625vw;
      left: 0;
      right: 0;
      margin: 0 auto;
      text-align: center;
      width: 100%;
      max-width: 47.7604166667vw;
      z-index: 1; }
      @media (max-width: 768px) {
        header.dlc h1 {
          bottom: 7.1614583333vw;
          max-width: 41.2760416667vw; } }
    header.dlc::before {
      display: none; }

.dlc_store_btn {
  background: url("../img/dlc/dlc_top_store-btn_bg.jpg") bottom center;
  background-size: cover;
  box-sizing: border-box;
  padding: 4.1666666667vw 0 3.125vw;
  position: relative;
  border-bottom: 1px solid #fff; }
  @media (max-width: 1280px) {
    .dlc_store_btn {
      padding: 6.25vw 0 4.6875vw; } }
  @media (max-width: 768px) {
    .dlc_store_btn {
      padding: 7.8125vw 0 7.8125vw; } }
  @media (max-width: 320px) {
    .dlc_store_btn {
      padding: 12.5vw 0 9.375vw; } }
  .dlc_store_btn h2 {
    position: absolute;
    top: -2.5vw;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    width: 100%;
    max-width: 14.9479166667vw;
    z-index: 1; }
    @media (max-width: 1280px) {
      .dlc_store_btn h2 {
        top: -3.75vw;
        max-width: 22.421875vw; } }
    @media (max-width: 768px) {
      .dlc_store_btn h2 {
        top: -6.25vw;
        max-width: 26.953125vw; } }
    @media (max-width: 320px) {
      .dlc_store_btn h2 {
        max-width: 37.5vw; } }
  .dlc_store_btn > .buy_box {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    width: 100%; }
    .dlc_store_btn > .buy_box ul {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: center;
      margin: -30px 0 0 -30px;
      width: 100%;
      max-width: 71.4583333333vw; }
      @media (max-width: 768px) {
        .dlc_store_btn > .buy_box ul {
          flex-wrap: wrap;
          justify-content: center;
          max-width: 100%;
          margin: -20px 0 0 -20px; } }
      .dlc_store_btn > .buy_box ul li {
        margin: 30px 0 0 30px; }
        @media (max-width: 768px) {
          .dlc_store_btn > .buy_box ul li {
            margin: 20px 0 0 20px; } }
        .dlc_store_btn > .buy_box ul li .btnArea {
          padding: 30px 80px 30px 30px; }
          @media (max-width: 768px) {
            .dlc_store_btn > .buy_box ul li .btnArea {
              font-size: 18px;
              padding: 20px 55px 20px 25px !important; } }
          .dlc_store_btn > .buy_box ul li .btnArea img {
            height: 1.9791666667vw;
            width: auto; }
            @media (max-width: 1280px) {
              .dlc_store_btn > .buy_box ul li .btnArea img {
                height: 2.96875vw; } }
            @media (max-width: 768px) {
              .dlc_store_btn > .buy_box ul li .btnArea img {
                height: 4.9479166667vw; } }
            @media (max-width: 320px) {
              .dlc_store_btn > .buy_box ul li .btnArea img {
                height: 6.25vw; } }

/* -----------------------------------------------------
   footer
----------------------------------------------------- */
footer {
  background: url("../img/bg_footer.jpg") no-repeat top center, #000;
  background-size: auto;
  box-sizing: border-box;
  border-top: 1px solid #fff;
  padding: 100px 25px; }
  @media (max-width: 768px) {
    footer {
      padding: 80px 20px 40px; } }
  footer > .wrap {
    display: flex;
    justify-content: center; }
    @media (max-width: 768px) {
      footer > .wrap {
        flex-wrap: wrap;
        flex-direction: column;
        align-items: center; } }
    footer > .wrap ul.sns {
      display: flex; }
      footer > .wrap ul.sns li {
        width: 80px; }
        @media (max-width: 768px) {
          footer > .wrap ul.sns li {
            width: 60px; } }
        footer > .wrap ul.sns li:nth-child(n + 2) {
          margin-left: 30px; }
    footer > .wrap ul.company {
      display: flex;
      align-items: center;
      border-left: 1px solid #222;
      box-sizing: border-box;
      margin-left: 80px;
      padding-left: 80px; }
      @media (max-width: 768px) {
        footer > .wrap ul.company {
          margin-left: 0;
          padding-left: 0;
          border-left: 0;
          justify-content: center;
          border-top: 1px solid #222;
          margin-top: 20px;
          padding-top: 20px;
          width: 100%; } }
      footer > .wrap ul.company li {
        width: 74px; }
        @media (max-width: 768px) {
          footer > .wrap ul.company li {
            width: 60px; } }
        footer > .wrap ul.company li:nth-child(2) {
          margin-left: 20px;
          width: 100%;
          max-width: 277px; }
          @media (max-width: 768px) {
            footer > .wrap ul.company li:nth-child(2) {
              margin-left: 2.6041666667vw;
              max-width: 41.6666666667vw; } }
        footer > .wrap ul.company li a {
          transition: all 0.3s; }
          footer > .wrap ul.company li a:hover {
            opacity: .6; }
            @media (max-width: 768px) {
              footer > .wrap ul.company li a:hover {
                opacity: 1; } }
          @media (max-width: 768px) {
            footer > .wrap ul.company li a:active {
              opacity: .6; } }
  footer > .inr {
    margin: 0 auto; }
    footer > .inr ul.bn {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 40px; }
      @media (max-width: 768px) {
        footer > .inr ul.bn {
          flex-wrap: wrap;
          margin: -10px 0 0 -10px;
          padding-top: 40px; } }
      @media (max-width: 768px) {
        footer > .inr ul.bn li {
          margin: 10px 0 0 10px !important;
          width: 45%; } }
      footer > .inr ul.bn li:nth-child(n + 2) {
        margin-left: 20px; }
        @media (max-width: 768px) {
          footer > .inr ul.bn li:nth-child(n + 2) {
            margin-left: 0; } }
      footer > .inr ul.bn li a {
        transition: all 0.3s; }
        footer > .inr ul.bn li a:hover {
          opacity: .6; }
          @media (max-width: 768px) {
            footer > .inr ul.bn li a:hover {
              opacity: 1; } }
        @media (max-width: 768px) {
          footer > .inr ul.bn li a:active {
            opacity: .6; } }
    footer > .inr .pf_area {
      background: #222;
      border-radius: 50px;
      box-sizing: border-box;
      width: 100%;
      max-width: 900px;
      margin: 40px auto 0;
      padding: 15px 50px; }
      footer > .inr .pf_area ul {
        display: flex;
        align-items: center;
        justify-content: center; }
        @media (max-width: 768px) {
          footer > .inr .pf_area ul {
            flex-wrap: wrap;
            margin: -10px 0 0 -10px; } }
        footer > .inr .pf_area ul li:nth-child(n + 2) {
          margin-left: 25px; }
          @media (max-width: 768px) {
            footer > .inr .pf_area ul li:nth-child(n + 2) {
              margin-left: 0; } }
        @media (max-width: 768px) {
          footer > .inr .pf_area ul li {
            margin: 10px 0 0 10px !important;
            height: 3.2552083333vw; }
            footer > .inr .pf_area ul li:nth-child(2) {
              height: 4.5572916667vw; }
            footer > .inr .pf_area ul li img {
              height: 100%;
              width: auto; } }
    footer > .inr .copy {
      width: 100%;
      margin-top: 50px; }
      footer > .inr .copy > figure {
        width: 100%;
        max-width: 970px;
        margin: 0 auto; }

/* -----------------------------------------------------
   spec
----------------------------------------------------- */
#spec {
  background: url("../img/spec/bg_bottom.png") no-repeat bottom left, url("../img/spec/bg.jpg") top center fixed;
  background-size: 100%, cover;
  box-sizing: border-box;
  padding: 100px 0 180px;
  position: relative; }
  @media (max-width: 1280px) {
    #spec {
      background-size: 120%, cover;
      padding: 14.0625vw 0 14.0625vw; } }
  @media (max-width: 768px) {
    #spec {
      background-size: 150%, cover;
      padding: 20.8333333333vw 0 20.8333333333vw; } }
  #spec.dlc {
    background: url("../img/spec/bg.jpg") top center fixed;
    background-size: cover;
    box-sizing: border-box;
    padding: 200px 0 170px; }
    @media (max-width: 1280px) {
      #spec.dlc {
        padding: 15.625vw 0 14.0625vw; } }
    @media (max-width: 768px) {
      #spec.dlc {
        padding: 20.8333333333vw 0 20.8333333333vw; } }
    #spec.dlc::before {
      content: "";
      background: url("../img/dlc/top_bg_line.png") no-repeat top center;
      background-size: cover;
      height: 186px;
      width: 100%;
      position: absolute;
      top: -115px;
      left: 0; }
      @media (max-width: 1280px) {
        #spec.dlc::before {
          background-size: cover;
          height: 14.53125vw;
          top: -4.296875vw; } }
      @media (max-width: 1024px) {
        #spec.dlc::before {
          background-size: cover;
          height: 18.1640625vw;
          top: -5.37109375vw; } }
      @media (max-width: 768px) {
        #spec.dlc::before {
          background-size: cover;
          height: 24.21875vw;
          top: -7.1614583333vw; } }
    #spec.dlc > .cont-inr .spec_inr {
      display: flex;
      flex-wrap: wrap;
      margin: 0 auto;
      position: relative;
      width: 100%;
      max-width: 62.5vw; }
      @media (max-width: 1280px) {
        #spec.dlc > .cont-inr .spec_inr {
          max-width: 78.125vw;
          justify-content: center; } }
      @media (max-width: 768px) {
        #spec.dlc > .cont-inr .spec_inr {
          flex-direction: column;
          max-width: 100%; } }
  #spec::before {
    content: "";
    background: url("../img/spec/top_bg_line.png") no-repeat top center;
    background-size: cover;
    height: 186px;
    width: 100%;
    position: absolute;
    top: -115px;
    left: 0; }
    @media (max-width: 1280px) {
      #spec::before {
        background-size: cover;
        height: 14.53125vw;
        top: -4.296875vw; } }
    @media (max-width: 1024px) {
      #spec::before {
        background-size: cover;
        height: 18.1640625vw;
        top: -5.37109375vw; } }
    @media (max-width: 768px) {
      #spec::before {
        background-size: cover;
        height: 24.21875vw;
        top: -7.1614583333vw; } }
  #spec .privilege {
    box-sizing: border-box;
    margin: 0 0 0 auto;
    padding: 20px 30px 0 0;
    width: 100%;
    max-width: 698px; }
    #spec .privilege img:hover {
      animation-name: shake-slow;
      animation-duration: 3s;
      animation-iteration-count: infinite; }
      @media (max-width: 768px) {
        #spec .privilege img:hover {
          animation-name: none;
          animation-duration: 0; } }
    @media (max-width: 1280px) {
      #spec .privilege {
        max-width: 54.53125vw; } }
    @media (max-width: 768px) {
      #spec .privilege {
        padding: 20px 15px 0 0;
        max-width: 60%; }
        #spec .privilege img:active {
          animation-name: shake-slow;
          animation-duration: 3s;
          animation-iteration-count: infinite; } }
  #spec > .cont-inr h2 {
    margin-bottom: 50px; }
    @media (max-width: 768px) {
      #spec > .cont-inr h2 {
        margin-bottom: 30px; } }
  #spec > .cont-inr #buy {
    margin-top: -40px;
    padding-top: 40px; }
    @media (max-width: 768px) {
      #spec > .cont-inr #buy {
        margin-top: 0;
        padding-top: 0; } }
    #spec > .cont-inr #buy .buy_cont {
      box-sizing: border-box;
      margin: 80px 0 100px;
      width: 100%;
      max-width: 1200px; }
      @media (max-width: 768px) {
        #spec > .cont-inr #buy .buy_cont {
          margin: 50px 0 60px; } }
      #spec > .cont-inr #buy .buy_cont.dlc {
        margin-bottom: 0; }
        @media (max-width: 768px) {
          #spec > .cont-inr #buy .buy_cont.dlc .wrap {
            max-width: 90%; } }
        #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box {
          margin: 0;
          margin: 0 auto;
          width: 100%;
          max-width: 70%; }
          @media (max-width: 768px) {
            #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box {
              max-width: 100%; } }
          #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            justify-content: center;
            text-align: center;
            margin: -30px 0 0 -30px; }
            @media (max-width: 768px) {
              #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul {
                display: flex;
                flex-wrap: wrap;
                flex-direction: row;
                align-items: center;
                justify-content: center;
                max-width: 100%;
                margin: -10px 0 0 -10px; } }
            #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li {
              margin: 30px 0 0 30px; }
              @media (max-width: 768px) {
                #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li {
                  margin: 10px 0 0 10px; } }
              #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li .btnArea {
                padding: 30px 80px 30px 30px; }
                @media (max-width: 768px) {
                  #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li .btnArea {
                    font-size: 18px;
                    padding: 20px 55px 20px 25px !important; } }
                #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li .btnArea img {
                  height: 1.9791666667vw;
                  width: auto; }
                  @media (max-width: 1280px) {
                    #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li .btnArea img {
                      height: 2.96875vw; } }
                  @media (max-width: 768px) {
                    #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li .btnArea img {
                      height: 4.9479166667vw; } }
                  @media (max-width: 320px) {
                    #spec > .cont-inr #buy .buy_cont.dlc .wrap .buy_box ul li .btnArea img {
                      height: 6.25vw; } }
      #spec > .cont-inr #buy .buy_cont h3 {
        box-sizing: border-box;
        color: #ffff00;
        font-size: 36px;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 900;
        margin-bottom: 20px;
        text-align: center;
        width: 100%; }
        @media (max-width: 768px) {
          #spec > .cont-inr #buy .buy_cont h3 {
            font-size: 24px; } }
      #spec > .cont-inr #buy .buy_cont > .wrap {
        border-top: 2px solid #fff;
        border-bottom: 2px solid #fff;
        box-sizing: border-box;
        background: #000;
        margin: 0 auto;
        padding: 40px 20px;
        width: 100%; }
        @media (max-width: 768px) {
          #spec > .cont-inr #buy .buy_cont > .wrap {
            margin: 0 auto;
            width: 93%; } }
      #spec > .cont-inr #buy .buy_cont .buy_box {
        margin-left: -30px; }
        #spec > .cont-inr #buy .buy_cont .buy_box ul {
          display: flex;
          flex-wrap: wrap;
          align-items: center;
          justify-content: center;
          margin: -30px auto 0;
          width: 100%;
          max-width: 800px; }
          @media (max-width: 768px) {
            #spec > .cont-inr #buy .buy_cont .buy_box ul {
              flex-wrap: nowrap;
              flex-direction: column;
              justify-content: flex-start;
              max-width: 100%; } }
          #spec > .cont-inr #buy .buy_cont .buy_box ul li {
            margin: 30px 0 0 30px; }
  #spec > .cont-inr > .spec_inr {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    position: relative;
    width: 100%;
    max-width: 1200px; }
    @media (max-width: 1280px) {
      #spec > .cont-inr > .spec_inr {
        justify-content: center; } }
    @media (max-width: 768px) {
      #spec > .cont-inr > .spec_inr {
        flex-direction: column; } }
    #spec > .cont-inr > .spec_inr .package_ttl {
      box-sizing: border-box;
      margin: 0 auto 30px;
      padding: 0 15px;
      text-align: center;
      width: 100%;
      max-width: 993px; }
    #spec > .cont-inr > .spec_inr:nth-child(n + 3) {
      margin-top: 40px; }
@media (max-width: 768px) and (max-width: 768px) {
  #spec > .cont-inr > .spec_inr:nth-child(n + 3) .spec_txt dl > div {
    align-items: flex-start; }
    #spec > .cont-inr > .spec_inr:nth-child(n + 3) .spec_txt dl > div:nth-child(n + 2) {
      align-items: center; } }

    #spec > .cont-inr > .spec_inr figure {
      width: 100%;
      max-width: 330px; }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr figure {
          box-sizing: border-box;
          padding-left: 15px;
          max-width: 60%; } }
    #spec > .cont-inr > .spec_inr .more_btn {
      cursor: pointer;
      position: absolute;
      right: 0;
      bottom: 105px;
      height: 217px;
      width: 332px;
      transition: all 0.3s; }
      #spec > .cont-inr > .spec_inr .more_btn .animated:hover {
        animation-name: bounce;
        animation-duration: 1.3s;
        animation-iteration-count: infinite; }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .more_btn .animated:hover {
            animation-name: none;
            animation-duration: 0; } }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr .more_btn .animated:active {
          animation-name: bounce;
          animation-duration: 1.3s;
          animation-iteration-count: infinite; } }
      @media (max-width: 1280px) {
        #spec > .cont-inr > .spec_inr .more_btn {
          right: 25px;
          bottom: 8.203125vw;
          height: 16.953125vw;
          width: 25.9375vw; } }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr .more_btn {
          right: 5px;
          top: 41.015625vw;
          bottom: auto;
          height: 28.2552083333vw;
          width: 43.2291666667vw; }
          #spec > .cont-inr > .spec_inr .more_btn:active {
            transition: all 0.3s;
            opacity: .6; } }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr .more_btn.pk {
          right: 5px;
          top: 69.6614583333vw;
          bottom: auto;
          height: 28.2552083333vw;
          width: 43.2291666667vw; } }
    #spec > .cont-inr > .spec_inr .spec_txt {
      margin-left: 40px;
      width: 100%;
      max-width: 820px; }
      @media (max-width: 1280px) {
        #spec > .cont-inr > .spec_inr .spec_txt {
          max-width: 64.0625vw; } }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr .spec_txt {
          margin-left: 0;
          margin-top: 20px;
          box-sizing: border-box;
          padding: 0 15px;
          max-width: 100%; } }
      #spec > .cont-inr > .spec_inr .spec_txt.dlc {
        margin-left: 0;
        max-width: 100%; }
        @media (max-width: 1280px) {
          #spec > .cont-inr > .spec_inr .spec_txt.dlc {
            max-width: 100%; } }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .spec_txt.dlc {
            margin: 0 auto;
            max-width: 90%; } }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .spec_txt.dlc dl > div {
            align-items: center; } }
        @media (max-width: 320px) {
          #spec > .cont-inr > .spec_inr .spec_txt.dlc dl > div {
            align-items: flex-start !important;
            flex-direction: column; }
            #spec > .cont-inr > .spec_inr .spec_txt.dlc dl > div dd {
              margin: 0;
              margin-top: 10px; } }
      #spec > .cont-inr > .spec_inr .spec_txt dl {
        color: #fff;
        box-sizing: border-box;
        width: 100%; }
        @media (max-width: 1280px) {
          #spec > .cont-inr > .spec_inr .spec_txt dl {
            padding-top: 20px; } }
        #spec > .cont-inr > .spec_inr .spec_txt dl > div {
          display: flex;
          align-items: center;
          width: 100%; }
          #spec > .cont-inr > .spec_inr .spec_txt dl > div:nth-child(n + 2) {
            margin-top: 20px; }
          @media (max-width: 768px) {
            #spec > .cont-inr > .spec_inr .spec_txt dl > div {
              align-items: flex-start; }
              #spec > .cont-inr > .spec_inr .spec_txt dl > div:nth-child(n + 3) {
                align-items: center; } }
          #spec > .cont-inr > .spec_inr .spec_txt dl > div dt {
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(254, 50, 100, 0.5);
            border: 1px solid #fff;
            box-sizing: border-box;
            font-weight: bold;
            padding: 15px;
            width: 100%;
            max-width: 150px; }
            @media (max-width: 1280px) {
              #spec > .cont-inr > .spec_inr .spec_txt dl > div dt {
                padding: 15px 10px;
                max-width: 110px; } }
            @media (max-width: 768px) {
              #spec > .cont-inr > .spec_inr .spec_txt dl > div dt {
                padding: 15px 10px;
                max-width: 110px; } }
            #spec > .cont-inr > .spec_inr .spec_txt dl > div dt.bk {
              background: rgba(34, 34, 34, 0.5); }
          #spec > .cont-inr > .spec_inr .spec_txt dl > div dd {
            font-size: 18px;
            line-height: 1.4;
            margin: -5px 0 -5px 30px;
            width: 100%; }
            @media (max-width: 768px) {
              #spec > .cont-inr > .spec_inr .spec_txt dl > div dd {
                font-size: 16px;
                box-sizing: border-box;
                margin-left: 15px; } }
            #spec > .cont-inr > .spec_inr .spec_txt dl > div dd span {
              font-size: 14px; }
      #spec > .cont-inr > .spec_inr .spec_txt .notes {
        color: #fff;
        font-size: 16px;
        margin-top: 30px;
        line-height: 1.6; }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .spec_txt .notes {
            font-size: 12px; } }
        #spec > .cont-inr > .spec_inr .spec_txt .notes strong {
          color: #ffdc19; }
    #spec > .cont-inr > .spec_inr .spec_detail {
      margin: 6.25vw auto 0;
      width: 100%;
      max-width: 62.5vw; }
      @media (max-width: 1280px) {
        #spec > .cont-inr > .spec_inr .spec_detail {
          margin: 9.375vw auto 0;
          max-width: 100%; } }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr .spec_detail {
          margin: 15.625vw auto 0;
          max-width: 90%; } }
      @media (max-width: 320px) {
        #spec > .cont-inr > .spec_inr .spec_detail {
          max-width: 90%; } }
      #spec > .cont-inr > .spec_inr .spec_detail h3 {
        background: #f5b414;
        border-radius: 60px;
        color: #000;
        font-weight: 900;
        font-family: "Noto Sans JP", sans-serif;
        font-size: 1.5625vw;
        margin: 0 auto;
        padding: 1.3020833333vw 0;
        position: relative;
        text-align: center;
        width: 14.0625vw;
        z-index: 1; }
        @media (max-width: 1280px) {
          #spec > .cont-inr > .spec_inr .spec_detail h3 {
            font-size: 2.34375vw;
            padding: 1.953125vw 0;
            width: 21.09375vw; } }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .spec_detail h3 {
            font-size: 3.6458333333vw;
            padding: 2.6041666667vw 0;
            width: 31.25vw; } }
        @media (max-width: 320px) {
          #spec > .cont-inr > .spec_inr .spec_detail h3 {
            font-size: 6.25vw;
            padding: 6.25vw 0;
            width: 56.25vw; } }
      #spec > .cont-inr > .spec_inr .spec_detail ol {
        border: 1px solid #fff;
        background: #000;
        margin-top: -2.0833333333vw;
        padding: 4.53125vw 3.125vw; }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .spec_detail ol {
            margin-top: -3.90625vw;
            padding: 10.0260416667vw 3.90625vw 6.5104166667vw; } }
        @media (max-width: 320px) {
          #spec > .cont-inr > .spec_inr .spec_detail ol {
            margin-top: -9.375vw;
            padding: 15.625vw 9.375vw 12.5vw; } }
        #spec > .cont-inr > .spec_inr .spec_detail ol li {
          list-style: disc;
          color: #fff;
          font-size: 1.25vw;
          margin-left: 20px; }
          @media (max-width: 768px) {
            #spec > .cont-inr > .spec_inr .spec_detail ol li {
              font-size: 2.6041666667vw;
              line-height: 1.6; } }
          @media (max-width: 320px) {
            #spec > .cont-inr > .spec_inr .spec_detail ol li {
              font-size: 5vw;
              line-height: 1.6; } }
          #spec > .cont-inr > .spec_inr .spec_detail ol li:nth-child(n + 2) {
            margin-top: 1.0416666667vw; }
            @media (max-width: 768px) {
              #spec > .cont-inr > .spec_inr .spec_detail ol li:nth-child(n + 2) {
                margin-top: 2.6041666667vw; } }
          #spec > .cont-inr > .spec_inr .spec_detail ol li strong {
            color: #fff; }
            #spec > .cont-inr > .spec_inr .spec_detail ol li strong.yellow {
              color: #f5b414; }
    #spec > .cont-inr > .spec_inr .pf_area {
      display: flex;
      align-items: center;
      justify-content: center;
      background: #222;
      border: 1px solid #000;
      border-radius: 50px;
      box-sizing: border-box;
      width: 100%;
      max-width: 100%;
      margin: 40px auto 0;
      padding: 15px 50px; }
      @media (max-width: 1280px) {
        #spec > .cont-inr > .spec_inr .pf_area {
          max-width: 95%; } }
      @media (max-width: 768px) {
        #spec > .cont-inr > .spec_inr .pf_area {
          flex-direction: column;
          margin: 30px auto 0; } }
      #spec > .cont-inr > .spec_inr .pf_area.pk {
        align-items: center;
        justify-content: center;
        width: auto; }
      #spec > .cont-inr > .spec_inr .pf_area > h3 {
        font-size: 20px;
        font-weight: bold;
        color: #21ecab;
        margin-right: 40px; }
        @media (max-width: 1280px) {
          #spec > .cont-inr > .spec_inr .pf_area > h3 {
            margin-right: 3.125vw; } }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .pf_area > h3 {
            font-size: 16px;
            margin-right: 0;
            margin-bottom: 15px; } }
      #spec > .cont-inr > .spec_inr .pf_area ul {
        display: flex;
        align-items: center;
        justify-content: center; }
        @media (max-width: 1280px) {
          #spec > .cont-inr > .spec_inr .pf_area ul {
            flex-wrap: wrap;
            margin: -10px 0 0 -10px !important; } }
        @media (max-width: 768px) {
          #spec > .cont-inr > .spec_inr .pf_area ul {
            align-items: stretch; } }
        #spec > .cont-inr > .spec_inr .pf_area ul li {
          height: 1.3020833333vw; }
          #spec > .cont-inr > .spec_inr .pf_area ul li:nth-child(2) {
            height: 2.6041666667vw; }
          #spec > .cont-inr > .spec_inr .pf_area ul li:nth-child(n + 2) {
            margin-left: 25px; }
            @media (max-width: 768px) {
              #spec > .cont-inr > .spec_inr .pf_area ul li:nth-child(n + 2) {
                margin-left: 0; } }
          #spec > .cont-inr > .spec_inr .pf_area ul li img {
            height: 100%;
            width: auto; }
          @media (max-width: 1280px) {
            #spec > .cont-inr > .spec_inr .pf_area ul li {
              height: 1.953125vw;
              margin: 10px 0 0 10px !important; }
              #spec > .cont-inr > .spec_inr .pf_area ul li:nth-child(2) {
                height: 2.96875vw; } }
          @media (max-width: 768px) {
            #spec > .cont-inr > .spec_inr .pf_area ul li {
              height: 3.2552083333vw;
              margin: 10px 0 0 10px !important; }
              #spec > .cont-inr > .spec_inr .pf_area ul li:nth-child(2) {
                height: 4.9479166667vw; } }

/* -----------------------------------------------------
   story
----------------------------------------------------- */
#story {
  background: url("../img/story/top_bg.jpg") no-repeat top center, url("../img/story/bottom_bg.jpg") no-repeat bottom center, #fdfde4;
  background-size: 100%, 100%;
  box-sizing: border-box;
  position: relative;
  padding: 60px 0 130px; }
  @media (max-width: 768px) {
    #story {
      padding: 13.0208333333vw 0 16.9270833333vw; } }
  #story::before {
    content: "";
    background: url("../img/story/bg_sticker_left.png") no-repeat left top;
    background-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    height: 20.3645833333vw;
    width: 30.78125vw;
    z-index: 1; }
    @media (max-width: 1280px) {
      #story::before {
        height: 20.15625vw;
        width: 30.546875vw; } }
    @media (max-width: 768px) {
      #story::before {
        height: 29.6875vw;
        width: 44.4010416667vw; } }
  #story::after {
    content: "";
    background: url("../img/story/bg_sticker_right.png") no-repeat right top;
    background-size: 100%;
    position: absolute;
    top: 0;
    right: 0;
    height: 17.9166666667vw;
    width: 31.40625vw;
    z-index: 1; }
    @media (max-width: 1280px) {
      #story::after {
        height: 17.890625vw;
        width: 30.703125vw; } }
    @media (max-width: 768px) {
      #story::after {
        height: 25.9114583333vw;
        width: 45.9635416667vw; } }
  #story > .cont-inr {
    width: 100%;
    max-width: 1475px; }
    @media (max-width: 1280px) {
      #story > .cont-inr {
        box-sizing: border-box;
        padding: 0 15px; } }
    #story > .cont-inr h2 {
      margin: 0 auto 40px;
      width: 100%;
      max-width: 47.7604166667vw; }
      @media (max-width: 1280px) {
        #story > .cont-inr h2 {
          max-width: 45.859375vw; } }
      @media (max-width: 768px) {
        #story > .cont-inr h2 {
          max-width: 58.59375vw;
          margin: 0 auto 3.90625vw; } }
    #story > .cont-inr .story-wrap {
      border: 8px solid #f4f57a;
      box-sizing: border-box;
      background: #fff;
      border-radius: 40px;
      padding: 50px 0 100px; }
      @media (max-width: 768px) {
        #story > .cont-inr .story-wrap {
          border: 4px solid #f4f57a;
          padding: 30px 0 50px; } }
      #story > .cont-inr .story-wrap::before {
        content: "";
        background: url("../img/story/bg_misako_left.png") no-repeat left top;
        background-size: 100%;
        position: absolute;
        top: 15.1041666667vw;
        left: 0;
        height: 35.2083333333vw;
        width: 27.6041666667vw;
        z-index: 2; }
        @media (max-width: 1280px) {
          #story > .cont-inr .story-wrap::before {
            top: 18.75vw;
            height: 38.75vw;
            width: 27.34375vw; } }
        @media (max-width: 768px) {
          #story > .cont-inr .story-wrap::before {
            background: url("../img/story/bg_misako_left.png") no-repeat right top;
            background-size: cover;
            top: 28.515625vw;
            height: 41.1458333333vw;
            width: 20.8333333333vw; } }
      #story > .cont-inr .story-wrap::after {
        content: "";
        background: url("../img/story/bg_kyoko_right.png") no-repeat right top;
        background-size: 100%;
        position: absolute;
        top: 12.2395833333vw;
        right: 0;
        height: 38.6979166667vw;
        width: 24.4791666667vw;
        z-index: 2; }
        @media (max-width: 1280px) {
          #story > .cont-inr .story-wrap::after {
            top: 14.453125vw;
            height: 45.546875vw;
            width: 24.21875vw; } }
        @media (max-width: 768px) {
          #story > .cont-inr .story-wrap::after {
            background: url("../img/story/bg_kyoko_right.png") no-repeat left top;
            background-size: cover;
            top: 21.484375vw;
            height: 49.8697916667vw;
            width: 18.2291666667vw; } }
      #story > .cont-inr .story-wrap > .story_point {
        background: url("../img/story/bg_story_point.png") no-repeat center;
        background-size: 100%;
        box-sizing: border-box;
        padding: 0 128px; }
        @media (max-width: 768px) {
          #story > .cont-inr .story-wrap > .story_point {
            background: url("../img/story/bg_story_point.png") no-repeat center;
            background-size: cover;
            padding: 0 30px; } }
        #story > .cont-inr .story-wrap > .story_point:nth-child(n + 2) {
          margin-top: 70px; }
          @media (max-width: 768px) {
            #story > .cont-inr .story-wrap > .story_point:nth-child(n + 2) {
              margin-top: 9.1145833333vw; } }
        #story > .cont-inr .story-wrap > .story_point h3 {
          margin: 0 auto;
          width: 100%;
          max-width: 610px; }
          @media (max-width: 768px) {
            #story > .cont-inr .story-wrap > .story_point h3 {
              max-width: 66.40625vw; } }
        #story > .cont-inr .story-wrap > .story_point .txt {
          box-sizing: border-box;
          color: #333;
          font-size: 24px;
          font-weight: bold;
          margin: -7px 0;
          padding: 50px 0;
          line-height: 1.6;
          text-align: center; }
          @media (max-width: 768px) {
            #story > .cont-inr .story-wrap > .story_point .txt {
              font-size: 16px;
              text-align: left;
              padding: 30px 0; } }
        #story > .cont-inr .story-wrap > .story_point ol {
          display: flex;
          justify-content: center; }
          @media (max-width: 768px) {
            #story > .cont-inr .story-wrap > .story_point ol {
              flex-direction: column;
              align-items: center; } }
          #story > .cont-inr .story-wrap > .story_point ol li {
            border: 1px solid #fff;
            cursor: pointer;
            width: 100%;
            max-width: 576px;
            transition: all 0.3s; }
            #story > .cont-inr .story-wrap > .story_point ol li:nth-child(n + 2) {
              margin-left: 55px; }
              @media (max-width: 768px) {
                #story > .cont-inr .story-wrap > .story_point ol li:nth-child(n + 2) {
                  margin-left: 0;
                  margin-top: 20px; } }
            #story > .cont-inr .story-wrap > .story_point ol li:hover {
              transition: all 0.3s;
              opacity: .6; }

/* -----------------------------------------------------
   character
----------------------------------------------------- */
#character {
  border-top: 15px solid #000;
  background: url("../img/chara/bg.jpg") top center fixed;
  background-size: 100%;
  box-sizing: border-box;
  padding: 120px 0 220px;
  position: relative; }
  @media (max-width: 1280px) {
    #character {
      padding: 10.9375vw 0 12.5vw; } }
  @media (max-width: 1024px) {
    #character {
      border-top: 8px solid #000;
      padding: 13.671875vw 0 15.625vw; } }
  @media (max-width: 768px) {
    #character {
      border-top: 8px solid #000;
      padding: 20.8333333333vw 0 23.4375vw; } }
  #character::before {
    content: "";
    background: url(../img/chara/left_sticker_chara.png) no-repeat;
    background-size: 100%;
    height: 100%;
    max-height: 411px;
    width: 100%;
    max-width: 548px;
    position: absolute;
    top: -180px;
    left: 0;
    z-index: 1; }
    @media (max-width: 1280px) {
      #character::before {
        max-height: 28.984375vw;
        max-width: 39.6875vw;
        top: -14.0625vw; } }
    @media (max-width: 768px) {
      #character::before {
        max-height: 29.6875vw;
        max-width: 40.3645833333vw;
        top: -14.9739583333vw; } }
  #character::after {
    content: "";
    background: url(../img/chara/right_sticker_chara.png) no-repeat;
    background-size: 100%;
    height: 100%;
    max-height: 411px;
    width: 100%;
    max-width: 548px;
    position: absolute;
    top: -185px;
    right: 0;
    z-index: 1; }
    @media (max-width: 1280px) {
      #character::after {
        max-height: 26.640625vw;
        max-width: 37.34375vw;
        top: -14.453125vw; } }
    @media (max-width: 768px) {
      #character::after {
        max-height: 30.859375vw;
        max-width: 45.8333333333vw;
        top: -18.8802083333vw; } }
  #character > .cont-inr h2 {
    margin-bottom: 60px; }
    @media (max-width: 768px) {
      #character > .cont-inr h2 {
        margin-bottom: 40px; } }
  #character > .cont-inr .chara_inr {
    display: flex;
    justify-content: center; }
    @media (max-width: 768px) {
      #character > .cont-inr .chara_inr {
        flex-direction: column;
        align-items: center; } }
    #character > .cont-inr .chara_inr .chara_wrap {
      width: 100%;
      max-width: 563px;
      position: relative; }
      @media (max-width: 1280px) {
        #character > .cont-inr .chara_inr .chara_wrap {
          max-width: 43.984375vw; } }
      @media (max-width: 768px) {
        #character > .cont-inr .chara_inr .chara_wrap {
          max-width: 563px; } }
      #character > .cont-inr .chara_inr .chara_wrap:nth-child(n + 2) {
        margin-left: 50px; }
        @media (max-width: 1280px) {
          #character > .cont-inr .chara_inr .chara_wrap:nth-child(n + 2) {
            margin-left: 1.5625vw; } }
        @media (max-width: 768px) {
          #character > .cont-inr .chara_inr .chara_wrap:nth-child(n + 2) {
            margin-left: 0;
            margin-top: 50px; } }
      #character > .cont-inr .chara_inr .chara_wrap.new::before {
        content: "";
        background: url(../img/chara/chara_new_icon.png) no-repeat;
        background-size: 100%;
        width: 100%;
        max-height: 75px;
        height: 100%;
        max-width: 75px;
        position: absolute;
        top: -15px;
        left: 5px;
        z-index: 1; }
        @media (max-width: 1280px) {
          #character > .cont-inr .chara_inr .chara_wrap.new::before {
            max-height: 5.859375vw;
            max-width: 5.859375vw; } }
        @media (max-width: 768px) {
          #character > .cont-inr .chara_inr .chara_wrap.new::before {
            max-height: 9.765625vw;
            max-width: 9.765625vw;
            top: -5px;
            left: 25px; } }
      @media (max-width: 768px) {
        #character > .cont-inr .chara_inr .chara_wrap > figure {
          margin: 0 0 0 auto;
          width: 95%; } }
      #character > .cont-inr .chara_inr .chara_wrap .txt {
        position: relative;
        margin: -80px auto 0;
        z-index: 1;
        box-sizing: border-box;
        background: rgba(0, 0, 0, 0.95);
        border: 1px solid #f9ff5a;
        color: #fff;
        font-size: 16px;
        padding: 45px 10px;
        line-height: 2;
        text-align: center;
        width: 100%;
        max-width: 452px; }
        @media (max-width: 1280px) {
          #character > .cont-inr .chara_inr .chara_wrap .txt {
            max-width: 35.3125vw; } }
        @media (max-width: 1024px) {
          #character > .cont-inr .chara_inr .chara_wrap .txt {
            padding: 20px;
            text-align: left; } }
        @media (max-width: 768px) {
          #character > .cont-inr .chara_inr .chara_wrap .txt {
            max-width: 95%; } }
        #character > .cont-inr .chara_inr .chara_wrap .txt > strong {
          color: #ff0078; }

/* -----------------------------------------------------
   system
----------------------------------------------------- */
#system {
  background: url("../img/system/top_bg.jpg") no-repeat top center, url("../img/system/bottom_bg.jpg") no-repeat bottom center, #0f0c20;
  background-size: 100%, 100%;
  box-sizing: border-box;
  padding: 220px 0 200px;
  position: relative; }
  @media (max-width: 1280px) {
    #system {
      padding: 17.1875vw 0 15.625vw; } }
  @media (max-width: 768px) {
    #system {
      padding: 16.9270833333vw 0 18.2291666667vw; } }
  #system::before {
    content: "";
    background: url("../img/system/top_bg_line.png") no-repeat top center;
    background-size: cover;
    height: 186px;
    width: 100%;
    position: absolute;
    top: -105px;
    left: 0; }
    @media (max-width: 1280px) {
      #system::before {
        background-size: cover;
        height: 14.53125vw;
        top: -4.296875vw; } }
    @media (max-width: 1024px) {
      #system::before {
        background-size: cover;
        height: 18.1640625vw;
        top: -9.27734375vw; } }
    @media (max-width: 768px) {
      #system::before {
        background-size: cover;
        height: 24.21875vw;
        top: -16.9270833333vw; } }
  #system > .cont-inr h2 {
    margin-bottom: 90px; }
    @media (max-width: 768px) {
      #system > .cont-inr h2 {
        margin-bottom: 40px; } }
  #system > .cont-inr .system_wrap {
    position: relative;
    width: 100%; }
    @media (max-width: 1280px) {
      #system > .cont-inr .system_wrap {
        box-sizing: border-box;
        padding: 0 10px; } }
    @media (max-width: 768px) {
      #system > .cont-inr .system_wrap {
        padding: 0; } }
    #system > .cont-inr .system_wrap.Left {
      display: -webkit-flex;
      display: flex; }
      @media (max-width: 768px) {
        #system > .cont-inr .system_wrap.Left {
          display: block; } }
      #system > .cont-inr .system_wrap.Left:nth-child(n + 2) {
        margin-top: 100px; }
        @media (max-width: 768px) {
          #system > .cont-inr .system_wrap.Left:nth-child(n + 2) {
            margin-top: 0; } }
      #system > .cont-inr .system_wrap.Left > .inr {
        position: absolute;
        top: 50%;
        right: 0;
        transform: translate(0, -50%);
        -webkit-transform: translate(0, -50%);
        -ms-transform: translate(0, -50%); }
        @media (max-width: 1280px) {
          #system > .cont-inr .system_wrap.Left > .inr {
            right: 10px; } }
        @media (max-width: 768px) {
          #system > .cont-inr .system_wrap.Left > .inr {
            position: static;
            top: 0;
            right: 0;
            transform: translate(0);
            -webkit-transform: translate(0);
            -ms-transform: translate(0); } }
    #system > .cont-inr .system_wrap.Right {
      margin-top: 100px; }
      @media (max-width: 768px) {
        #system > .cont-inr .system_wrap.Right {
          margin-top: 50px; } }
      #system > .cont-inr .system_wrap.Right figure {
        width: 100%;
        max-width: 576px;
        margin: 0 0 0 auto; }
        @media (max-width: 768px) {
          #system > .cont-inr .system_wrap.Right figure {
            width: 100%;
            max-width: 95%;
            margin: 0 auto; } }
      #system > .cont-inr .system_wrap.Right > .inr {
        position: absolute;
        top: 50%;
        letf: 0;
        transform: translate(0, -50%);
        -webkit-transform: translate(0, -50%);
        -ms-transform: translate(0, -50%); }
        @media (max-width: 768px) {
          #system > .cont-inr .system_wrap.Right > .inr {
            position: static;
            top: 0;
            transform: translate(0);
            -webkit-transform: translate(0);
            -ms-transform: translate(0); } }
    #system > .cont-inr .system_wrap figure {
      border: 1px solid #222;
      width: 100%;
      max-width: 576px; }
      @media (max-width: 768px) {
        #system > .cont-inr .system_wrap figure {
          width: 100%;
          max-width: 95%;
          margin: 0 auto; } }
    #system > .cont-inr .system_wrap > .inr {
      background: rgba(0, 0, 0, 0.8);
      box-sizing: border-box;
      padding: 20px;
      width: 100%;
      max-width: 670px; }
      @media (max-width: 1280px) {
        #system > .cont-inr .system_wrap > .inr {
          max-width: 52.34375vw; } }
      @media (max-width: 768px) {
        #system > .cont-inr .system_wrap > .inr {
          margin: -10px auto 0;
          max-width: 90%; } }
      #system > .cont-inr .system_wrap > .inr h3 {
        height: 40px;
        margin-bottom: 40px;
        width: auto; }
        @media (max-width: 1280px) {
          #system > .cont-inr .system_wrap > .inr h3 {
            height: 2.96875vw;
            margin-bottom: 3.125vw; } }
        @media (max-width: 768px) {
          #system > .cont-inr .system_wrap > .inr h3 {
            height: 4.5572916667vw;
            margin-bottom: 20px; } }
        #system > .cont-inr .system_wrap > .inr h3 img {
          height: 100%;
          width: auto; }
      #system > .cont-inr .system_wrap > .inr .txt {
        color: #fff;
        font-size: 16px;
        margin: -7px 0;
        line-height: 2; }
        #system > .cont-inr .system_wrap > .inr .txt strong {
          color: #77ffd3; }

/* -----------------------------------------------------
   other
----------------------------------------------------- */
#other {
  box-sizing: border-box;
  background: #111;
  border-top: 1px solid #000;
  padding: 80px 0; }
  #other > .cont-inr {
    display: flex;
    justify-content: center; }
    @media (max-width: 768px) {
      #other > .cont-inr {
        flex-direction: column; } }
    @media (max-width: 768px) {
      #other > .cont-inr a {
        margin: 0 auto;
        width: 90%; } }
    #other > .cont-inr a:nth-child(2) {
      margin-left: 40px; }
      @media (max-width: 768px) {
        #other > .cont-inr a:nth-child(2) {
          margin: 0 auto;
          margin-top: 30px; } }

/* -----------------------------------------------------
   lower - 下層ページ
----------------------------------------------------- */
#lower {
  /* -----------------------------------------------------
     character
  ----------------------------------------------------- */
  /* -----------------------------------------------------
     story
  ----------------------------------------------------- */
  /* -----------------------------------------------------
     movie
  ----------------------------------------------------- */
  /* -----------------------------------------------------
     system
  ----------------------------------------------------- */
  /* -----------------------------------------------------
     special
  ----------------------------------------------------- */ }
  #lower_character {
    background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/chara/bg.jpg") repeat top center fixed;
    background-size: 100%, 100%;
    box-sizing: border-box;
    padding: 14.0625vw 0 6.25vw; }
    @media (max-width: 768px) {
      #lower_character {
        background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/chara/bg.jpg") repeat-y top center;
        background-size: contain, 100%;
        padding: 80px 0 80px; } }
    #lower_character .character_wrap .chara_content {
      background: url("../img/chara/chara_cont_bg.png") no-repeat top left;
      background-size: 100%;
      background-position: 50% 0;
      box-sizing: border-box;
      margin-top: 60px; }
      @media (max-width: 1024px) {
        #lower_character .character_wrap .chara_content {
          background: url("../img/chara/chara_cont_bg.png") no-repeat top right;
          background-position: 50% 50%;
          background-size: cover; } }
      @media (max-width: 768px) {
        #lower_character .character_wrap .chara_content {
          background: url("../img/chara/chara_cont_bg.png") no-repeat top right;
          background-position: 50% 50%;
          background-size: cover; } }
      #lower_character .character_wrap .chara_content > h3 {
        box-sizing: border-box;
        margin: 0 auto;
        padding-left: 6.5104166667vw;
        position: relative;
        width: 100%;
        max-width: 72.9166666667vw; }
        @media (max-width: 1024px) {
          #lower_character .character_wrap .chara_content > h3 {
            padding-left: 12.20703125vw;
            max-width: 136.71875vw; } }
        @media (max-width: 768px) {
          #lower_character .character_wrap .chara_content > h3 {
            padding-left: 16.2760416667vw;
            max-width: 100%; } }
        #lower_character .character_wrap .chara_content > h3.pb {
          padding-top: 30px;
          margin: 0 auto 65px; }
          @media (max-width: 768px) {
            #lower_character .character_wrap .chara_content > h3.pb {
              margin: 0 auto 35px; } }
          #lower_character .character_wrap .chara_content > h3.pb::before {
            content: "";
            background: url("../img/chara/ttl_icon_playable.png") no-repeat top left;
            background-size: 100%;
            height: 3.8020833333vw;
            width: 100%;
            max-width: 3.59375vw;
            position: absolute;
            left: 1.4583333333vw;
            top: 50%;
            margin-top: -1.3541666667vw; }
            @media (max-width: 1024px) {
              #lower_character .character_wrap .chara_content > h3.pb::before {
                height: 7.12890625vw;
                max-width: 6.73828125vw;
                left: 2.734375vw;
                margin-top: -2.5390625vw; } }
            @media (max-width: 768px) {
              #lower_character .character_wrap .chara_content > h3.pb::before {
                height: 9.5052083333vw;
                max-width: 8.984375vw;
                left: 3.6458333333vw;
                margin-top: -3.3854166667vw; } }
        #lower_character .character_wrap .chara_content > h3.boss {
          padding-top: 30px;
          margin: 0 auto 65px; }
          @media (max-width: 768px) {
            #lower_character .character_wrap .chara_content > h3.boss {
              margin: 0 auto 35px; } }
          #lower_character .character_wrap .chara_content > h3.boss::before {
            content: "";
            background: url("../img/chara/ttl_icon_boss.png") no-repeat top left;
            background-size: 100%;
            height: 4.0104166667vw;
            width: 100%;
            max-width: 3.1770833333vw;
            position: absolute;
            left: 1.4583333333vw;
            top: 50%;
            margin-top: -1.0416666667vw; }
            @media (max-width: 1024px) {
              #lower_character .character_wrap .chara_content > h3.boss::before {
                height: 7.51953125vw;
                max-width: 5.95703125vw;
                left: 2.734375vw;
                margin-top: -1.953125vw; } }
            @media (max-width: 768px) {
              #lower_character .character_wrap .chara_content > h3.boss::before {
                height: 10.0260416667vw;
                max-width: 7.9427083333vw;
                left: 3.6458333333vw;
                margin-top: -2.6041666667vw; } }
        #lower_character .character_wrap .chara_content > h3.other {
          padding-top: 30px;
          margin: 0 auto 65px; }
          @media (max-width: 768px) {
            #lower_character .character_wrap .chara_content > h3.other {
              margin: 0 auto 35px; } }
          #lower_character .character_wrap .chara_content > h3.other::before {
            content: "";
            background: url("../img/chara/ttl_icon_other.png") no-repeat top left;
            background-size: 100%;
            height: 4.0104166667vw;
            width: 100%;
            max-width: 3.1770833333vw;
            position: absolute;
            left: 1.4583333333vw;
            top: 50%;
            margin-top: -1.0416666667vw; }
            @media (max-width: 1024px) {
              #lower_character .character_wrap .chara_content > h3.other::before {
                height: 7.51953125vw;
                max-width: 5.95703125vw;
                left: 2.734375vw;
                margin-top: -1.953125vw; } }
            @media (max-width: 768px) {
              #lower_character .character_wrap .chara_content > h3.other::before {
                height: 10.0260416667vw;
                max-width: 7.9427083333vw;
                left: 3.6458333333vw;
                margin-top: -2.6041666667vw; } }
        #lower_character .character_wrap .chara_content > h3 figure {
          height: 2.0833333333vw; }
          @media (max-width: 1024px) {
            #lower_character .character_wrap .chara_content > h3 figure {
              height: 3.90625vw; } }
          @media (max-width: 768px) {
            #lower_character .character_wrap .chara_content > h3 figure {
              height: 5.2083333333vw; } }
          #lower_character .character_wrap .chara_content > h3 figure img {
            height: 100%;
            width: auto; }
      #lower_character .character_wrap .chara_content .chara-wrap {
        display: flex;
        justify-content: center; }
        #lower_character .character_wrap .chara_content .chara-wrap .chara-list {
          display: flex;
          justify-content: center;
          flex-wrap: wrap;
          margin: -40px 0 0 -4px;
          width: 100%;
          max-width: 1440px; }
          @media (max-width: 1024px) {
            #lower_character .character_wrap .chara_content .chara-wrap .chara-list {
              max-width: 100%; } }
          @media (max-width: 768px) {
            #lower_character .character_wrap .chara_content .chara-wrap .chara-list {
              max-width: 100%; } }
          #lower_character .character_wrap .chara_content .chara-wrap .chara-list li {
            position: relative;
            cursor: pointer;
            margin-top: 40px;
            margin-left: 4px;
            width: 100%;
            max-width: 11.9791666667vw; }
            #lower_character .character_wrap .chara_content .chara-wrap .chara-list li.new::before {
              content: "";
              background: url("../img/chara/chara_new_icon.png") no-repeat top left;
              background-size: 100%;
              position: absolute;
              height: 3.90625vw;
              width: 100%;
              max-width: 3.90625vw;
              top: -1.0416666667vw;
              left: 0;
              z-index: 1; }
              @media (max-width: 768px) {
                #lower_character .character_wrap .chara_content .chara-wrap .chara-list li.new::before {
                  height: 7.8125vw;
                  max-width: 7.8125vw;
                  top: -2.6041666667vw; } }
            #lower_character .character_wrap .chara_content .chara-wrap .chara-list li > img {
              width: 11.9791666667vw; }
              @media (max-width: 1024px) {
                #lower_character .character_wrap .chara_content .chara-wrap .chara-list li > img {
                  width: 15.625vw; } }
              @media (max-width: 768px) {
                #lower_character .character_wrap .chara_content .chara-wrap .chara-list li > img {
                  width: 20.8333333333vw; } }
            @media (max-width: 1024px) {
              #lower_character .character_wrap .chara_content .chara-wrap .chara-list li {
                max-width: 15.625vw; } }
            @media (max-width: 768px) {
              #lower_character .character_wrap .chara_content .chara-wrap .chara-list li {
                max-width: 20.8333333333vw; } }
  #lower_story {
    background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/story/bg.jpg") repeat-y top left;
    background-size: 100%, 100%;
    box-sizing: border-box;
    padding: 14.0625vw 0 6.25vw; }
    @media (max-width: 768px) {
      #lower_story {
        padding: 80px 0 80px; } }
    #lower_story .story_inr {
      margin-top: 70px;
      position: relative;
      padding-bottom: 8.8541666667vw; }
      @media (max-width: 768px) {
        #lower_story .story_inr {
          margin-top: 30px;
          padding-bottom: 100px; } }
      #lower_story .story_inr > .txt {
        margin: 0 auto;
        width: 100%;
        max-width: 33.1770833333vw;
        position: relative;
        z-index: 2; }
        @media (max-width: 768px) {
          #lower_story .story_inr > .txt {
            max-width: 65%; } }
        #lower_story .story_inr > .txt > img {
          position: relative;
          z-index: 2; }
        #lower_story .story_inr > .txt::before {
          content: "";
          background: url("../img/story/lower_bg_kyoko_left.png") no-repeat left top;
          background-size: 100%;
          height: 41.0416666667vw;
          width: 100%;
          max-width: 22.03125vw;
          position: absolute;
          left: -19.2708333333vw;
          top: -9.8958333333vw;
          z-index: 1; }
          @media (max-width: 768px) {
            #lower_story .story_inr > .txt::before {
              top: 75px;
              left: -20%; } }
        #lower_story .story_inr > .txt::after {
          content: "";
          background: url("../img/story/lower_bg_misako_right.png") no-repeat left top;
          background-size: 100%;
          height: 30.8854166667vw;
          width: 100%;
          max-width: 21.1979166667vw;
          position: absolute;
          right: -19.1666666667vw;
          top: -5.7291666667vw;
          z-index: 1; }
          @media (max-width: 768px) {
            #lower_story .story_inr > .txt::after {
              top: -52px;
              right: -20%; } }
    #lower_story .rcg_inr h3 {
      box-sizing: border-box;
      margin: -4.1666666667vw auto 0;
      padding: 0 80px;
      width: 100%;
      max-width: 850px; }
      @media (max-width: 768px) {
        #lower_story .rcg_inr h3 {
          margin: -80px auto 0;
          padding: 0;
          max-width: 65%; } }
    #lower_story .rcg_inr .txt {
      margin: 20px auto 0;
      width: 100%;
      max-width: 575px; }
      @media (max-width: 768px) {
        #lower_story .rcg_inr .txt {
          max-width: 72%; } }
    #lower_story .rcg_inr p.ttl {
      margin: 50px auto 30px;
      text-align: center; }
      @media (max-width: 768px) {
        #lower_story .rcg_inr p.ttl {
          margin: 40px auto 30px; } }
      #lower_story .rcg_inr p.ttl span {
        box-sizing: border-box;
        background: #000;
        border-radius: 100vh;
        color: #ffff00;
        display: inline-block;
        font-size: 20px;
        font-weight: bold;
        margin: 0 auto;
        padding: 20px 0;
        width: 100%;
        max-width: 320px;
        text-align: center; }
        @media (max-width: 768px) {
          #lower_story .rcg_inr p.ttl span {
            font-size: 16px;
            max-width: 41.6666666667vw;
            padding: 15px 0; } }
    #lower_story .rcg_inr .bn {
      display: flex;
      justify-content: center; }
      @media (max-width: 768px) {
        #lower_story .rcg_inr .bn {
          align-items: center;
          flex-direction: column; } }
      #lower_story .rcg_inr .bn li {
        height: 100px; }
        @media (max-width: 768px) {
          #lower_story .rcg_inr .bn li {
            height: 50px; } }
        #lower_story .rcg_inr .bn li > a img {
          height: 100%;
          width: auto; }
        #lower_story .rcg_inr .bn li:nth-child(n + 2) {
          margin-left: 1.5625vw; }
          @media (max-width: 768px) {
            #lower_story .rcg_inr .bn li:nth-child(n + 2) {
              margin-left: 0;
              margin-top: 20px; } }
        #lower_story .rcg_inr .bn li:hover {
          transition: all 0.3s;
          opacity: .6; }
          @media (max-width: 768px) {
            #lower_story .rcg_inr .bn li:hover {
              opacity: 1; } }
        @media (max-width: 768px) {
          #lower_story .rcg_inr .bn li:active {
            transition: all 0.3s;
            opacity: .6; } }
  #lower #movie {
    background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/movie/bg.jpg") repeat-y top left;
    background-size: 100%, 100%;
    box-sizing: border-box;
    padding: 14.0625vw 0 6.25vw; }
    @media (max-width: 768px) {
      #lower #movie {
        padding: 80px 0 80px; } }
    #lower #movie .movie_area {
      box-sizing: border-box;
      margin: 50px auto 0;
      width: 100%;
      max-width: 1000px; }
      @media (max-width: 768px) {
        #lower #movie .movie_area {
          margin-top: 30px; } }
    #lower #movie .movie_wrap {
      display: flex;
      justify-content: center;
      flex-flow: wrap;
      margin: -4.1666666667vw 0 0 -2.0833333333vw; }
      @media (max-width: 768px) {
        #lower #movie .movie_wrap {
          margin: -10.4166666667vw 0 0 -5.2083333333vw; } }
    #lower #movie .video {
      cursor: pointer;
      margin: 4.1666666667vw 0 0 2.0833333333vw;
      width: 100%;
      max-width: 25vw;
      position: relative; }
      @media (max-width: 768px) {
        #lower #movie .video {
          margin: 10.4166666667vw 0 0 5.2083333333vw;
          max-width: 62.5vw; } }
      #lower #movie .video.new::after {
        content: "";
        background: url("../img/movie/movie_new_icon.png") no-repeat left;
        background-size: 100%;
        height: 100%;
        max-height: 2.4479166667vw;
        width: 100%;
        max-width: 5.2083333333vw;
        top: 1.0416666667vw;
        left: -0.6770833333vw;
        position: absolute; }
        @media (max-width: 768px) {
          #lower #movie .video.new::after {
            max-height: 6.1197916667vw;
            max-width: 13.0208333333vw;
            top: 2.6041666667vw;
            left: -1.6927083333vw; } }
      #lower #movie .video::before {
        content: "";
        background: url("../img/movie/movie_thumb_icon.png") no-repeat top left;
        background-size: 100%;
        height: 100%;
        max-height: 6.09375vw;
        width: 100%;
        max-width: 6.6666666667vw;
        top: 50%;
        right: 0;
        left: 0;
        margin: -3.6458333333vw auto;
        position: absolute; }
        @media (max-width: 768px) {
          #lower #movie .video::before {
            margin-top: -9.1145833333vw;
            max-height: 15.234375vw;
            max-width: 16.6666666667vw; } }
      #lower #movie .video > img {
        box-sizing: border-box;
        border: 5px solid #fff; }
        @media (max-width: 768px) {
          #lower #movie .video > img {
            border: 3px solid #fff; } }
      #lower #movie .video p {
        box-sizing: border-box;
        color: #fff;
        font-family: "Dela Gothic One", cursive;
        font-size: 20px;
        padding-top: 20px;
        text-align: center;
        width: 100%; }
        @media (max-width: 768px) {
          #lower #movie .video p {
            font-size: 18px; } }
      #lower #movie .video:hover > img {
        border: 5px solid #ffff00;
        transition: all 0.3s;
        opacity: .8; }
        @media (max-width: 768px) {
          #lower #movie .video:hover > img {
            border: 3px solid #fff; } }
        @media (max-width: 768px) {
          #lower #movie .video:hover > img {
            opacity: 1; } }
      #lower #movie .video:hover::before {
        transition: all 0.3s;
        opacity: .6;
        z-index: 1; }
        @media (max-width: 768px) {
          #lower #movie .video:hover::before {
            opacity: 1; } }
      @media (max-width: 768px) {
        #lower #movie .video:active > img {
          border: 3px solid #ffff00;
          transition: all 0.3s;
          opacity: .8; }
        #lower #movie .video:active::before {
          transition: all 0.3s;
          opacity: .6;
          z-index: 1; } }
  #lower_system {
    background: url("../img/system/top_bg.jpg") no-repeat top center, url("../img/system/bottom_bg.jpg") no-repeat bottom center, #0f0c20;
    background-size: 100%, 100%;
    box-sizing: border-box;
    padding: 270px 0 200px;
    position: relative; }
    @media (max-width: 1280px) {
      #lower_system {
        padding: 21.09375vw 0 15.625vw; } }
    @media (max-width: 768px) {
      #lower_system {
        padding: 16.9270833333vw 0 18.2291666667vw; } }
    #lower_system::before {
      content: "";
      background: url("../img/system/lower_top_left.png") no-repeat top center;
      background-size: cover;
      height: 311px;
      width: 100%;
      position: absolute;
      top: 0;
      left: 0; }
      @media (max-width: 1280px) {
        #lower_system::before {
          background-size: cover;
          height: 24.296875vw; } }
      @media (max-width: 1024px) {
        #lower_system::before {
          background-size: cover;
          height: 30.37109375vw; } }
      @media (max-width: 768px) {
        #lower_system::before {
          background-size: cover;
          height: 40.4947916667vw; } }
    #lower_system .system_wrap {
      box-sizing: border-box;
      margin: 40px auto 0;
      padding: 0 40px;
      width: 100%;
      max-width: 1480px; }
      @media (max-width: 1280px) {
        #lower_system .system_wrap {
          box-sizing: border-box;
          padding: 0 3.125vw; } }
      @media (max-width: 1024px) {
        #lower_system .system_wrap {
          padding: 0 3.90625vw; } }
      @media (max-width: 768px) {
        #lower_system .system_wrap {
          max-width: 90%; } }
      #lower_system .system_wrap h3 {
        box-sizing: border-box;
        color: #fff;
        border-bottom: 3px solid #fff;
        font-size: 38px;
        padding: 0 0 25px 100px;
        position: relative; }
        @media (max-width: 1280px) {
          #lower_system .system_wrap h3 {
            font-size: 2.96875vw;
            padding: 0 0 1.953125vw 7.8125vw; } }
        @media (max-width: 768px) {
          #lower_system .system_wrap h3 {
            font-size: 4.9479166667vw;
            padding: 0 0 3.2552083333vw 13.0208333333vw; } }
        #lower_system .system_wrap h3:nth-child(n + 2) {
          margin-top: 4.1666666667vw; }
          @media (max-width: 768px) {
            #lower_system .system_wrap h3:nth-child(n + 2) {
              margin-top: 10.4166666667vw; } }
        #lower_system .system_wrap h3::before {
          content: "";
          background: url("../img/system/ui_icon_fFire.png") no-repeat left;
          background-size: 100%;
          position: absolute;
          left: 1.5625vw;
          height: 50px;
          width: 100%;
          max-width: 55px; }
          @media (max-width: 1280px) {
            #lower_system .system_wrap h3::before {
              left: 2.34375vw;
              height: 3.90625vw;
              max-width: 4.296875vw; } }
          @media (max-width: 768px) {
            #lower_system .system_wrap h3::before {
              left: 3.90625vw;
              height: 6.5104166667vw;
              max-width: 7.1614583333vw; } }
      #lower_system .system_wrap > .cont-inr {
        margin-top: 45px; }
        @media (max-width: 1280px) {
          #lower_system .system_wrap > .cont-inr {
            margin-top: 3.515625vw; } }
        @media (max-width: 768px) {
          #lower_system .system_wrap > .cont-inr {
            margin-top: 5.859375vw; } }
        #lower_system .system_wrap > .cont-inr .cont-wrap {
          display: flex;
          flex-wrap: wrap;
          justify-content: center;
          align-items: flex-start;
          align-content: stretch;
          margin: 0 0 -2.0833333333vw -2.34375vw; }
          @media (max-width: 1280px) {
            #lower_system .system_wrap > .cont-inr .cont-wrap {
              margin: 0 0 -3.125vw -3.515625vw; } }
          @media (max-width: 768px) {
            #lower_system .system_wrap > .cont-inr .cont-wrap {
              margin: 0 auto;
              box-sizing: border-box;
              flex-direction: column;
              justify-content: center;
              align-items: center;
              width: 95%; } }
          #lower_system .system_wrap > .cont-inr .cont-wrap .box {
            margin: 0 0 2.0833333333vw 2.34375vw;
            width: 100%;
            max-width: 575px; }
            @media (max-width: 1280px) {
              #lower_system .system_wrap > .cont-inr .cont-wrap .box {
                margin: 0 0 3.125vw 3.515625vw;
                max-width: 40%; } }
            @media (max-width: 768px) {
              #lower_system .system_wrap > .cont-inr .cont-wrap .box {
                margin: 0;
                max-width: 100%; }
                #lower_system .system_wrap > .cont-inr .cont-wrap .box:nth-child(n + 2) {
                  margin-top: 7.8125vw; } }
            #lower_system .system_wrap > .cont-inr .cont-wrap .box_two {
              display: flex;
              justify-content: center;
              flex-wrap: wrap;
              margin: 0 0 2.0833333333vw 2.34375vw;
              width: 100%;
              max-width: 100%; }
              @media (max-width: 1280px) {
                #lower_system .system_wrap > .cont-inr .cont-wrap .box_two {
                  margin: 0 0 3.125vw 3.515625vw; } }
              @media (max-width: 768px) {
                #lower_system .system_wrap > .cont-inr .cont-wrap .box_two {
                  margin: 0 auto;
                  flex-direction: column;
                  width: 100%; }
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two:nth-child(n + 2) {
                    margin-top: 60px; } }
              #lower_system .system_wrap > .cont-inr .cont-wrap .box_two figure {
                border: 1px solid #000;
                width: 100%;
                max-width: 575px; }
                #lower_system .system_wrap > .cont-inr .cont-wrap .box_two figure:nth-child(2) {
                  margin-left: 2.34375vw; }
                  @media (max-width: 1280px) {
                    #lower_system .system_wrap > .cont-inr .cont-wrap .box_two figure:nth-child(2) {
                      margin-left: 3.515625vw; } }
                  @media (max-width: 768px) {
                    #lower_system .system_wrap > .cont-inr .cont-wrap .box_two figure:nth-child(2) {
                      margin-left: 0vw;
                      margin-top: 10px; } }
                @media (max-width: 1280px) {
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two figure {
                    max-width: 41%; } }
                @media (max-width: 768px) {
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two figure {
                    max-width: 100%; } }
              #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr {
                background: rgba(0, 0, 0, 0.8);
                box-sizing: border-box;
                margin-top: 20px;
                padding: 20px;
                height: 100%;
                width: 100%; }
                @media (max-width: 1280px) {
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr {
                    max-width: 79.6875vw; } }
                @media (max-width: 768px) {
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr {
                    margin: 20px auto 0;
                    max-width: 100%; } }
                #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr h4 {
                  color: yellow;
                  font-size: 2.5vw;
                  font-weight: 400;
                  font-family: "Dela Gothic One", cursive;
                  line-height: 1.2;
                  margin-top: -8px;
                  margin-bottom: 30px;
                  width: 100%; }
                  @media (max-width: 1280px) {
                    #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr h4 {
                      font-size: 3.75vw;
                      margin-bottom: 3.125vw; } }
                  @media (max-width: 768px) {
                    #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr h4 {
                      font-size: 6.25vw;
                      height: 4.5572916667vw;
                      margin-bottom: 40px; } }
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr h4 img {
                    height: 100%;
                    width: auto; }
                #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr .txt {
                  color: #fff;
                  font-size: 16px;
                  margin: -7px 0;
                  line-height: 2; }
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box_two .txt_inr .txt strong {
                    color: #77ffd3; }
            #lower_system .system_wrap > .cont-inr .cont-wrap .box > figure {
              border: 1px solid #000; }
            #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr {
              background: rgba(0, 0, 0, 0.8);
              box-sizing: border-box;
              margin-top: 20px;
              padding: 20px;
              height: 100%;
              width: 100%;
              max-width: 670px; }
              @media (max-width: 1280px) {
                #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr {
                  max-width: 100%; } }
              @media (max-width: 768px) {
                #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr {
                  margin: 20px auto 0;
                  max-width: 100%; } }
              #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr h4 {
                color: yellow;
                font-size: 2.5vw;
                font-weight: 400;
                font-family: "Dela Gothic One", cursive;
                line-height: 1.2;
                margin-top: -8px;
                margin-bottom: 30px;
                width: 100%; }
                @media (max-width: 1280px) {
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr h4 {
                    font-size: 3.75vw;
                    margin-bottom: 3.125vw; } }
                @media (max-width: 768px) {
                  #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr h4 {
                    font-size: 6.25vw;
                    height: 4.5572916667vw;
                    margin-bottom: 40px; } }
                #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr h4 img {
                  height: 100%;
                  width: auto; }
              #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr .txt {
                color: #fff;
                font-size: 16px;
                margin: -7px 0;
                line-height: 2; }
                #lower_system .system_wrap > .cont-inr .cont-wrap .box .txt_inr .txt strong {
                  color: #77ffd3; }
  #lower #special {
    background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/spec/bg.jpg") top center fixed;
    background-size: 100%, cover;
    box-sizing: border-box;
    padding: 14.0625vw 0 6.25vw; }
    @media (max-width: 768px) {
      #lower #special {
        padding: 80px 0 80px; } }
    #lower #special .special_area {
      width: 100%; }
      #lower #special .special_area .tos_area {
        background: #000;
        box-sizing: border-box;
        border: 1px solid #fff;
        color: #fff;
        margin: 80px auto;
        padding: 2.6041666667vw 5.2083333333vw;
        width: 100%;
        max-width: 1200px; }
        @media (max-width: 768px) {
          #lower #special .special_area .tos_area {
            margin: 50px auto 40px;
            padding: 30px 0 30px 20px;
            max-width: 90%; } }
        #lower #special .special_area .tos_area > .wrap {
          box-sizing: border-box;
          height: 500px;
          padding-right: 20px;
          overflow-y: scroll; }
          #lower #special .special_area .tos_area > .wrap h3 {
            margin-top: 25px; }
          #lower #special .special_area .tos_area > .wrap h4 {
            border-bottom: 2px solid #ffff00;
            box-sizing: border-box;
            color: #ffff00;
            margin-top: 30px;
            margin-bottom: 20px;
            padding-bottom: 10px; }
            #lower #special .special_area .tos_area > .wrap h4:nth-child(n + 4) {
              margin-top: 40px; }
          #lower #special .special_area .tos_area > .wrap p {
            line-height: 1.4;
            margin-top: -5px; }
            #lower #special .special_area .tos_area > .wrap p.txt {
              margin-top: 5px;
              margin-bottom: 20px; }
            #lower #special .special_area .tos_area > .wrap p a {
              color: #21ecab; }
          #lower #special .special_area .tos_area > .wrap dl {
            margin-top: 20px; }
            #lower #special .special_area .tos_area > .wrap dl div {
              display: flex;
              align-items: center; }
              @media (max-width: 768px) {
                #lower #special .special_area .tos_area > .wrap dl div {
                  flex-direction: column;
                  align-items: flex-start; } }
              #lower #special .special_area .tos_area > .wrap dl div:nth-child(n + 2) {
                margin-top: 20px; }
              #lower #special .special_area .tos_area > .wrap dl div dt {
                color: #21ecab;
                font-weight: bold;
                line-height: 1.4;
                margin-right: 20px;
                width: 100%;
                max-width: 270px; }
                @media (max-width: 768px) {
                  #lower #special .special_area .tos_area > .wrap dl div dt {
                    max-width: 100%; } }
              #lower #special .special_area .tos_area > .wrap dl div dd a {
                color: #fff;
                text-decoration: underline; }
      #lower #special .special_area ul.special_btn {
        display: flex;
        justify-content: center;
        margin: 0 auto;
        width: 100%;
        max-width: 1200px; }
        @media (max-width: 768px) {
          #lower #special .special_area ul.special_btn {
            flex-direction: column;
            align-items: center; } }
        #lower #special .special_area ul.special_btn li {
          width: 100%;
          max-width: 242px; }
          @media (max-width: 768px) {
            #lower #special .special_area ul.special_btn li {
              max-width: 90%; } }
          #lower #special .special_area ul.special_btn li a {
            font-size: 24px;
            padding: 25px 20px 25px 30px;
            text-align: left;
            width: 100%; }
            @media (max-width: 768px) {
              #lower #special .special_area ul.special_btn li a {
                font-size: 20px;
                padding: 20px 20px 20px 30px;
                text-align: left;
                width: 100%; } }
            #lower #special .special_area ul.special_btn li a::after {
              margin-top: -15px;
              right: 20px;
              width: 30px;
              height: 30px;
              /*アニメーションの指定*/
              transition: all .3s; }
            #lower #special .special_area ul.special_btn li a:hover::after {
              right: 10px; }
              @media (max-width: 768px) {
                #lower #special .special_area ul.special_btn li a:hover::after {
                  right: 20px; } }
          #lower #special .special_area ul.special_btn li:nth-child(n + 2) {
            margin-left: 80px; }
            @media (max-width: 768px) {
              #lower #special .special_area ul.special_btn li:nth-child(n + 2) {
                margin-left: 0;
                margin-top: 20px; } }
      #lower #special .special_area .sns_area,
      #lower #special .special_area .wallpaper_area,
      #lower #special .special_area .fankit_area {
        margin: 0 auto;
        width: 100%;
        max-width: 1200px; }
        #lower #special .special_area .sns_area h3,
        #lower #special .special_area .wallpaper_area h3,
        #lower #special .special_area .fankit_area h3 {
          box-sizing: border-box;
          border-bottom: 2px solid #fff;
          color: #fff;
          font-size: 38px;
          font-family: "Noto Sans JP", sans-serif;
          font-weight: 900;
          padding-left: 20px;
          padding-bottom: 30px;
          margin-top: 100px;
          margin-bottom: 50px;
          width: 100%; }
          @media (max-width: 768px) {
            #lower #special .special_area .sns_area h3,
            #lower #special .special_area .wallpaper_area h3,
            #lower #special .special_area .fankit_area h3 {
              font-size: 28px;
              margin-top: 80px;
              padding-bottom: 15px;
              margin-bottom: 30px; } }
        #lower #special .special_area .sns_area > .wrap,
        #lower #special .special_area .wallpaper_area > .wrap,
        #lower #special .special_area .fankit_area > .wrap {
          margin: 0 auto;
          width: 100%;
          max-width: 1050px; }
          #lower #special .special_area .sns_area > .wrap ul,
          #lower #special .special_area .wallpaper_area > .wrap ul,
          #lower #special .special_area .fankit_area > .wrap ul {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            margin: -50px 0 0 -30px; }
            #lower #special .special_area .sns_area > .wrap ul li,
            #lower #special .special_area .wallpaper_area > .wrap ul li,
            #lower #special .special_area .fankit_area > .wrap ul li {
              margin: 50px 0 0 30px;
              width: 100%; }
              #lower #special .special_area .sns_area > .wrap ul li figure,
              #lower #special .special_area .wallpaper_area > .wrap ul li figure,
              #lower #special .special_area .fankit_area > .wrap ul li figure {
                position: relative; }
                #lower #special .special_area .sns_area > .wrap ul li figure::after,
                #lower #special .special_area .wallpaper_area > .wrap ul li figure::after,
                #lower #special .special_area .fankit_area > .wrap ul li figure::after {
                  content: "";
                  position: absolute;
                  top: 0;
                  left: 0;
                  width: 100%;
                  height: 100%; }
              #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list,
              #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list,
              #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list {
                display: flex;
                justify-content: flex-start;
                margin: 0;
                margin-top: 10px; }
                #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li,
                #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li,
                #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li {
                  margin: 0;
                  width: 100%; }
                  #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li:nth-child(2),
                  #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li:nth-child(2),
                  #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li:nth-child(2) {
                    margin-left: 20px; }
                  @media (max-width: 768px) {
                    #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li,
                    #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li,
                    #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li {
                      max-width: 100%; }
                      #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li:nth-child(2),
                      #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li:nth-child(2),
                      #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li:nth-child(2) {
                        margin-left: 0;
                        margin-top: 15px; } }
                  #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li a,
                  #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li a,
                  #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li a {
                    background: #000;
                    border: 1px solid #fff;
                    box-sizing: border-box;
                    color: #ffff00;
                    font-size: 16px;
                    padding: 12px 20px 12px 15px;
                    text-align: left;
                    width: 100%; }
                    #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li a::after,
                    #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li a::after,
                    #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li a::after {
                      content: "";
                      background: url("../img/special/arrow.svg") no-repeat;
                      background-size: auto;
                      position: absolute;
                      top: 50%;
                      margin-top: -5px;
                      right: 15px;
                      width: 11px;
                      height: 11px;
                      /*アニメーションの指定*/
                      transition: all .3s; }
                    #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li a:hover,
                    #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li a:hover,
                    #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li a:hover {
                      background: #555; }
                      #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li a:hover::after,
                      #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li a:hover::after,
                      #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li a:hover::after {
                        right: 10px; }
                        @media (max-width: 768px) {
                          #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li a:hover::after,
                          #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li a:hover::after,
                          #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li a:hover::after {
                            right: 15px; } }
                    @media (max-width: 768px) {
                      #lower #special .special_area .sns_area > .wrap ul li > ul.btn_list li a:active::after,
                      #lower #special .special_area .wallpaper_area > .wrap ul li > ul.btn_list li a:active::after,
                      #lower #special .special_area .fankit_area > .wrap ul li > ul.btn_list li a:active::after {
                        right: 10px; } }
          #lower #special .special_area .sns_area > .wrap.sns ul li,
          #lower #special .special_area .wallpaper_area > .wrap.sns ul li,
          #lower #special .special_area .fankit_area > .wrap.sns ul li {
            max-width: 240px; }
            @media (max-width: 768px) {
              #lower #special .special_area .sns_area > .wrap.sns ul li,
              #lower #special .special_area .wallpaper_area > .wrap.sns ul li,
              #lower #special .special_area .fankit_area > .wrap.sns ul li {
                max-width: 40.3645833333vw; } }
          @media (max-width: 768px) {
            #lower #special .special_area .sns_area > .wrap.wallpaper ul,
            #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul,
            #lower #special .special_area .fankit_area > .wrap.wallpaper ul {
              margin: 0 auto;
              max-width: 90%; } }
          #lower #special .special_area .sns_area > .wrap.wallpaper ul li,
          #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul li,
          #lower #special .special_area .fankit_area > .wrap.wallpaper ul li {
            max-width: 510px; }
            @media (max-width: 768px) {
              #lower #special .special_area .sns_area > .wrap.wallpaper ul li,
              #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul li,
              #lower #special .special_area .fankit_area > .wrap.wallpaper ul li {
                margin: 0;
                max-width: 100%; }
                #lower #special .special_area .sns_area > .wrap.wallpaper ul li:nth-child(2),
                #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul li:nth-child(2),
                #lower #special .special_area .fankit_area > .wrap.wallpaper ul li:nth-child(2) {
                  margin-top: 40px; } }
            @media (max-width: 768px) {
              #lower #special .special_area .sns_area > .wrap.wallpaper ul li > ul.btn_list,
              #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul li > ul.btn_list,
              #lower #special .special_area .fankit_area > .wrap.wallpaper ul li > ul.btn_list {
                max-width: 100%; } }
            #lower #special .special_area .sns_area > .wrap.wallpaper ul li > ul.btn_list li,
            #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul li > ul.btn_list li,
            #lower #special .special_area .fankit_area > .wrap.wallpaper ul li > ul.btn_list li {
              width: 48%; }
              @media (max-width: 768px) {
                #lower #special .special_area .sns_area > .wrap.wallpaper ul li > ul.btn_list li,
                #lower #special .special_area .wallpaper_area > .wrap.wallpaper ul li > ul.btn_list li,
                #lower #special .special_area .fankit_area > .wrap.wallpaper ul li > ul.btn_list li {
                  width: 100%; } }
          #lower #special .special_area .sns_area > .wrap.fankit ul,
          #lower #special .special_area .wallpaper_area > .wrap.fankit ul,
          #lower #special .special_area .fankit_area > .wrap.fankit ul {
            /*@include pad{
              flex-direction: column;
              margin: 0 auto;
            }*/ }
            #lower #special .special_area .sns_area > .wrap.fankit ul li,
            #lower #special .special_area .wallpaper_area > .wrap.fankit ul li,
            #lower #special .special_area .fankit_area > .wrap.fankit ul li {
              max-width: 330px; }
              @media (max-width: 768px) {
                #lower #special .special_area .sns_area > .wrap.fankit ul li,
                #lower #special .special_area .wallpaper_area > .wrap.fankit ul li,
                #lower #special .special_area .fankit_area > .wrap.fankit ul li {
                  max-width: 40.3645833333vw;
                  /*margin: 0;
                  margin: 0 auto;
                  max-width: 90%;*/ } }
              #lower #special .special_area .sns_area > .wrap.fankit ul li > ul,
              #lower #special .special_area .wallpaper_area > .wrap.fankit ul li > ul,
              #lower #special .special_area .fankit_area > .wrap.fankit ul li > ul {
                flex-wrap: nowrap; }
                @media (max-width: 768px) {
                  #lower #special .special_area .sns_area > .wrap.fankit ul li > ul,
                  #lower #special .special_area .wallpaper_area > .wrap.fankit ul li > ul,
                  #lower #special .special_area .fankit_area > .wrap.fankit ul li > ul {
                    flex-wrap: wrap; }
                    #lower #special .special_area .sns_area > .wrap.fankit ul li > ul li,
                    #lower #special .special_area .wallpaper_area > .wrap.fankit ul li > ul li,
                    #lower #special .special_area .fankit_area > .wrap.fankit ul li > ul li {
                      margin-left: 0; }
                      #lower #special .special_area .sns_area > .wrap.fankit ul li > ul li:nth-child(2),
                      #lower #special .special_area .wallpaper_area > .wrap.fankit ul li > ul li:nth-child(2),
                      #lower #special .special_area .fankit_area > .wrap.fankit ul li > ul li:nth-child(2) {
                        margin-top: 10px; } }
        #lower #special .special_area .sns_area .sns_area,
        #lower #special .special_area .wallpaper_area .sns_area,
        #lower #special .special_area .fankit_area .sns_area {
          margin-top: 6.25vw; }
          @media (max-width: 768px) {
            #lower #special .special_area .sns_area .sns_area,
            #lower #special .special_area .wallpaper_area .sns_area,
            #lower #special .special_area .fankit_area .sns_area {
              margin-top: 15.625vw; } }
          #lower #special .special_area .sns_area .sns_area h3,
          #lower #special .special_area .wallpaper_area .sns_area h3,
          #lower #special .special_area .fankit_area .sns_area h3 {
            margin-top: 0; }

/* -----------------------------------------------------
   modal
----------------------------------------------------- */
.remodal {
  position: relative;
  padding: 25px; }
  .remodal img {
    width: 100%;
    height: auto;
    vertical-align: top; }

.remodal_close {
  cursor: pointer;
  margin: 0 0 0 auto;
  height: 63px;
  width: 62px;
  transition: all 0.3s; }
  .remodal_close:hover {
    opacity: .6;
    transition: all 0.3s; }
    @media (max-width: 768px) {
      .remodal_close:hover {
        opacity: 1; } }
  @media (max-width: 768px) {
    .remodal_close:active {
      opacity: .6;
      transition: all 0.3s; } }

.movie_modal {
  box-sizing: border-box;
  position: relative;
  width: 100%;
  height: 0;
  margin-top: 30px;
  padding-top: 56.25%; }
  .movie_modal iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.spec_modal h2 {
  color: #ffff00;
  font-size: 42px;
  font-family: "Dela Gothic One", cursive;
  font-weight: normal;
  margin-top: 20px;
  transform: scale(0.9, 1);
  text-align: center; }
  @media (max-width: 768px) {
    .spec_modal h2 {
      font-size: 28px; } }
.spec_modal p {
  box-sizing: border-box;
  color: #fff;
  font-size: 18px;
  line-height: 1.4;
  margin: -5px 0 -5px;
  padding-top: 30px;
  text-align: left; }
  @media (max-width: 768px) {
    .spec_modal p {
      font-size: 16px; } }
.spec_modal > .package_wrap > ol {
  display: flex;
  justify-content: center;
  box-sizing: border-box;
  padding-top: 30px; }
  .spec_modal > .package_wrap > ol li {
    height: 230px; }
    @media (max-width: 768px) {
      .spec_modal > .package_wrap > ol li {
        height: 29.9479166667vw; } }
    .spec_modal > .package_wrap > ol li:nth-child(n + 2) {
      margin-left: 10px; }
    .spec_modal > .package_wrap > ol li img {
      height: 100%;
      width: auto; }
.spec_modal > .package_wrap figure {
  box-sizing: border-box;
  margin: 20px auto 0;
  padding: 0 15px;
  width: 100%;
  max-width: 720px; }
.spec_modal > .spec_txt {
  margin-top: 20px;
  width: 100%; }
  .spec_modal > .spec_txt.pk dl > div:nth-child(9) {
    align-items: flex-start; }
  @media (max-width: 768px) {
    .spec_modal > .spec_txt {
      margin-left: 0;
      margin-top: 20px;
      box-sizing: border-box;
      padding: 0 15px;
      max-width: 100%; } }
  .spec_modal > .spec_txt dl {
    color: #fff;
    box-sizing: border-box;
    padding-top: 20px;
    width: 100%; }
    @media (max-width: 1280px) {
      .spec_modal > .spec_txt dl {
        padding-top: 20px; } }
    .spec_modal > .spec_txt dl > div {
      display: flex;
      align-items: center;
      width: 100%; }
      .spec_modal > .spec_txt dl > div:nth-child(n + 2) {
        margin-top: 20px; }
        @media (max-width: 768px) {
          .spec_modal > .spec_txt dl > div:nth-child(n + 2) {
            margin-top: 40px; } }
      @media (max-width: 768px) {
        .spec_modal > .spec_txt dl > div {
          align-items: flex-start;
          flex-direction: column; }
          .spec_modal > .spec_txt dl > div:nth-child(n + 3) {
            align-items: center; } }
      .spec_modal > .spec_txt dl > div dt {
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(254, 50, 100, 0.5);
        border: 1px solid #fff;
        box-sizing: border-box;
        font-weight: bold;
        padding: 15px;
        width: 100%;
        max-width: 180px; }
        @media (max-width: 1280px) {
          .spec_modal > .spec_txt dl > div dt {
            padding: 15px 10px;
            max-width: 110px; } }
        @media (max-width: 768px) {
          .spec_modal > .spec_txt dl > div dt {
            padding: 15px 10px;
            max-width: 100%; } }
        .spec_modal > .spec_txt dl > div dt.bk {
          background: #000; }
      .spec_modal > .spec_txt dl > div dd {
        font-size: 18px;
        line-height: 1.4;
        margin: -5px 0 -5px 30px;
        text-align: left;
        width: 100%; }
        @media (max-width: 768px) {
          .spec_modal > .spec_txt dl > div dd {
            font-size: 16px;
            box-sizing: border-box;
            margin-left: 0;
            margin-top: 15px; } }
        .spec_modal > .spec_txt dl > div dd strong.grn {
          color: #21ecab; }
        .spec_modal > .spec_txt dl > div dd span {
          font-size: 14px; }
  .spec_modal > .spec_txt .notes {
    color: #fff;
    font-size: 14px;
    text-align: left; }
    .spec_modal > .spec_txt .notes strong {
      color: #ffdc19; }
    .spec_modal > .spec_txt .notes > ol {
      background: #111;
      box-sizing: border-box;
      margin-top: 50px;
      padding: 20px 18px;
      list-style-type: none; }
      .spec_modal > .spec_txt .notes > ol li {
        line-height: 1.6;
        margin: -7px 0 -7px 20px; }
        .spec_modal > .spec_txt .notes > ol li:nth-child(n + 2) {
          box-sizing: border-box;
          padding-top: 10px; }
        .spec_modal > .spec_txt .notes > ol li::before {
          content: "※";
          margin-left: -20px;
          padding-right: 5px; }

.story_modal {
  margin-top: 30px; }

/* -----------------------------------------------------
   Character_slider
----------------------------------------------------- */
#modal_box {
  display: none;
  background: rgba(0, 0, 0, 0.95);
  height: 100%;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999; }
  #modal_box .modal_close {
    cursor: pointer;
    position: fixed;
    width: 73px;
    height: 50px;
    top: 2%;
    right: 2%;
    z-index: 10; }
    @media (max-width: 768px) {
      #modal_box .modal_close {
        width: 9.5052083333vw;
        height: 6.5104166667vw; } }
  #modal_box .detail_content {
    position: relative;
    z-index: 5; }
    #modal_box .detail_content .bg_chara {
      background: url("../img/chara/mdl/bg.png") no-repeat;
      background-size: auto;
      background-position: center;
      height: 100%;
      width: 100%;
      position: absolute;
      left: 0;
      top: 0; }
      @media (max-width: 1480px) {
        #modal_box .detail_content .bg_chara {
          background-size: 135%; } }
      @media (max-width: 1280px) {
        #modal_box .detail_content .bg_chara {
          background-size: 140%; } }
      @media (max-width: 1024px) {
        #modal_box .detail_content .bg_chara {
          background-size: 150%; } }
      @media (max-width: 768px) {
        #modal_box .detail_content .bg_chara {
          background-size: 145%;
          background-position: 50% 40%; } }
  #modal_box #modal_wrap {
    overflow-y: hidden;
    overflow-x: hidden; }

#chara-detail_slider {
  height: 100vh;
  width: 100%; }
  #chara-detail_slider .slide-arrow {
    position: absolute;
    display: block;
    width: 6.3020833333vw;
    height: 7.2916666667vw;
    cursor: pointer;
    transition: all .2s;
    z-index: 10; }
    @media (max-width: 1280px) {
      #chara-detail_slider .slide-arrow {
        width: 9.453125vw;
        height: 10.9375vw; } }
    @media (max-width: 768px) {
      #chara-detail_slider .slide-arrow {
        width: 13.1510416667vw;
        height: 15.625vw;
        transform: translateY(0); } }
  #chara-detail_slider .prev-arrow {
    top: 3.6458333333vw;
    left: 30px; }
    @media (max-width: 768px) {
      #chara-detail_slider .prev-arrow {
        top: 0;
        top: 13%;
        left: 3.2552083333vw; } }
    #chara-detail_slider .prev-arrow:hover {
      transform: translateX(-15%); }
      @media (max-width: 768px) {
        #chara-detail_slider .prev-arrow:hover {
          transform: translateY(0); } }
  #chara-detail_slider .next-arrow {
    bottom: 3.6458333333vw;
    right: 30px; }
    @media (max-width: 768px) {
      #chara-detail_slider .next-arrow {
        border: 0;
        top: 13%;
        right: 3.2552083333vw; } }
    #chara-detail_slider .next-arrow:hover {
      transform: translateX(15%); }
      @media (max-width: 768px) {
        #chara-detail_slider .next-arrow:hover {
          transform: translateY(0); } }
  #chara-detail_slider li {
    height: 100vh;
    display: flex;
    position: relative; }
    #chara-detail_slider li .chara_cont {
      display: flex;
      justify-content: flex-end;
      align-items: flex-start;
      margin: 0 auto;
      position: relative;
      height: 100%;
      width: 100%;
      max-width: 75.5208333333vw; }
      @media (max-width: 1480px) {
        #chara-detail_slider li .chara_cont {
          max-width: 90%; } }
      @media (max-width: 1280px) {
        #chara-detail_slider li .chara_cont {
          max-width: 90%; } }
      @media (max-width: 768px) {
        #chara-detail_slider li .chara_cont {
          flex-direction: column;
          max-width: 100%; } }
      #chara-detail_slider li .chara_cont figure.chara {
        position: absolute;
        top: 50%;
        left: 0;
        margin-top: -23.8020833333vw;
        width: 100%;
        max-width: 31.25vw; }
        @media (max-width: 1480px) {
          #chara-detail_slider li .chara_cont figure.chara {
            margin-top: -30.8783783784vw;
            max-width: 40.5405405405vw; } }
        @media (max-width: 1280px) {
          #chara-detail_slider li .chara_cont figure.chara {
            margin-top: -26.953125vw;
            max-width: 37.5vw; } }
        @media (max-width: 768px) {
          #chara-detail_slider li .chara_cont figure.chara {
            margin: -66.015625vw auto 0;
            max-width: 80%;
            position: absolute;
            top: 40%;
            left: 0;
            right: 0; } }
        #chara-detail_slider li .chara_cont figure.chara_wide {
          position: absolute;
          top: 50%;
          left: -5%;
          margin-top: -23.8020833333vw;
          width: 100%;
          max-width: 41.6666666667vw; }
          @media (max-width: 1480px) {
            #chara-detail_slider li .chara_cont figure.chara_wide {
              margin-top: -30.8783783784vw;
              max-width: 54.0540540541vw; } }
          @media (max-width: 1280px) {
            #chara-detail_slider li .chara_cont figure.chara_wide {
              margin-top: -28.90625vw;
              max-width: 54.6875vw; } }
          @media (max-width: 1024px) {
            #chara-detail_slider li .chara_cont figure.chara_wide {
              margin-top: -27.34375vw;
              max-width: 50.78125vw; } }
          @media (max-width: 768px) {
            #chara-detail_slider li .chara_cont figure.chara_wide {
              margin: -66.015625vw auto 0;
              max-width: 100%;
              position: absolute;
              top: 40%;
              left: 0;
              right: 0; } }
          #chara-detail_slider li .chara_cont figure.chara_wide img.pc {
            display: block; }
          #chara-detail_slider li .chara_cont figure.chara_wide img.sp {
            display: none; }
          @media (max-width: 768px) {
            #chara-detail_slider li .chara_cont figure.chara_wide img.pc {
              display: none; }
            #chara-detail_slider li .chara_cont figure.chara_wide img.sp {
              display: block; } }
      #chara-detail_slider li .chara_cont figure.txt {
        position: absolute;
        top: 50%;
        left: 2.6041666667vw;
        height: 16.0416666667vw;
        margin: -17px auto 0;
        width: 100%;
        z-index: 7; }
        @media (max-width: 1480px) {
          #chara-detail_slider li .chara_cont figure.txt {
            height: 20.8108108108vw; } }
        @media (max-width: 1280px) {
          #chara-detail_slider li .chara_cont figure.txt {
            top: 51%;
            height: auto;
            width: 77%;
            margin: 0 auto; } }
        @media (max-width: 1024px) {
          #chara-detail_slider li .chara_cont figure.txt {
            width: 76%; } }
        @media (max-width: 768px) {
          #chara-detail_slider li .chara_cont figure.txt {
            bottom: 0;
            top: 55%;
            left: 0;
            right: 0;
            margin: -30% auto 0;
            height: auto;
            width: 90%; } }
        @media (max-width: 320px) {
          #chara-detail_slider li .chara_cont figure.txt {
            top: 48%;
            margin: -23% auto 0; } }
        #chara-detail_slider li .chara_cont figure.txt > img {
          height: 100%;
          width: auto; }
          @media (max-width: 1280px) {
            #chara-detail_slider li .chara_cont figure.txt > img {
              height: auto;
              width: 100%; } }
      #chara-detail_slider li .chara_cont figure.dot {
        display: flex;
        justify-content: center;
        align-items: center;
        background: url("../img/chara/mdl/dot_bg.png") no-repeat;
        background-size: 100%;
        top: 50%;
        right: 0;
        position: absolute;
        height: 18.0208333333vw;
        width: 20.46875vw;
        z-index: 6; }
        #chara-detail_slider li .chara_cont figure.dot.pc {
          display: block; }
        #chara-detail_slider li .chara_cont figure.dot.sp {
          display: none; }
        @media (max-width: 768px) {
          #chara-detail_slider li .chara_cont figure.dot {
            bottom: 0;
            top: -23.4375vw;
            right: 10px;
            height: auto;
            height: 25.5208333333vw;
            width: 27.734375vw; }
            #chara-detail_slider li .chara_cont figure.dot.pc {
              display: none; }
            #chara-detail_slider li .chara_cont figure.dot.sp {
              display: block; } }
        #chara-detail_slider li .chara_cont figure.dot > img {
          position: absolute;
          bottom: 4.1666666667vw;
          right: 1.0416666667vw;
          width: 20.46875vw; }
          @media (max-width: 768px) {
            #chara-detail_slider li .chara_cont figure.dot > img {
              bottom: 6.5104166667vw;
              right: 0;
              height: 29.4270833333vw;
              width: 31.640625vw; } }
          @media (max-width: 320px) {
            #chara-detail_slider li .chara_cont figure.dot > img {
              right: 0;
              height: auto;
              width: 100px; } }
          #chara-detail_slider li .chara_cont figure.dot > img.png {
            left: 0;
            right: 0;
            margin: 0 auto;
            height: 11.6666666667vw;
            width: 11.6666666667vw; }
            @media (max-width: 768px) {
              #chara-detail_slider li .chara_cont figure.dot > img.png {
                bottom: 6.5104166667vw;
                right: 0;
                height: 16.6666666667vw;
                width: 16.6666666667vw; } }
            @media (max-width: 320px) {
              #chara-detail_slider li .chara_cont figure.dot > img.png {
                right: 0;
                height: auto;
                width: 50%; } }
      #chara-detail_slider li .chara_cont .inr {
        display: flex;
        flex-direction: column;
        box-sizing: border-box;
        padding-top: 3.3854166667vw;
        width: 100%;
        max-width: 43.4895833333vw; }
        @media (max-width: 1480px) {
          #chara-detail_slider li .chara_cont .inr {
            padding-top: 4.3918918919vw;
            max-width: 49.6621621622vw; } }
        @media (max-width: 1280px) {
          #chara-detail_slider li .chara_cont .inr {
            position: absolute;
            margin-top: -15%;
            padding-top: 0;
            top: 30%;
            max-width: 59%; } }
        @media (max-width: 1024px) {
          #chara-detail_slider li .chara_cont .inr {
            position: absolute;
            margin-top: -18%;
            padding-top: 0;
            top: 35%;
            max-width: 58%; } }
        @media (max-width: 768px) {
          #chara-detail_slider li .chara_cont .inr {
            top: auto;
            bottom: 0;
            margin-top: -30px;
            padding-top: 0;
            padding: 20px 5px 30px;
            background: rgba(0, 0, 0, 0.9);
            max-width: 100%; } }
        #chara-detail_slider li .chara_cont .inr_txt {
          box-sizing: border-box;
          color: #fff;
          font-size: 24px;
          font-weight: bold;
          text-shadow: 1px 1px 3px #c325c3, 1px 1px 3px #c325c3;
          line-height: 1.6;
          margin: -5px 0;
          padding: 4.6875vw 0 0 1.0416666667vw; }
          @media (max-width: 1480px) {
            #chara-detail_slider li .chara_cont .inr_txt {
              font-size: 20px;
              padding: 6.0810810811vw 0 0 1.3513513514vw; } }
          @media (max-width: 1280px) {
            #chara-detail_slider li .chara_cont .inr_txt {
              font-size: 18px;
              padding: 3.125vw 0 0 1.5625vw; } }
          @media (max-width: 1024px) {
            #chara-detail_slider li .chara_cont .inr_txt {
              font-size: 16px;
              padding: 3.90625vw 0 0 1.953125vw; } }
          @media (max-width: 768px) {
            #chara-detail_slider li .chara_cont .inr_txt {
              font-size: 16px;
              margin: -5px auto;
              padding: 5.2083333333vw 0 0;
              width: 90%; } }
          @media (max-width: 320px) {
            #chara-detail_slider li .chara_cont .inr_txt {
              font-size: 15px; } }
          #chara-detail_slider li .chara_cont .inr_txt.Top {
            padding: 3.125vw 0 0 1.0416666667vw; }
            @media (max-width: 1480px) {
              #chara-detail_slider li .chara_cont .inr_txt.Top {
                font-size: 20px;
                padding: 4.0540540541vw 0 0 1.3513513514vw; } }
            @media (max-width: 1480px) {
              #chara-detail_slider li .chara_cont .inr_txt.Top {
                padding: 3.125vw 0 0 1.5625vw; } }
            @media (max-width: 1024px) {
              #chara-detail_slider li .chara_cont .inr_txt.Top {
                font-size: 16px;
                padding: 3.90625vw 0 0 1.953125vw; } }
        #chara-detail_slider li .chara_cont .inr .wrap {
          position: relative; }
          #chara-detail_slider li .chara_cont .inr .wrap .name_wrap {
            display: flex;
            align-items: flex-end; }
            @media (max-width: 1024px) {
              #chara-detail_slider li .chara_cont .inr .wrap .name_wrap {
                flex-wrap: wrap; } }
            @media (max-width: 768px) {
              #chara-detail_slider li .chara_cont .inr .wrap .name_wrap {
                align-items: center;
                flex-direction: column; } }
            #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name {
              color: #fff;
              font-family: "Dela Gothic One", cursive;
              font-size: 100px; }
              @media (max-width: 1280px) {
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name {
                  font-size: 7.8125vw; } }
              @media (max-width: 1024px) {
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name {
                  font-size: 5.859375vw; } }
              @media (max-width: 768px) {
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name {
                  font-size: 36px; } }
              #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide {
                color: #fff;
                font-family: "Dela Gothic One", cursive;
                font-size: 65px; }
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide .pad {
                  display: none; }
                @media (max-width: 1280px) {
                  #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide {
                    font-size: 4.296875vw; }
                    #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide .pad {
                      display: block; } }
                @media (max-width: 1024px) {
                  #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide {
                    font-size: 4.8828125vw; } }
                @media (max-width: 768px) {
                  #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide {
                    text-align: left;
                    font-size: 36px;
                    width: 90%; }
                    #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .name_wide .pad {
                      display: none; } }
            #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .cv {
              box-sizing: border-box;
              background: #ff054f;
              border-radius: 100vh;
              color: #ffff00;
              font-size: 20px;
              font-weight: bold;
              margin-left: 2.6041666667vw;
              padding: 1.0416666667vw 30px; }
              @media (max-width: 1280px) {
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .cv {
                  font-size: 18px; } }
              @media (max-width: 1024px) {
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .cv {
                  font-size: 16px; } }
              @media (max-width: 768px) {
                #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .cv {
                  display: flex;
                  align-items: center;
                  margin-left: 0;
                  padding: 2.6041666667vw 30px;
                  font-size: 16px;
                  margin-top: 15px; } }
              #chara-detail_slider li .chara_cont .inr .wrap .name_wrap .cv span {
                color: #fff;
                font-weight: bold; }

/* -----------------------------------------------------
   news
----------------------------------------------------- */
#news {
  background: #c325c3;
  box-sizing: border-box;
  padding-bottom: 7.2916666667vw; }
  @media (max-width: 768px) {
    #news {
      padding-top: 153.6458333333vw; } }
  #news .news-inr {
    position: relative;
    z-index: 3; }
    #news .news-inr h2 {
      width: 100%;
      max-width: 21.4583333333vw;
      margin: 0 auto; }
      @media (max-width: 1280px) {
        #news .news-inr h2 {
          max-width: 32.1875vw; } }
      @media (max-width: 768px) {
        #news .news-inr h2 {
          max-width: 53.6458333333vw; } }
    #news .news-inr .news_wrap {
      box-sizing: border-box;
      padding: 25px auto 0;
      margin: 0 auto;
      overflow: hidden;
      width: 1560px; }
      @media (max-width: 768px) {
        #news .news-inr .news_wrap {
          padding: 10px auto 0; } }
      #news .news-inr .news_wrap .swiper-container .swiper-wrapper {
        display: flex;
        justify-content: center; }
        #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide {
          position: relative;
          box-sizing: border-box;
          margin: 15px 0 0 0 !important;
          width: 100%;
          max-width: 480px;
          transition: all 0.3s; }
          @media (max-width: 768px) {
            #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide {
              max-width: 70%; } }
          #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dt {
            font-size: 18px;
            font-weight: bold;
            text-align: right;
            color: #ffff00;
            margin-bottom: 10px;
            position: relative; }
            @media (max-width: 768px) {
              #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dt {
                font-size: 16px;
                margin-bottom: 1.3020833333vw; } }
            #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dt .new {
              background: url("../img/news/icon_new.png") no-repeat top left;
              background-size: 100%;
              position: absolute;
              top: -0.6770833333vw;
              left: 0;
              height: 5.5729166667vw;
              width: 4.0104166667vw;
              z-index: 1; }
              @media (max-width: 768px) {
                #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dt .new {
                  top: -1.953125vw;
                  height: 17.8385416667vw;
                  width: 15.234375vw; } }
          #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dd.pict {
            border: 2px solid #ff0078;
            margin: 0;
            padding: 0;
            background: #fff;
            overflow: hidden;
            width: 100%;
            max-width: 480px; }
          #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dd.txt {
            background: url("../img/news/bg_news_txt_03.jpg") no-repeat top center;
            background-size: 100%;
            box-sizing: border-box;
            color: #fff;
            font-size: 20px;
            padding: 20px 0; }
            @media (max-width: 768px) {
              #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide dd.txt {
                font-size: 16px; } }
          #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide a dd.pict {
            border: 2px solid #ff0078;
            margin: 0;
            padding: 0;
            background: #fff;
            overflow: hidden;
            cursor: pointer;
            width: 100%;
            max-width: 480px; }
            #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide a dd.pict:hover img {
              transform: scale(1.05); }
            #news .news-inr .news_wrap .swiper-container .swiper-wrapper .swiper-slide a dd.pict img {
              width: 100%;
              height: 100%;
              transform: scale(1);
              transition: .3s ease-in-out; }

/* -----------------------------------------------------
   TOP_news_slider
----------------------------------------------------- */
.swiper-container {
  overflow: hidden;
  margin: 0 auto;
  width: 100%;
  max-width: 1560px; }
  @media (max-width: 1280px) {
    .swiper-container {
      max-width: 83%; } }
  @media (max-width: 768px) {
    .swiper-container {
      max-width: 90%; } }

.swiper-slide {
  width: 100%;
  max-width: 480px; }
  @media (max-width: 1280px) {
    .swiper-slide {
      max-width: 37.5vw; } }
  @media (max-width: 768px) {
    .swiper-slide {
      max-width: 100%; } }
  .swiper-slide:nth-child(n + 2) {
    margin-left: 2.6041666667vw; }
    @media (max-width: 1280px) {
      .swiper-slide:nth-child(n + 2) {
        margin-left: 3.90625vw; } }
    @media (max-width: 768px) {
      .swiper-slide:nth-child(n + 2) {
        margin-left: 0; } }
  .swiper-slide figure {
    border: 2px solid #ff0078;
    margin: 0;
    padding: 0;
    background: #fff;
    overflow: hidden;
    width: 100%;
    max-width: 480px; }
    @media (max-width: 1280px) {
      .swiper-slide figure {
        max-width: 99%; } }
    @media (max-width: 768px) {
      .swiper-slide figure {
        max-width: 99%; } }
  .swiper-slide p.day {
    box-sizing: border-box;
    font-size: 18px;
    font-weight: bold;
    text-align: right;
    color: #ffff00;
    margin-top: 25px;
    margin-bottom: 10px;
    position: relative; }
    @media (max-width: 768px) {
      .swiper-slide p.day {
        font-size: 16px;
        margin-bottom: 1.3020833333vw; } }
    .swiper-slide p.day .new {
      background: url("../img/news/icon_new.png") no-repeat top left;
      background-size: 100%;
      position: absolute;
      top: -0.6770833333vw;
      left: 0;
      height: 5.5729166667vw;
      width: 4.0104166667vw;
      z-index: 1; }
      @media (max-width: 1280px) {
        .swiper-slide p.day .new {
          top: -1.015625vw;
          height: 8.359375vw;
          width: 6.015625vw; } }
      @media (max-width: 768px) {
        .swiper-slide p.day .new {
          top: -1.953125vw;
          height: 17.8385416667vw;
          width: 15.234375vw; } }
  .swiper-slide p.txt {
    background: url("../img/news/bg_news_txt_03.jpg") no-repeat top center;
    background-size: 100%;
    box-sizing: border-box;
    color: #fff;
    font-size: 20px;
    padding: 20px 0; }
    @media (max-width: 768px) {
      .swiper-slide p.txt {
        font-size: 16px; } }
  .swiper-slide a {
    transition: all 0.3s; }
    .swiper-slide a:hover figure {
      transition: all 0.3s;
      border: 2px solid #ffff00; }
    .swiper-slide a:hover .txt {
      transition: all 0.3s;
      opacity: .6; }

.swiper-button-prev {
  background-image: url("../img/arrow_prev.png");
  height: 5.7291666667vw !important;
  width: 5.3125vw !important;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 2.0833333333vw; }
  @media (max-width: 1280px) {
    .swiper-button-prev {
      height: 8.59375vw !important;
      width: 7.96875vw !important;
      top: 8%; } }
  @media (max-width: 768px) {
    .swiper-button-prev {
      height: 14.3229166667vw !important;
      width: 13.28125vw !important;
      top: 8%;
      /*width: vw_p(70)!important;*/ } }
  .swiper-button-prev::after {
    display: none; }

.swiper-button-next {
  background-image: url("../img/arrow_next.png");
  height: 5.7291666667vw !important;
  width: 5.3125vw !important;
  background-size: contain;
  background-repeat: no-repeat;
  margin-right: 2.0833333333vw; }
  @media (max-width: 1280px) {
    .swiper-button-next {
      height: 8.59375vw !important;
      width: 7.96875vw !important;
      top: 8%; } }
  @media (max-width: 768px) {
    .swiper-button-next {
      height: 14.3229166667vw !important;
      width: 13.28125vw !important;
      top: 8%;
      /*width: vw_p(70)!important;*/ } }
  .swiper-button-next::after {
    display: none; }

/* -----------------------------------------------------
   DLC
----------------------------------------------------- */
#hot_contents {
  background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/dlc/dlc_hot-contents_bg.jpg") repeat top center fixed;
  background-size: 100%, 100%;
  box-sizing: border-box;
  padding: 14.0625vw 0 10.4166666667vw; }
  @media (max-width: 768px) {
    #hot_contents {
      background: url("../img/lower_bg_top.png") no-repeat top left, url("../img/dlc/dlc_hot-contents_bg.jpg") repeat-y top center;
      background-size: contain, 100%;
      padding: 16.9270833333vw 0 19.53125vw; } }
  #hot_contents h2 {
    margin: 0 auto 3.125vw;
    width: 100%;
    max-width: 60.3125vw; }
    @media (max-width: 1280px) {
      #hot_contents h2 {
        margin: 0 auto 4.6875vw;
        max-width: 67.03125vw; } }
    @media (max-width: 768px) {
      #hot_contents h2 {
        max-width: 78.125vw; } }
  #hot_contents div.wrap {
    display: flex;
    margin: 0 auto;
    width: 100%;
    max-width: 69.2708333333vw; }
    @media (max-width: 1280px) {
      #hot_contents div.wrap {
        align-items: center;
        max-width: 85.9375vw; } }
    @media (max-width: 768px) {
      #hot_contents div.wrap {
        flex-direction: column;
        max-width: 90%; } }
    #hot_contents div.wrap:nth-child(3) {
      flex-direction: row-reverse;
      margin-top: 4.1666666667vw; }
      @media (max-width: 1280px) {
        #hot_contents div.wrap:nth-child(3) {
          margin-top: 6.25vw; } }
      @media (max-width: 768px) {
        #hot_contents div.wrap:nth-child(3) {
          margin-top: 10.4166666667vw;
          flex-direction: column; } }
      #hot_contents div.wrap:nth-child(3) dl {
        box-sizing: border-box;
        margin: 0;
        margin-right: 2.0833333333vw; }
        @media (max-width: 1280px) {
          #hot_contents div.wrap:nth-child(3) dl {
            margin-right: 3.125vw; } }
        @media (max-width: 768px) {
          #hot_contents div.wrap:nth-child(3) dl {
            margin-right: 0;
            margin-top: 5.2083333333vw; } }
    #hot_contents div.wrap figure {
      width: 100%;
      max-width: 30.2083333333vw; }
      @media (max-width: 1280px) {
        #hot_contents div.wrap figure {
          max-width: 45.3125vw; } }
      @media (max-width: 768px) {
        #hot_contents div.wrap figure {
          max-width: 90%; } }
      #hot_contents div.wrap figure img {
        border: 1px solid #fff; }
    #hot_contents div.wrap dl {
      margin-left: 2.0833333333vw;
      width: 100%;
      max-width: 36.9270833333vw; }
      @media (max-width: 1280px) {
        #hot_contents div.wrap dl {
          margin-left: 3.125vw;
          max-width: 55.390625vw; } }
      @media (max-width: 768px) {
        #hot_contents div.wrap dl {
          margin-left: 0;
          margin-top: 5.2083333333vw;
          max-width: 90%; } }
      #hot_contents div.wrap dl dt {
        background: #e4007f;
        box-sizing: border-box;
        border-radius: 50px;
        padding: 1.5625vw 1.8229166667vw; }
        @media (max-width: 768px) {
          #hot_contents div.wrap dl dt {
            padding: 2.6041666667vw 10.4166666667vw !important; } }
        #hot_contents div.wrap dl dt img {
          height: auto;
          width: 100%;
          object-fit: cover; }
      #hot_contents div.wrap dl dd {
        background: #fff;
        box-sizing: border-box;
        margin-top: 30px;
        padding: 1.8229166667vw 2.0833333333vw;
        line-height: 1.6;
        width: 100%; }
        @media (max-width: 1280px) {
          #hot_contents div.wrap dl dd {
            padding: 2.734375vw 3.125vw; } }
        @media (max-width: 768px) {
          #hot_contents div.wrap dl dd {
            padding: 3.2552083333vw 3.90625vw; } }
        #hot_contents div.wrap dl dd strong {
          color: #e4007f; }

#dlc_movie {
  background: #111;
  cursor: pointer;
  position: relative; }
  #dlc_movie::before {
    content: "";
    background: url("../img/dlc/dlc_icon_movie.png") no-repeat top center;
    background-size: cover;
    position: absolute;
    top: 45%;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 164px;
    height: 149px; }
    @media (max-width: 768px) {
      #dlc_movie::before {
        top: 38%;
        width: 13.5416666667vw;
        height: 11.5885416667vw; } }
    #dlc_movie::before:hover {
      transition: all 0.3s;
      opacity: .6; }
      @media (max-width: 768px) {
        #dlc_movie::before:hover {
          opacity: 1; } }
    @media (max-width: 768px) {
      #dlc_movie::before:active {
        transition: all 0.3s;
        opacity: .8; } }
  #dlc_movie img {
    object-fit: cover;
    width: 100%; }
    #dlc_movie img:hover {
      transition: all 0.3s;
      opacity: .6; }
      @media (max-width: 768px) {
        #dlc_movie img:hover {
          opacity: 1; } }
    @media (max-width: 768px) {
      #dlc_movie img:active {
        transition: all 0.3s;
        opacity: .8; } }
#dlc_character {
  background: url("../img/dlc/dlc_dlc_contents_bg.jpg") no-repeat top;
  background-size: cover;
  box-sizing: border-box;
  padding: 7.03125vw 0 0;
  position: relative; }
  @media (max-width: 768px) {
    #dlc_character {
      padding: 6.5104166667vw 0 0; } }
  #dlc_character::before {
    content: "";
    background: url("../img/dlc/dlc_stickers_left.png") left top;
    background-size: 100%;
    position: absolute;
    top: -4.1666666667vw;
    left: 0;
    height: 24.5833333333vw;
    width: 30.9375vw; }
  #dlc_character::after {
    content: "";
    background: url("../img/dlc/dlc_stickers_right.png") left top;
    background-size: 100%;
    position: absolute;
    top: -3.4375vw;
    right: 0;
    height: 20.2083333333vw;
    width: 31.25vw; }
  #dlc_character h2 {
    margin: 0 auto;
    position: relative;
    width: 100%;
    max-width: 52.0833333333vw;
    z-index: 1; }
    @media (max-width: 768px) {
      #dlc_character h2 {
        max-width: 52.0833333333vw; } }
  #dlc_character .chara_visual {
    margin-top: -5.2083333333vw; }
    #dlc_character .chara_visual img {
      height: auto;
      width: 100%; }
  #dlc_character .chara_txt {
    position: absolute;
    bottom: 4.6875vw;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    max-width: 69.6875vw; }
    @media (max-width: 768px) {
      #dlc_character .chara_txt {
        max-width: 72%; } }
#dlc_story {
  background: url("../img/dlc/dlc_story_bg.jpg") no-repeat center center;
  background-size: cover; }
  #dlc_story .cont-inr {
    background: rgba(0, 0, 0, 0.8);
    box-sizing: border-box;
    padding: 6.25vw 0; }
    @media (max-width: 768px) {
      #dlc_story .cont-inr {
        padding: 10.4166666667vw 0;
        width: 80%; } }
    #dlc_story .cont-inr > .txt {
      color: #fff;
      font-size: 1.25vw;
      font-weight: bold;
      margin-top: 4.1666666667vw;
      line-height: 2;
      text-align: center; }
      @media (max-width: 768px) {
        #dlc_story .cont-inr > .txt {
          font-size: 2.6041666667vw;
          margin-top: 5.2083333333vw; } }
      #dlc_story .cont-inr > .txt strong {
        color: #ffff00;
        font-size: 1.875vw;
        line-height: 2; }
        @media (max-width: 768px) {
          #dlc_story .cont-inr > .txt strong {
            font-size: 3.6458333333vw; } }
