@charset "UTF-8";
/* ====================
Layout
 ==================== */
/* ====================
Project
 ==================== */
.p-bdcd {
  position: relative;
  margin: 0 auto;
  padding: 10px 0 100px;
  width: 100%;
  max-width: 1400px;
}

.p-bdcd__container {
  position: relative;
  margin: 0 auto;
  padding: 12px 0;
  width: 73.143%;
}

.p-bdcd__header {
  position: relative;
  margin: 0 auto 62px;
  width: 100%;
}

.p-bdcd__btn {
  position: relative;
  -webkit-transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  margin: 50px auto 0;
  width: 635px;
}

.p-bdcd__btn-img {
  display: block;
  position: relative;
}

[data-ua="pc"] .p-bdcd__btn:hover {
  opacity: .6;
}

.p-bdcd__inner {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd__coming {
  display: none;
  position: relative;
  margin: 200px auto;
  width: 100%;
  font-size: 32px;
  text-align: center;
}

.p-bdcd__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 auto -50px;
  width: 100%;
}

.p-bdcd__list-item {
  display: block;
  position: relative;
  margin: 0 3.2% 50px 0;
  width: 22.6%;
}

.p-bdcd__footer {
  position: relative;
  margin-top: 64px;
  padding-top: 48px;
  width: 100%;
  text-align: center;
}

.p-bdcd__footer::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  border-top: 1px solid #fff;
  width: 100%;
  height: 1px;
  content: "";
}

.p-bdcd__back {
  display: inline-block;
  position: relative;
  -webkit-transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  margin: 0 auto;
}

[data-ua="pc"] .p-bdcd__back:hover {
  opacity: .6;
}

.p-bdcd__back-text {
  display: block;
  position: relative;
  padding: 8px 20px 8px 40px;
  font-size: 24px;
  font-family: 'Cormorant Infant', YakuHanMP_Noto, 'Noto Serif JP', "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ 明朝", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
}

.p-bdcd__back-text::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
  background: url("../img/common/arrow_s.svg") no-repeat center;
  background-size: contain;
  width: 20px;
  height: 100%;
  content: "";
}

[data-ua="pc"] .p-bdcd__back:hover .p-bdcd__back-text::before {
  -webkit-animation: arrow-1 1.6s linear infinite;
  animation: arrow-1 1.6s linear infinite;
}

.p-bdcd_cat {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_cat__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-bdcd_cat__list-item {
  display: block;
  position: relative;
}

.p-bdcd_cat__text {
  display: block;
  position: relative;
  -webkit-transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  background: #bd0100;
  padding: 10px 20px;
  width: 100%;
  color: #fff;
  text-align: center;
}

.is-current .p-bdcd_cat__text {
  background: #000;
}

[data-ua="pc"] .p-bdcd_cat__text:hover {
  opacity: .6;
}

.p-bdcd_data {
  display: block;
  position: relative;
  -webkit-transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  transition: opacity 0.8s cubic-bezier(0.25, 1, 0.5, 1);
  width: 100%;
}

[data-ua="pc"] .p-bdcd_data:hover {
  opacity: .6;
}

.p-bdcd_data__thumb {
  position: relative;
  padding-top: 100%;
  width: 100%;
}

.p-bdcd_data__thumb-img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.p-bdcd_data__thumb-img::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  border: 1px solid #fff;
  width: 100%;
  height: 100%;
  content: "";
}

.p-bdcd_data__text {
  display: block;
  position: relative;
  margin-top: 10px;
  font-size: 16px;
  line-height: 2;
  text-align: left;
}

