@charset "UTF-8";

/*
|---------------------------------------------------------------
| プレイヤーズ走魂ビジュアルグッズ
|---------------------------------------------------------------
*/
.block-page-caption {
  display: none;
}

.plpage {
  display: block;
  width: 100%;
  color: #000000;
}

.plpage * {
  min-width: 0;
}

@media screen and (min-width: 750.2px) {
  .plpage .d-none--pc {
    display: none !important;
  }
}

@media screen and (max-width: 750px) {
  .plpage .d-none--sp {
    display: none !important;
  }
}

.pl-container {
  max-width: 1170px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
}

.plpage__header {
  display: block;
  width: 100%;
  margin: 0 0 25px;
}

.plpage__header__term {
  position: relative;
  background: linear-gradient(90deg, #1d2087 0%, #1ecafd 70%);
  padding: 15px 0;
  text-align: center;
  color: #fff;
  font-size: 28px;
  max-width: 90%;
  margin: 50px auto;
}

.plpage__header__term::after {
  content: "";
  display: block;
  width: 100px;
  height: 100px;
  position: absolute;
  right: 0;
  top: 0;
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/fire.png);
  background-size: contain;
  background-position: left bottom;
  background-repeat: no-repeat;
  transform: translate(40px, -60px);
}

.plpage__header__term_head {
  font-weight: bold;
}


@media screen and (max-width: 750.1px) {

  .plpage__header__term {
    position: relative;
    background: linear-gradient(90deg, #1d2087 0%, #1ecafd 70%);
    padding: 15px 0;
    text-align: center;
    color: #fff;
    font-size: 15px;
    max-width: 100%;
    margin: 50px auto;
  }

  .plpage__header__term::after {
    content: "";
    display: block;
    width: 50px;
    height: 70px;
    position: absolute;
    right: 0;
    top: 0;
    background-image: url(/assets/sokonvisualgoods-jyutyu/images/fire.png);
    background-size: contain;
    background-position: left bottom;
    background-repeat: no-repeat;
    transform: translate(20px, -50px);
  }
}

@media screen and (min-width: 750.2px) {
  .plpage__header {
    margin-bottom: 60px;
  }
}

.plpage__header__image {
  display: block;
  width: 100%;
  margin: 0 0 15px;
}

@media screen and (min-width: 750.2px) {
  .plpage__header__image {
    margin-bottom: 25px;
  }
}

.plpage__header__image img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 750px) {
  .plpage__header__image .pl-container {
    padding-left: 0;
    padding-right: 0;
  }
}

.plpage__header__title {
  display: block;
  font-size: 20px;
  line-height: 1.4285714286;
  font-weight: 500;
  text-align: center;
  margin: 0 0 25px;
}

@media screen and (min-width: 750.2px) {
  .plpage__header__title {
    font-size: 42px;
    margin-bottom: 25px;
  }
}

.plpage__header__lead {
  display: block;
  font-size: 14px;
  line-height: 1.32;
  text-align: center;
}

@media screen and (min-width: 750.2px) {
  .plpage__header__lead {
    font-size: 25px;
  }
}

.plpage__body {
  display: block;
  margin: 0;
  padding: 0;
}

@media screen and (min-width: 750.2px) {
  .plpage__body {}
}

.plpage__profile {
  display: block;
  width: 100%;
  margin: 0 0 30px;
  padding: 0 0 12px;
  clear: both;
}

@media screen and (min-width: 750.2px) {
  .plpage__profile {
    margin-bottom: 70px;
    padding: 0 0 33px;
  }
}

.plpage__lineup {
  display: block;
  width: 100%;
  margin: 0 0 30px;
}

@media screen and (min-width: 750.2px) {
  .plpage__lineup {}
}

/*
 * Profile
------------------------------------------------*/
.pl-profile {
  display: block;
  width: 100%;
  color: #000000;
  background: #fff;
  box-shadow: 12px 12px 0 0 #009740;
  padding: 20px 15px;
  border: solid 1px #000;
}

@media screen and (min-width: 750.2px) {
  .pl-profile {
    box-shadow: 33px 33px 0 0 #009740;
    padding: 35px 33px;
  }
}

