@charset "UTF-8";
@media screen and (max-width: 767px) {
  .xs-left {
    text-align: left !important; } }

.font10 {
  font-size: 10px; }

.font11 {
  font-size: 11px; }

.font18 {
  font-size: 18px; }

.font24 {
  font-size: 24px; }

.font28 {
  font-size: 28px; }

@media screen and (max-width: 768px) {
  .xs-font20 {
    font-size: 20px; }
  .xs-font24 {
    font-size: 24px; }
  .xs-font28 {
    font-size: 28px; }
  .xs-font32 {
    font-size: 32px; } }

.bg-grey {
  background-color: #eee; }

.bg-sub-grey {
  background-color: #9c9c9c; }

.bg-blue {
  background-color: #003791; }

.bg-flow {
  background: url("/etc/designs/pscom/ja-jp/catalog/images/flow_dark.jpg") no-repeat;
  background-size: cover; }

@media screen and (max-width: 768px) {
  .xs-bg-alpha {
    background-color: transparent; } }

.mrg03-top {
  margin-top: 0.3em; }

@media screen and (max-width: 768px) {
  .xs-mrg0-top {
    margin-top: 0; }
  .xs-mrg2 {
    margin: 2em; }
  .xs-mrg2-top {
    margin-top: 2em; }
  .xs-mrg2-bottom {
    margin-bottom: 2em; }
  .xs-mrg2-left {
    margin-left: 2em; }
  .xs-mrg2-right {
    margin-right: 2em; } }

.d-table {
  display: table; }

.table-cell {
  display: table-cell; }

@media screen and (max-width: 991px) {
  .sm-block {
    display: block; } }

@media screen and (max-width: 768px) {
  .xs-block {
    display: block; } }

.line-through {
  text-decoration: line-through; }

.pd15 {
  padding: 15px; }

.pd15-top {
  padding-top: 15px; }

.pd15-left {
  padding-left: 15px; }

.pd15-right {
  padding-right: 15px; }

.pd20 {
  padding: 20px; }

.pd20-top {
  padding-top: 20px; }

.pd20-left {
  padding-left: 20px; }

.pd20-right {
  padding-right: 20px; }

.pd20-bottom {
  padding-bottom: 20px; }

@media screen and (max-width: 768px) {
  .xs-pd15-left {
    padding-left: 15px; }
  .xs-pd15-right {
    padding-right: 15px; } }

.solid-top-light {
  border-top: solid 1px #CFCFCF; }

@media screen and (max-width: 768px) {
  .xs-solid-top-light {
    border-top: solid 1px #CFCFCF; } }

.line-narrow {
  line-height: 1.3; }

.ellipsis {
  height: 28.6px;
  overflow: hidden;
  position: relative;
  padding-right: 1.5em;
  word-break: break-all; }
  .ellipsis:before {
    content: "...";
    position: absolute;
    right: 0;
    bottom: 0;
    display: inline-block;
    width: 1.5em; }
  .ellipsis:after {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 1.5em;
    height: 100%;
    background-color: inherit; }

@media screen and (max-width: 768px) {
  .xs-top {
    vertical-align: top; }
  .xs-middle {
    vertical-align: middle; }
  .xs-bottom {
    vertical-align: bottom; } }

.break-all {
  word-break: break-all; }

.psc-of-hidden {
  overflow: hidden; }

.psc-d-block {
  display: block; }

.copyrights p {
  font-size: 10px; }

body {
  word-wrap: break-word;
  overflow-wrap: break-word; }

h1 + div .video
h2 + div .video,
h3 + div .video,
h4 + div .video,
h5 + div .video,
h6 + div .video {
  margin-top: 1em; }

ul.list-style {
  list-style: disc;
  margin-left: 1.5em; }
  ul.list-style li {
    list-style: disc !important; }

ol.list-style {
  list-style: decimal;
  margin-left: 1.5em; }
  ol.list-style li {
    list-style: decimal !important; }

.break-all.break-all-deny {
  word-break: normal; }

@media screen and (max-width: 768px) {
  a:hover {
    color: #00a2ff; } }

.section-game-cover {
  padding: 10px 15px; }

@media screen and (max-width: 992px) {
  .section-game-cover {
    padding-top: 0; } }

.section-catalog-cover {
  padding: 15px 15px; }

@media screen and (max-width: 992px) {
  .section-catalog-cover {
    padding: 0; } }

.section-gallery {
  padding-top: 3em;
  padding-bottom: 3em;
  background-color: #eee; }

@media screen and (max-width: 768px) {
  .section-gallery {
    padding-top: 1.5em;
    padding-bottom: 1.5em; } }

.section-cnt-narrow {
  padding-top: 24px;
  padding-bottom: 24px; }

.row.vertical-layout [class^=col-] {
  margin-top: 15px;
  margin-bottom: 15px; }

.row.vertical-layout + .row.vertical-layout {
  margin-top: 1em; }

@media screen and (max-width: 768px) {
  .row.vertical-layout [class^=col-] {
    margin-top: 2em;
    margin-bottom: 0; } }

/* section-cnt */
/* コンポーネントでsection-cnt-narrowなどのクラスを追加した場合は、それらが優先されるため問題なし */
/* モックで別のクラスを指定していないケース用にsection-cnt-denyクラスを付与して効果を打ち消す */
.section-cnt.section-cnt-deny {
  padding-top: 0;
  padding-bottom: 0; }

.section-game-cover .text-link {
  padding-left: 10px;
  padding-right: 10px;
  margin-top: 5px;
  margin-bottom: 5px;
  display: inline-block; }
  .section-game-cover .text-link a {
    color: #fff; }
    .section-game-cover .text-link a:hover {
      color: #00A2FF; }

a .icon-link-left {
  display: inline-block;
  padding-left: 20px;
  position: relative; }

a .icon-link-left:before {
  content: "";
  width: 15px;
  height: 15px;
  background: url("../../catalog/images/icon_link_before_off.svg") no-repeat;
  position: absolute;
  top: 2px;
  left: 0; }

a:hover .icon-link-left:before {
  content: "";
  width: 15px;
  height: 15px;
  background: url("../../catalog/images/icon_link_before_on.svg") no-repeat;
  position: absolute;
  top: 2px; }

.icon-bookmark {
  background: url("/etc/designs/pscom/ja-jp/catalog/images/bookmark.svg") no-repeat;
  background-position: center left;
  padding-left: 18px; }

.icon-link-no-hover {
  display: inline-block;
  padding-left: 20px;
  position: relative; }
  .icon-link-no-hover:before {
    content: "";
    width: 15px;
    height: 15px;
    background: url("../../catalog/images/icon_link_before_off.svg") no-repeat;
    position: absolute;
    top: -1px;
    left: 0; }

.icon-link-before {
  display: inline-block;
  padding-left: 20px;
  position: relative; }
  .icon-link-before:before {
    content: "";
    width: 15px;
    height: 15px;
    background: url("../../catalog/images/icon_link_before_off.svg") no-repeat;
    position: absolute;
    top: -1px;
    left: 0; }

a:hover .icon-link-before {
  display: inline-block;
  padding-left: 20px;
  position: relative; }
  a:hover .icon-link-before:before {
    content: "";
    width: 15px;
    height: 15px;
    background: url("../../catalog/images/icon_link_before_on.svg") no-repeat;
    position: absolute;
    top: -1px;
    left: 0; }

.icon-anchor-before {
  display: inline-block;
  padding-left: 20px;
  position: relative; }
  .icon-anchor-before:before {
    content: "";
    width: 15px;
    height: 15px;
    background: url("../../catalog/images/icon_link_before_off.svg") no-repeat;
    position: absolute;
    top: -1px;
    left: 0; }

.icon-blank {
  padding-right: 16px; }
  .icon-blank:after {
    display: inline-block;
    width: 14px;
    height: 14px;
    content: '';
    background: url("../../../../../../content/dam/pscom/ja-jp/icon/icon_blank.png");
    background-size: cover;
    position: absolute;
    top: 0;
    right: 0; }

.label-recommend {
  position: relative; }
  .label-recommend:before {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    content: "おすすめのゲームソフト";
    padding: 3.6px 6px;
    display: inline-block;
    background: #0068bf;
    color: #ffffff;
    position: absolute;
    top: 15px;
    left: 15px;
    font-size: 12px; }

.sns-size {
  width: 32px;
  height: 32px; }

@media screen and (max-width: 767px) {
  .sns-size {
    width: 50px;
    height: 50px; } }

.cero {
  width: 30px;
  display: inline-block; }

@media screen and (max-width: 991px) {
  .game-cover {
    margin-left: 0;
    margin-right: 0; }
    .game-cover [class^=col-] {
      margin-top: 0;
      margin-bottom: 0;
      padding-left: 0;
      padding-right: 0; }
    .game-cover img {
      vertical-align: bottom; } }

input[type="text"].game-search {
  width: 100%;
  height: 48px;
  padding: 0 62px 0 14px;
  border: 0;
  outline: 0;
  border-radius: 4px;
  color: #1f1f1f;
  font-size: 14px;
  vertical-align: top;
  box-sizing: border-box; }

.row.information .row > [class*=col-xs-12] + [class*=col-xs-12] {
  margin-top: 0.2em; }

@media screen and (max-width: 767px) {
  .row.information .xs-info-icon {
    position: relative;
    padding-right: 18px; }
    .row.information .xs-info-icon:after {
      display: block;
      content: "";
      background: url("/content/dam/pscom/ja-jp/icon/icon_link.svg") no-repeat;
      background-size: contain;
      background-position: center center;
      width: 15px;
      height: 15px;
      margin: -7px auto;
      position: absolute;
      right: 0;
      top: 50%; } }