.p-bdcd_in {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_in__header {
  position: relative;
  margin: 0 auto 42px;
  width: 100%;
}

.p-bdcd_in__title {
  position: relative;
  margin: 0 auto;
  width: 100%;
  font-size: 32px;
  line-height: 1.4;
}

.p-bdcd_in__description {
  position: relative;
  margin: 30px auto 0;
  width: 100%;
  line-height: 1.8;
}

.p-bdcd_in__inner {
  position: relative;
  margin: 0 auto;
  width: 100%;
  text-align: center;
}

.p-bdcd_in__footer {
  position: relative;
  margin: 58px auto 0;
  width: 100%;
}

.p-bdcd_detail {
  position: relative;
  margin: 0 auto;
  background: #000;
  padding: 50px 20px 50px 40px;
  width: 100%;
}

.p-bdcd_detail + .p-bdcd_detail {
  margin-top: 32px;
}

.p-bdcd_detail__header {
  position: relative;
  margin-right: 38px;
  width: 330px;
}

.p-bdcd_detail__img {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_detail__img img {
  width: 100%;
}

.p-bdcd_detail__btn {
  position: relative;
  margin: 32px auto 0;
  width: 86%;
}

.p-bdcd_detail__btn + .p-bdcd_detail__btn {
  margin-top: 10px;
}

.p-bdcd_detail__btn-text {
  display: block;
  position: relative;
  cursor: pointer;
  border-radius: 200px;
  background: #bd0100;
  padding: 12px 20px;
}

.p-bdcd_detail__btn-text::before {
  display: block;
  position: absolute;
  top: 0;
  left: 20px;
  width: 16px;
  height: 100%;
  content: "";
}

.-shop .p-bdcd_detail__btn-text::before {
  background: url("../img/bd-cd/icon_cart.png") no-repeat center;
  background-size: contain;
}

.-dl .p-bdcd_detail__btn-text::before {
  background: url("../img/bd-cd/icon_dl.png") no-repeat center;
  background-size: contain;
}

.p-bdcd_detail__inner {
  position: relative;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 0px;
  flex: 1 1 0;
  text-align: left;
}

.p-bdcd_detail__type {
  display: table;
  position: relative;
  margin-bottom: 18px;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.2;
}

.p-bdcd_detail__title {
  display: block;
  position: relative;
  margin-bottom: 22px;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 1px;
}

.p-bdcd_detail__info {
  position: relative;
  margin: 20px auto 0;
  width: 100%;
  font-size: 14px;
  line-height: 1.3;
}

.p-bdcd_detail__info + .p-bdcd_detail__info {
  margin-top: 12px;
}

.p-bdcd_detail__text {
  position: relative;
  margin: 30px auto 0;
  width: 100%;
  font-size: 15px;
  line-height: 1.6;
}

.p-bdcd_detail__text a {
  text-decoration: underline;
}

.p-bdcd_detail__text a:hover {
  text-decoration: none;
}

.p-bdcd_detail__text img {
  max-width: 80%;
  height: auto !important;
}

.p-bdcd_detail__text iframe {
  max-width: 80%;
}

.p-bdcd_disc {
  position: relative;
  margin: 26px auto 0;
  width: 100%;
}

.p-bdcd_disc__title {
  display: table;
  position: relative;
  margin: 34px 0 18px;
  background: #bd0100;
  padding: 6px 12px 4px;
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  line-height: 1.2;
}

.p-bdcd_disc__title:first-child {
  margin-top: 0;
}

.p-bdcd_disc__intro {
  position: relative;
  margin: 0 auto 10px;
  width: 100%;
  font-size: 15px;
  line-height: 1.6;
}

.p-bdcd_disc__text {
  position: relative;
  margin: 30px auto 0;
  width: 100%;
  font-size: 15px;
  line-height: 1.6;
}

.p-bdcd_disc__text a {
  text-decoration: underline;
}

.p-bdcd_disc__text a:hover {
  text-decoration: none;
}

.p-bdcd_disc__text img {
  max-width: 80%;
  height: auto !important;
}

.p-bdcd_disc__text iframe {
  max-width: 80%;
}

.p-bdcd_disc__list {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_disc__list-item:nth-child(odd) {
  background: #4c4c4c;
}

.p-bdcd_disc__list-item:nth-child(even) {
  background: #3e3e3e;
}

.p-bdcd_disc_data {
  display: block;
  position: relative;
  padding: 20px;
}

.p-bdcd_disc_data__cap {
  display: block;
  margin-right: 8px;
  font-size: 12px;
}

.p-bdcd_disc_data__name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  min-width: 0;
  font-size: 14px;
  line-height: 1.6;
}

.p-bdcd_disc_data__name-sub {
  display: block;
  margin-right: 8px;
}

.p-bdcd_disc_data__name-main {
  display: block;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 0px;
  flex: 1 1 0;
  min-width: 0;
}

.p-bdcd_disc_data__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  margin-left: 16px;
  max-width: 205px;
}

.p-bdcd_disc_data__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 200px;
  background: #bd0100;
  padding: 4px;
  width: 100px;
}