.pl-profile__layout {
  display: block;
  width: 100%;
}

.pl-profile__layout__image {
  display: block;
  width: 100%;
  margin: 0 0 15px;
}

.pl-profile__layout__body {
  display: block;
  width: 100%;
}

.pl-profile__image {
  display: block;
  width: 100%;
  height: auto;
}

.pl-profile__image img {
  display: block;
  width: 100%;
  height: auto;
}

@media screen and (min-width: 750.2px) {
  .pl-profile__image {
    width: 437px;
  }

  .pl-profile__layout {
    display: flex;
    width: auto;
    margin-left: -10px;
    margin-right: -10px;
    flex-direction: row-reverse;
  }

  .pl-profile__layout__image {
    margin-bottom: 0;
    padding-left: 10px;
    padding-right: 10px;
    width: auto;
    flex: 0 0 auto;
    max-width: 100%;
  }

  .pl-profile__layout__body {
    padding-left: 10px;
    padding-right: 10px;
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
    display: flex;
    flex-direction: column;
  }
}

.pl-profile__title {
  display: block;
  width: 100%;
  font-size: 20px;
  line-height: 1.4285714286;
  font-weight: 500;
  text-align: left;
  margin: 0 0 15px;
  color: #00214a;
  font-weight: bold;
}

@media screen and (min-width: 750.2px) {
  .pl-profile__title {
    font-size: 34px;
    margin-bottom: 15px;
  }
}

.pl-profile__summary_image {
  max-width: 140px;
  float: right;
}

.pl-profile__summary {
  display: block;
  width: 100%;
  font-size: 13px;
  font-weight: 500;
  text-align: left;
  line-height: 1.7647058824;
  margin: 0 0 0.5em;
}

@media screen and (min-width: 750.2px) {
  .pl-profile__summary_image {
    max-width: 180px;
    float: right;
  }

  .pl-profile__summary {
    font-size: 18px;
  }
}

.pl-profile__history {
  display: block;
  width: 100%;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.7647058824;
  margin: 0;
}

@media screen and (min-width: 750.2px) {
  .pl-profile__history {
    font-size: 17px;
    margin-top: auto;
  }
}

.pl-profile__history::before,
.pl-profile__history::after {
  content: "";
  display: block;
  width: 100%;
  max-width: 352px;
  height: 1px;
  margin: 0.5em 0;
  background: #707070;
}

.pl-profile__history__list {
  list-style: none;
  padding: 10px 0;
  display: block;
  width: 100%;
}

.pl-profile__history__list li {
  display: block;
  margin: 0;
}

/*
 * Lineup
------------------------------------------------*/
.pl-product {
  display: block;
  width: 100%;
}

.pl-product__layout {
  display: block;
  width: 100%;
}

.pl-product__layout__image {
  display: block;
  width: 100%;
  margin: 0 0 15px;
}

.pl-product__layout__body {
  display: block;
  width: 100%;
}

.pl-product__image {
  display: block;
  width: 100%;
  height: auto;
  padding: 0;
}

.pl-product__image img {
  border: solid 1px #000;
}

@media screen and (max-width: 750.1px) {

  .pl-product {
    padding: 15px 4% 30px;
    position: relative;
  }

  .pl-product::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(-135deg, rgb(13, 204, 255) 0%, rgb(32, 51, 172) 100%);
    position: absolute;
    top: 0px;
    left: 0px;
    z-index: 0;
  }

  .pl-product__layout {
    z-index: 5;
    position: relative;
  }
}

@media screen and (min-width: 750.2px) {
  .pl-product {
    padding: 30px 30px 30px 30px;
    position: relative;
  }

  .pl-product::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(-135deg, rgb(13, 204, 255) 0%, rgb(32, 51, 172) 100%);
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 0;
  }

  .pl-product__layout {
    z-index: 4;
  }
}

.pl-product__image img {
  display: block;
  width: 100%;
  height: auto;
}

@media screen and (min-width: 750.2px) {
  .pl-product__layout {
    display: flex;
    width: auto;
    margin-left: -20px;
    margin-right: -20px;
  }

  .pl-product__layout__image {
    margin-bottom: 0;
    padding-left: 20px;
    padding-right: 20px;
    width: auto;
    flex: 0 0 auto;
    max-width: 100%;
    z-index: 2;
  }

  .pl-product__layout__body {
    padding-left: 20px;
    padding-right: 20px;
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
    padding-top: 15px;
    display: flex;
    flex-direction: column;
    z-index: 2;
  }
}

.pl-product__name {
  display: block;
  width: 100%;
  font-size: 18px;
  line-height: 1.1251125113;
  margin: 0 0 0.3em;
  color: #fff;
}

@media screen and (min-width: 750.2px) {
  .pl-product__name {
    font-size: 33px;
  }
}

.pl-product__summary {
  display: block;
  width: 100%;
  font-size: 12px;
  line-height: 1.99940012;
  margin: 0 0 1em;
  color: #fff;
}

@media screen and (min-width: 750.2px) {
  .pl-product__summary {
    font-size: 17px;
  }
}

.pl-product__price {
  display: block;
  width: 100%;
  font-size: 17px;
  line-height: 1.1426122729;
  margin: auto 0 0.5em;
  text-align: right;
  color: #fff;
}

@media screen and (min-width: 750.2px) {
  .pl-product__price {
    font-size: 29px;
  }
}

.pl-product__price .lso_price__main__addon,
.pl-product__price .lso_price__addon {
  font-size: 0.7em;
}

.pl-product__nav {
  display: block;
  width: 100%;
  margin-top: 30px;
}

.pl-product__nav__btn {
  position: relative;
  display: block;
  width: 100%;
  max-width: 320px;
  margin-left: auto;
  box-shadow: none;
  outline: 0 !important;
  font-size: 16px;
  line-height: 1.5;
  padding: 10.5px 5px;
  text-align: center;
  text-decoration: none !important;
  color: #fff;
  z-index: 2;
}

.pl-product__nav__btn::after {
  content: "";
  display: block;
  width: 120%;
  height: 150%;
  position: absolute;
  left: -8%;
  bottom: 0;
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/btn.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -1;
}

.pl-product__nav__btn--finished {
  color: #fff;
  background: #6d6d6d;
}

@media screen and (min-width: 750.2px) {
  .pl-product__nav__btn {
    margin-left: auto;
    box-shadow: none;
    vertical-align: middle;
    outline: 0 !important;
    font-size: 20px;
    line-height: 1.5;
    padding: 13px 5px;
    text-align: center;
    text-decoration: none !important;
  }
}

.pl-product__aside {
  margin-top: 30px;
}

.pl-product__image_aside {
  font-size: 16px;
  font-weight: bold;
  padding: 0 3%;
}

@media screen and (min-width: 750.2px) {
  .pl-product__image_aside {
    font-size: 21px;
    font-weight: bold;
    padding: 0 30px;
  }
}

.pl-lineup {
  display: block;
  width: 100%;
}

.pl-lineup__list {
  display: block;
  width: 100%;
}

.pl-lineup__list__item {
  display: block;
  width: 100%;
}

.pl-lineup__list__item::before,
.pl-grid_lineup::before,
.pl-aside::before {
  content: "";
  display: block;
  width: 100%;
  height: 9vw;
  min-height: 30px;
  max-height: 80px;
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/players_line.png);
  background-size: 100%;
  background-repeat: repeat-x;
  margin-bottom: 20px;
}

.pl-lineup__list__item:nth-of-type(2):before {
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/players_line2.png);
}

.pl-lineup__list__item:nth-of-type(3):before {
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/players_line3.png);
}

.pl-lineup__list__item:nth-of-type(4):before {
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/players_line4.png);
}

.pl-grid_lineup::before {
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/players_line.png);
}

.pl-aside::before {
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/players_line2.png);
}

.pl-lineup__list__item + .pl-lineup__list__item {
  margin-top: 50px;
}

@media screen and (min-width: 750.2px) {

  .pl-lineup__list__item::before,
  .pl-grid_lineup::before {
    background-size: contain;
    height: 10vh;
    max-height: 94px;
    min-height: 50px;
  }

  .pl-lineup__list__item + .pl-lineup__list__item {
    margin-top: 120px;
  }
}