.p-bdcd_disc_data__btn + .p-bdcd_disc_data__btn {
  margin-left: 5px;
}

.p-bdcd_disc_data__btn-img {
  display: block;
  position: relative;
  margin-right: 6px;
  width: 20px;
}

.p-bdcd_disc_data__btn-text {
  position: relative;
  font-size: 12px;
  line-height: 1;
}

.p-bdcd_disc_data__player {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 0;
  padding-left: 27px;
  width: 92px;
  height: 28px;
}

.p-bdcd_disc_data__player-icon {
  position: absolute;
  top: 4px;
  left: 2px;
  z-index: 1;
  background-size: 20px 20px;
  width: 100%;
  height: 20px;
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: left center;
  object-position: left center;
}

.p-bdcd_disc_data__player-text {
  position: relative;
  font-size: 12px;
  line-height: 1;
}

.p-bdcd_sp {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_sp__header {
  position: relative;
  margin: 0 auto 28px;
  width: 100%;
}

.p-bdcd_sp__title {
  display: block;
  position: relative;
  font-weight: 700;
  font-size: 38px;
  font-family: 'Noto Serif JP', "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ 明朝", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  letter-spacing: 3px;
  text-align: left;
}

.p-bdcd_sp__inner {
  position: relative;
  width: 100%;
  font-size: 15px;
  line-height: 2;
  letter-spacing: .8px;
}

.p-bdcd_sp__inner a {
  text-decoration: underline;
}

.p-bdcd_sp__inner a:hover {
  text-decoration: none;
}

.p-bdcd_sp__inner img {
  max-width: 80%;
  height: auto !important;
}

.p-bdcd_sp__inner iframe {
  max-width: 80%;
}

.p-bdcd_modal {
  position: relative;
  margin: 0 auto;
  border-radius: 40px;
  padding: 56px;
  padding: 60px;
  width: 100%;
}

.p-bdcd_modal__name {
  display: block;
  position: relative;
  margin-bottom: 28px;
  font-weight: 700;
  font-size: 34px;
  line-height: 1.3;
  font-family: 'Noto Serif JP', "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ 明朝", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  letter-spacing: 3px;
}

.p-bdcd_modal__text {
  font-size: 25.6px;
  font-size: 1.6rem;
  line-height: 1.9;
  text-align: left;
}

.p-bdcd_modal__list {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 800px;
  font-size: 0;
  letter-spacing: -.4em;
  text-align: center;
}

.p-bdcd_modal__item {
  display: inline-block;
  vertical-align: top;
  width: 24%;
  font-size: 16px;
  font-size: 1rem;
  letter-spacing: normal;
}

.p-bdcd_modal__item img {
  width: 100%;
}

.p-bdcd_modal__download {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_modal__download-title {
  display: none !important;
}

.p-bdcd_modal__download-qr {
  display: none !important;
}

.m-modal__content {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  margin-left: 50px;
}

.p-bdcd_novelty__header {
  position: relative;
  margin: 0 auto 52px;
  width: 100%;
}

.p-bdcd_novelty__title {
  display: table;
  position: relative;
  background: #000;
  padding: 1px 8px 4px;
  font-size: 28px;
  line-height: 1.3;
}

.p-bdcd_novelty__text {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

.p-bdcd_novelty__text {
  position: relative;
  margin: 0 auto;
  width: 100%;
  font-size: 15px;
  line-height: 2;
}

.p-bdcd_novelty__text img {
  width: auto;
  max-width: 100% !important;
}

.p-bdcd_novelty__text iframe,
.p-bdcd_novelty__text video {
  display: block;
  max-width: 100% !important;
}

.p-bdcd_novelty__text h3 {
  margin-bottom: 22px;
  font-size: 20px;
}

.p-bdcd_novelty__text strong {
  vertical-align: top;
}

.p-bdcd_novelty__text p + p {
  margin-top: 28px;
}

/* ====================
COMPONENT
 ==================== */

@media screen and (max-width: 960px){
  .p-bdcd {
    padding: 60px 0 80px;
  }
  .p-bdcd__container {
    width: 90.667%;
  }
  .p-bdcd__header {
    margin-bottom: 50px;
  }
  .p-bdcd__btn {
    margin-top: 24px;
    width: 97%;
  }
  .p-bdcd__list {
    margin-bottom: -20px;
  }
  .p-bdcd__list-item {
    margin: 0 4% 20px 0;
    width: 48%;
  }
  .p-bdcd__list-item:nth-child(2n) {
    margin-right: 0;
  }
  .p-bdcd__footer {
    margin-top: 28px;
    padding-top: 28px;
  }
  .p-bdcd__back-text {
    padding: 8px 10px 8px 28px;
    font-size: 16px;
  }
  .p-bdcd__back-text::before {
    width: 18px;
  }
  .p-bdcd_cat__list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
  .p-bdcd_cat__list-item {
    margin: 0 4% 10px 0;
    width: 48%;
  }
  .p-bdcd_cat__list-item:nth-child(2n) {
    margin-right: 0;
  }
  .p-bdcd_cat__text {
    font-size: 12px;
  }
  .p-bdcd_data__text {
    margin-top: 8px;
    font-size: 12px;
    line-height: 1.8;
  }
  .p-bdcd_in__title {
    font-size: 15px;
    line-height: 1.5;
  }
  .p-bdcd_in__description {
    margin-top: 12px;
    font-size: 12px;
  }
  .p-bdcd_in__inner {
    left: -5.147%;
    width: 110.294%;
  }
  .p-bdcd_in__footer {
    margin-top: 38px;
  }
  .p-bdcd_detail {
    padding: 40px 18px;
  }
  .p-bdcd_detail__header {
    position: relative;
    margin: 0 auto 38px;
    width: 100%;
  }
  .p-bdcd_detail__btn {
    margin-top: 20px;
    width: 84%;
  }
  .p-bdcd_detail__btn-text {
    padding: 10px 20px;
  }
  .p-bdcd_detail__btn-text::before {
    left: 28px;
    width: 18px;
  }
  .p-bdcd_detail__type {
    margin-bottom: 8px;
    font-size: 10px;
  }
  .p-bdcd_detail__title {
    font-size: 15px;
    line-height: 1.6;
  }
  .p-bdcd_detail__info {
    font-size: 12px;
  }
  .p-bdcd_detail__info + .p-bdcd_detail__info {
    margin-top: 4px;
  }
  .p-bdcd_detail__text {
    font-size: 12px;
  }
  .p-bdcd_detail__text img {
    max-width: 100%;
  }
  .p-bdcd_detail__text iframe {
    max-width: 100%;
  }
  .p-bdcd_disc__title {
    margin-bottom: 8px;
    padding: 4px 8px 2px;
    font-size: 10px;
  }
  .p-bdcd_disc__intro {
    font-size: 12px;
  }
  .p-bdcd_disc__text {
    font-size: 12px;
  }
  .p-bdcd_disc__text img {
    max-width: 100%;
  }
  .p-bdcd_disc__text iframe {
    max-width: 100%;
  }
  .p-bdcd_disc_data {
    padding: 12px;
  }
  .p-bdcd_disc_data__name {
    font-size: 12px;
  }
  .p-bdcd_disc_data__link {
    margin: 10px auto 0;
    width: 100%;
    max-width: none;
  }
  .p-bdcd_disc_data__btn {
    padding: 3px;
    width: 80px;
  }
  .p-bdcd_disc_data__btn-img {
    width: 14px;
  }
  .p-bdcd_disc_data__btn-text {
    font-size: 10px;
  }
  .p-bdcd_disc_data__player {
    height: 16px;
  }
  .p-bdcd_disc_data__player-icon {
    top: -1px;
    background-size: 10px 4px;
    width: 14px;
    height: 4px;
    -o-object-fit: contain;
    object-fit: contain;
  }
  .p-bdcd_disc_data__player-text {
    font-size: 10px;
  }
  .p-bdcd_sp__header {
    margin-bottom: 18px;
  }
  .p-bdcd_sp__title {
    font-size: 20px;
    letter-spacing: 1.2px;
  }
  .p-bdcd_sp__inner {
    font-size: 12px;
  }
  .p-bdcd_sp__inner img {
    max-width: 100%;
  }
  .p-bdcd_sp__inner iframe {
    max-width: 100%;
  }
  .p-bdcd_modal {
    border-radius: 20px;
    padding: 26px;
  }
  .p-bdcd_modal {
    padding: 28px 24px;
  }
  .p-bdcd_modal__name {
    margin-bottom: 12px;
    font-size: 20px;
    letter-spacing: 1.2px;
  }
  .p-bdcd_modal__text {
    font-size: 1.5rem;
    line-height: 2;
  }
  .p-bdcd_modal__item {
    margin: 0 1.5% 6px 0;
    width: 31%;
  }
  .p-bdcd_modal__item:nth-child(3n), .p-bdcd_modal__item:last-child {
    margin-right: 0;
  }
  .m-modal__content {
    top: 45%;
    left: 50%;
    margin-left: 0;
  }
  .p-bdcd_novelty__header {
    margin-bottom: 35px;
  }
  .p-bdcd_novelty__title {
    padding: 1px 8px 2px;
    font-size: 20px;
  }
  .p-bdcd_novelty__text img {
    height: auto !important;
  }
  .p-bdcd_novelty__text iframe,
  .p-bdcd_novelty__text video {
    width: 100% !important;
    height: 51vw !important;
  }
  .p-bdcd_novelty__text {
    font-size: 12px;
  }
  .p-bdcd_novelty__text h3 {
    margin-bottom: 20px;
    font-size: 15px;
    line-height: 1.8em;
    letter-spacing: 0.1em;
  }
}

@media screen and (min-width: 961px){
  .p-bdcd__list-item:nth-child(4n) {
    margin-right: 0;
  }
  .p-bdcd_cat__list-item {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    max-width: 240px;
  }
  .p-bdcd_cat__list-item + .p-bdcd_cat__list-item {
    margin-left: 10px;
  }
  .p-bdcd_detail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p-bdcd_detail__btn-text {
    -webkit-transition: opacity 0.6s cubic-bezier(0.25, 1, 0.5, 1);
    transition: opacity 0.6s cubic-bezier(0.25, 1, 0.5, 1);
  }
  .p-bdcd_detail__btn-text:hover {
    opacity: .6;
  }
  .p-bdcd_disc_data__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .p-bdcd_disc_data__name {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 0px;
    flex: 1 1 0;
  }
  .p-bdcd_modal__item {
    margin: 0 1% 10px 0;
  }
  .p-bdcd_modal__item:nth-child(4n), .p-bdcd_modal__item:last-child {
    margin-right: 0;
  }
  .p-bdcd_modal__item {
    -webkit-transition: opacity 0.6s cubic-bezier(0.25, 1, 0.5, 1);
    transition: opacity 0.6s cubic-bezier(0.25, 1, 0.5, 1);
  }
  .p-bdcd_modal__item:hover {
    opacity: .6;
  }
  .p-bdcd_novelty__text a:hover {
    text-decoration: none;
  }
  .p-bdcd_novelty__text {
    margin: 0 auto;
    max-width: 1040px;
  }
}

@media (-ms-high-contrast: none){
  .p-bdcd_disc_data__player-icon {
    width: 20px;
  }
}