@media screen and (min-width: 750.2px) {
  .pl-lineup__list__item:nth-child(odd) .pl-product__layout {
    flex-direction: row;
  }

  .pl-lineup__list__item:nth-child(odd) .pl-product__image img {
    width: 500px;
  }

  .pl-lineup__list__item:nth-child(even) .pl-product__layout {
    flex-direction: row-reverse;
  }

  .pl-lineup__list__item:nth-child(even) .pl-product__image img {
    width: 561px;
  }
}

/* 2023.05.29 */
@media screen and (min-width: 750.2px) {
  .pl-profile__history {
    margin-top: 25px;
  }
}

.pl-profile__history::before,
.pl-profile__history::after {
  max-width: 100%;
}

.pl-history {
  display: block;
  width: 100%;
  padding: 15px 0;
}

.pl-history__list {
  list-style: none;
  padding-left: 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}

.pl-history__list > li {
  display: block;
}

.pl-history__list > li + li::before {
  content: "、";
}

.plpage__aside .players-sokonvisualgoods-series {
  display: block;
  position: relative;
  background: #009740;
  padding: 10px;
  text-align: center;
  color: #fff;
  font-size: 27px;
  font-weight: bold;
}

.plpage__aside .players-sokonvisualgoods-series::after {
  content: "";
  display: block;
  width: 0.7em;
  height: 0.7em;
  border-style: solid;
  border-width: 2px 2px 0px 0px;
  border-color: #fff #fff transparent transparent;
  position: absolute;
  right: 3%;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  transition: transform 0.2s;
}

.plpage__aside .players-sokonvisualgoods-series:hover::after {
  transform: translate(10px, -50%) rotate(45deg);
}

/*
 * Grid lineup
------------------------------------------------*/
.pl-grid_lineup {
  display: block;
  width: 100%;
  overflow: hidden;
  margin-top: 100px;
}

.pl-grid_lineup__list {
  position: relative;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  width: auto;
  margin-left: -5px;
  margin-right: -5px;
  z-index: 2;
  background: #fff;
}

@media screen and (max-width: 750.1px) {
  .box_shadow {
    position: relative;
    padding: 4%;
    margin-top: 10px;
  }

  .box_shadow::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(-135deg, rgb(13, 204, 255) 0%, rgb(32, 51, 172) 100%);
    position: absolute;
    z-index: 0;
  }

  .box_shadow::before {
    top: 0%;
    left: 0%;
  }

  .box_shadow::after {
    bottom: 0;
    right: 0;
  }
}

@media screen and (min-width: 750.2px) {
  .box_shadow {
    position: relative;
    padding: 30px;
  }

  .box_shadow::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(-135deg, rgb(13, 204, 255) 0%, rgb(32, 51, 172) 100%);
    position: absolute;
    z-index: 0;
  }

  .box_shadow::before {
    bottom: 10px;
    right: 10px;
  }

  .box_shadow::after {
    top: 10px;
    left: 10px;
  }
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__list {
    width: 100%;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    border-style: solid;
    border-width: 0 0 0 1px;
    border-color: #cccccc;
  }
}

.pl-grid_lineup__list__item {
  display: flex;
  margin: 0 0 40px;
  padding-left: 10px;
  padding-right: 10px;
  flex: 0 0 100%;
  max-width: 100%;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__list__item {
    display: block;
    margin: 0;
    padding: 0;
    flex: 0 0 50%;
    max-width: 50%;
    border-style: solid;
    border-width: 0 1px 1px 0;
    border-color: #cccccc;
  }

  .pl-grid_lineup__list__item:nth-child(-n + 3) {
    border-width: 1px 1px 1px 0;
  }
}

.pl-grid_lineup__image {
  display: block;
  width: 100%;
  height: auto;
  margin: 0;
  border: solid 1px #ccc;
}

.pl-grid_lineup__image img {
  display: block;
  width: 100%;
  height: auto;
}

.pl-grid_lineup__name {
  display: block;
  font-size: 16px;
  font-weight: bold;
  margin: 0 0 20px;
  line-height: 1.3;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__name {
    font-size: 22px;
  }
}

.pl-grid_lineup__summary {
  display: block;
  font-size: 13px;
  font-weight: normal;
  margin: 0 0 10px;
  line-height: 1.625;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__summary {
    font-size: 16px;
  }
}

.pl-grid_lineup__name + .pl-grid_lineup__summary {
  margin-top: -10px;
}

.pl-grid_lineup__price {
  font-size: 16px;
  font-weight: bold;
  margin: auto 0 15px;
  line-height: 1.3;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__price {
    margin: 0 0 15px;
    font-size: 20px;
  }
}

.pl-grid_lineup__block {
  display: flex;
  flex-direction: column;
  position: relative;
  width: 100%;
  height: auto;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__block {
    display: block;
  }
}

.pl-grid_lineup__block__image {
  display: block;
  position: relative;
  margin: 15px 0;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__block__image {
    margin: 0;
  }
}

.pl-grid_lineup__block__body {
  width: 100%;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__block__body {
    display: block;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    padding: 30px 20px 20px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 5;
    margin: auto;
    color: #fff;
    background: rgba(0, 34, 72, 0.7);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s cubic-bezier(0.42, 0.03, 0.4, 0.93), visibility 0s ease 0.4s;
  }
}

.pl-grid_lineup__block__nav {
  display: block;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__block__nav {
    margin-top: auto;
  }
}

.pl-grid_lineup__block__nav__btn {
  display: block;
  width: 100%;
  box-shadow: none;
  outline: 0 !important;
  font-size: 18px;
  line-height: 1.5;
  padding: 49px 5px 20px;
  text-align: center;
  text-decoration: none !important;
  color: #ffffff;
  font-weight: bold;
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/btn.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}


.pl-grid_lineup__block__nav__btn--pre_release {
  color: #333;
  background: #f3f3f3;
}

.pl-grid_lineup__block__nav__btn--finished {
  color: #fff;
  background: #6d6d6d;
}

@media screen and (min-width: 750.2px) {
  .pl-grid_lineup__block:hover {
    opacity: 1 !important;
  }

  .pl-grid_lineup__block:hover .pl-grid_lineup__block__body {
    opacity: 1;
    visibility: visible;
    transition: opacity 0.4s cubic-bezier(0.42, 0.03, 0.4, 0.93), visibility 0s;
  }

  .pl-grid_lineup__block:hover .pl-grid_lineup__block__nav__btn {
    transform: translateY(0%);
  }
}


.pl-aside {
  margin-top: 50px;
  padding: 20px 3%;
  text-align: center;
}

.pl-aside-link {
  margin-top: clamp(50px, 10vw, 100px);
}

.pl-aside-link a {
  position: relative;
  display: inline-block;
  background: linear-gradient(90deg, #1d2087 0%, #1ecafd 70%);
  padding: 14px 100px;
  color: #fff;
  font-weight: bold;
  font-size: 32px;
  border-radius: 25px;
}

.pl-aside-link a::after {
  content: "";
  display: block;
  width: 80px;
  height: 80px;
  position: absolute;
  right: 0;
  top: 0;
  background-image: url(/assets/sokonvisualgoods-jyutyu/images/fire.png);
  background-size: contain;
  background-position: left bottom;
  background-repeat: no-repeat;
  transform: translate(30px, -40px);
}


@media screen and (max-width: 750.1px) {

  .pl-aside-link a {
    position: relative;
    display: inline-block;
    background: linear-gradient(90deg, #1d2087 0%, #1ecafd 70%);
    padding: 14px 10px;
    color: #fff;
    font-weight: bold;
    font-size: 21px;
    border-radius: 25px;
    width: 100%;
  }

  .pl-aside-link a::after {
    content: "";
    display: block;
    width: 70px;
    height: 70px;
    position: absolute;
    right: 0;
    top: 0;
    background-image: url(/assets/sokonvisualgoods-jyutyu/images/fire.png);
    background-size: contain;
    background-position: left bottom;
    background-repeat: no-repeat;
    transform: translate(16px, -40px);
  }
}