﻿@charset "UTF-8";

/* 商品詳細（ＰＣ） ファーストビュー用 */

/* sys/base_form.css のコピー ここから */

/* ----ボタン---- */
select{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url(../../img/usr/common/arrow_bottom.png);
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 24px;
  padding-right: 40px;
}

.btn-primary {
  border: 1px solid var(--color-accent);
  color: #fff;
  background: var(--color-accent);
}

/* ここまで sys/base_form.css のコピー */


/* sys/base_misc.css のコピー ここから */

/* ----テキストカラー----*/

.price {
  color: #333;
}

/* ----商品説明リスト---- */

.goods-detail-description {
  display: table;
  width: 100%;
}

.goods-detail-description dt {
  display: table-cell;
  width: 100px;
  font-weight: bold;
}

.goods-detail-description dd {
  display: table-cell;
}

/* ----画像センタリング配置---- */

.img-center {
  display: -webkit-flex;
  display: flex;
  justify-content: center;
  align-items: center;
}

.img-center img {
  text-align: center;
  max-height: 100%;
  max-width: 100%;
  width: auto;
  height: auto;
}


/* ここまで sys/base_misc.css のコピー */


/* sys/layout.css のコピー ここから */
.wrapper {
  width: 100%;
  padding-top: 130px;
}

.container {
  width: 1200px;
  width: calc(100% - 240px);
  min-width: 1200px;
  margin: 0 auto;
}

.pane-header .container {
  display: flex;
  align-items: center;
  height: 130px;
}

.pane-globalnav {
  width: 100%;
}

.pane-contents {
  min-height: 600px;
  padding-bottom: 50px;
}

.pane-contents .container {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto 1fr;
  /* IE11 */
  display: -ms-grid;
  -ms-grid-columns: auto 1fr;
  -ms-grid-rows: auto 1fr;
}

.pane-left-menu {
  grid-column-start: 1;
  grid-column-end: 2;
  grid-row-start: 1;
  grid-row-end: 3;
  /* IE11 */
  -ms-grid-column: 1;
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  width: 240px;
  margin: 30px 60px 0 0;
}

.pane-main {
  display: block;
  grid-column-start: 2;
  grid-column-end: 3;
  grid-row-start: 1;
  grid-row-end: 2;
  /* IE11 */
  -ms-grid-column: 2;
  -ms-grid-row: 1;
  width: 100%;
}

.pane-right-menu {
  grid-column-start: 2;
  grid-column-end: 3;
  grid-row-start: 2;
  grid-row-end: 3;
  /* IE11 */
  -ms-grid-column: 2;
  -ms-grid-row: 2;
  margin: 30px 0;
  width: 900px;
}

.pane-footer {
  padding: 33px 0;
}

/* ----商品詳細レイアウト---- */

.page-goodspreview .pane-left-menu,
.page-goodspreview .pane-right-menu,
.page-goods .pane-left-menu,
.page-goods .pane-right-menu {
  display: none;
}

.block-goods-detail {
  display: grid;
  grid-template-columns: 1fr 80px 1fr;
  -ms-grid-columns: 1fr 80px 1fr;
}

.pane-goods-header {
  grid-column-start: 1;
  grid-column-end: 3;
  grid-row-start: 1;
  grid-row-end: 2;
  /* IE11 */
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  -ms-grid-row: 1;
  width: 100%;
  margin: 0 0 30px;
  grid-column: 1 / -1;
}

.pane-goods-header:not(:has( *)) {
  margin-bottom: 8px;
}

.pane-goods-left-side {
  grid-column-start: 1;
  grid-column-end: 2;
  grid-row-start: 2;
  grid-row-end: 3;
  /* IE11 */
  -ms-grid-column: 1;
  -ms-grid-row: 2;
  width: 740px;
  margin: 0 60px 0 0;
}

.pane-goods-right-side {
  grid-column-start: 2;
  grid-column-end: 3;
  grid-row-start: 2;
  grid-row-end: 3;
  /* IE11 */
  -ms-grid-column: 2;
  -ms-grid-row: 2;
  width: 400px;
}

.pane-goods-center {
  grid-column-start: 1;
  grid-column-end: 3;
  grid-row-start: 3;
  grid-row-end: 4;
  /* IE11 */
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  -ms-grid-row: 3;
  width: 100%;
  grid-column: 1 / -1;
}

.pane-goods-footer {
  grid-column-start: 1;
  grid-column-end: 3;
  grid-row-start: 4;
  grid-row-end: 5;
  /* IE11 */
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  -ms-grid-row: 4;
  width: 100%;
  grid-column: 1 / -1;
}

/* ここまで sys/layout.css のコピー */


/* sys/block_common.css のコピー ここから */

/* ----パンくずリスト---- */
.block-topic-path {
  padding: 16px 0;
  font-size: 12px;
}

.block-topic-path--list{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 4px;
  overflow: hidden;
  min-width: 0;
}

.block-topic-path--list li {
  position: relative;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0;
  flex-shrink: 0;
}

.block-topic-path--list li.is-last-visible {
  flex-shrink: 1;
  min-width: 0;
  overflow: hidden;
}

.block-topic-path--list li.is-last-visible a{
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.block-topic-path--delimiter{
  font-size: 0;
  width: 16px;
  height: 16px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.block-topic-path--delimiter::after {
  content: "";
  width: 6px;
  height: 6px;
  border-top: 1px solid #808080;
  border-right: 1px solid #808080;
  display: inline-block;
  transform: rotate(45deg);
}

.block-topic-path--list a {
  color: #808080;
  text-decoration: none;
}

.block-topic-path--list .block-topic-path--item__home a {
  padding-left: 0;
}

/* ----左メニューブロック共通---- */

.pane-left-menu .pane-block--title {
  font-size: 16px;
  border-top: #444 1px solid;
  padding: 16px 0;
  font-weight: bold;
  margin-bottom: 0;
}

.pane-block--title {
  margin: 20px 0;
  font-size: 26px;
  font-weight: normal;
}


/* ここまで sys/block_common.css のコピー */



/* sys/block_goods.css のコピー ここから */

/* ----商品詳細画面---- */

.block-goods-detail--promotion-freespace {
  margin-bottom: 10px;
}

.block-src-l {
  z-index: 3 !important;
}

.block-src-l figure {
  height: auto;
  aspect-ratio: 1/1;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.block-add-cart--btn {
  margin-top: 10px;
  padding: 12px 0;
  font-size: 18px;
  width: 280px;
}

.block-contact-about-goods--btn {
  margin-top: 10px;
  padding: 6px 0;
  font-size: 16px;
  width: 280px;
}

.block-goods-price {
  margin: 10px 0;
}

.block-goods-price .net-price{
  display: none;
}

.block-goods-price--price {
  font-size: 24px;
  font-weight: bold;
}

.block-accessory-list {
  width: 100%;
}

.block-goods-footer-cart {
  text-align: center;
  display: none;
}

.block-goods-detail .swiper-slider-main {
  overflow: hidden;
}

.block-goods-detail .swiper-slider-main img {
  width: auto;
  height: auto;
}

/* バリエーション切り替えボタン */
.block-variation--item-dropdown {
  border: 1px solid #CCC;
  border-radius: 4px;
  padding: 14px 40px 14px 16px;
}

.pane-goods-right-side form > .block-variation:has(.block-variation-head) {
  border-bottom: 1px solid #CCC;
  margin: 0 0 40px;
}

.block-variation--item-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.block-variation--item {
  display: inline-block;
  font-size: 14px;
  margin-right: 5px;
}
.block-variation.block-color{
  margin: 0 0 40px;
}

.pane-goods-right-side:has(.block-variation-head) .block-goods-price, .pane-goods-right-side:has(.block-variation--item-dropdown) .block-goods-price {
  margin-bottom: 24px;
}

.pane-goods-right-side form > .block-variation:has(.block-variation--item-dropdown) {
  margin: 0 0 24px;
}

.block-variation.block-size{
  margin: 0 0 24px;
}

.block-variation--name.block-color--name,
.block-variation--name.block-size--name {
  font-size: 16px;
  font-weight: 400;
  margin: 0;
  padding: 0;
  border: 0;
  width: 6em;
  position: relative;
}

.block-variation--name.block-color--name::after,
.block-variation--name.block-size--name::after {
  content: "：";
  position: absolute;
  top: 0;
  right: 0;
}

.block-variation-head{
  display: flex;
  margin: 0 0 8px;
}

.block-variation--selected-item{
  padding-left: 10px;
}

.block-variation--item {
  vertical-align: top;
  margin: 0;
}

.block-color--item dt {
  width: 83px;
  height: 83px;
  border: 1px solid #CCC;
  border-radius: 4px;
}

.block-size--item dt {
  font-size: 13px;
  width: 83px;
  height: 59px;
  border: 1px solid #CCC;
  border-radius: 4px;
}

.block-variation--item.size-disable-stock dt {
  border: 2px dashed #CCC;
}

.block-variation--item.color-disable-stock dt {
  border: 2px dashed #CCC;
}

.block-variation--item.active dt {
  border: 2px solid var(--color-accent);
}

.block-color--item-term figure,
.block-size--item-term figure {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
}

.block-color--item-term img {
  max-width: 100%;
  max-height: 100%;
}

.block-variation--item-description{
  font-size: 13px;
  text-align: center;
  padding: 4px 0 0;
}

.block-size--item-term span {
  width: 100%;
  height: 100%;
  padding: 2px;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 商品詳細ユーザーレビュー */
.block-goods-user-review h2 {
  background-color: #f5f5f5;
  font-size: 22px;
  padding: 10px 15px;
}

/* ----アイコン---- */
.block-icon img {
  width: 32px;
}

/* ここまで sys/block_goods.css のコピー */


/* usr/layout.css のコピー ここから */

.wrapper {
  width: 100%;
  min-width: 1200px;
  background: #fff;
}

.pane-goods-left-side {
  grid-column: 1 / 2;
  width: 100%;
  margin: 0;
  min-width: 0;
}

.pane-goods-right-side {
  grid-column: 3 / 4;
  width: 100%;
  min-width: 0;
}

/* ここまで usr/layout.css のコピー */


/* usr/block.css のコピー ここから */

.pane-goods-left-side {
  display: flex;
  gap: 20px;
}

.pane-goods-left-side .swiper-slider-main {
  width: calc(100% - 80px);
  order: 20;
}

.pane-goods-left-side .block-goods-gallery-thumbnail{
  width: 60px;
  order: 10;
}

.pane-goods-left-side .block-goods-gallery-thumbnail .block-goods-gallery{
  height: 480px;
}

.pane-goods-left-side .block-goods-gallery-thumbnail .block-goods-gallery-src {
  flex-wrap: nowrap;
}

.block-goods-detail--color-variation-goods-image .swiper-slider-main {
  width: calc(100% - 80px);
  order: 20;
}

.pane-goods-left-side .swiper-slider-main p {
  font-size: 12px;
  text-align: center;
  margin-top: 8px;
}

.block-goods-detail--color-variation-goods-image .swiper-slider {
  width: 100%;
}

.block-goods-detail--color-variation-goods-image .swiper-slider .block-goods-detail-line-item {
  width: 100%;
}

.block-goods-detail--color-variation-goods-image .swiper-slider .block-goods-detail-line-item img {
  vertical-align: top;
}

.pane-goods-left-side .block-goods-gallery li {
  display: block;
  width: 100%;
  margin: 0;
}

.pane-goods-left-side .block-goods-gallery li figure {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  border: 1px solid #CCC;
}

.pane-goods-left-side .block-goods-gallery li.swiper-slide-thumb-active figure {
  border-color: var(--color-accent);
}

.block-artist-name{
  font-size: 24px;
  color: #707070;
  margin: 0;
}

.block-artist-name:has(*){
  margin-bottom: 24px;
}

.block-icon {
  font-size: 13px;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 4px;
  margin: 14px 0 0;
}

.block-icon > span {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #CCC;
  border-radius: 2px;
  background: #FFF;
  min-width: 70px;
  height: 24px;
  text-align: center;
  padding-inline: 4px;
}

.block-icon > span.block-icon--format {
  color: #FFF;
  font-weight: bold;
  background: #4D4D4D;
  border-color: #4D4D4D;
  padding-inline: 6px;
}

.block-icon img {
  display: block;
  width: auto;
  height: 24px;
}

.page-goods .block-icon {
  margin: 0 0 40px;
}

.page-goods .block-goods-name h1 {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  margin: 0 0 40px;
  padding: 0;
}

.block-goods-comment {
  margin: 0 0 12px;
  font-size: 14px;
}

.block-goods-comment2 {
  margin: 0 0 40px;
}

.block-caution-list li{
  font-size: 14px;
  color: #CB1925;
  text-indent: -1em;
  padding-left: 1em;
}

.block-goods-price {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-bottom: 1px solid #CCC;
  margin: 0 0 40px;
  padding: 0 0 14px;
}

.pane-goods-right-side:has(.block-variation-head) .block-goods-price {
  margin-bottom: 24px;
}

.block-goods-price .block-goods-price--on-sales-off-percent {
  width: 100%;
  display: none;
}

.block-goods-price .block-goods-price--on-sales-comment {
  font-size: 14px;
  font-weight: 400;
  color: #CB1925;
  margin: 0 0 6px;
  width: 100%;
}

.block-goods-price--default-price {
  font-size: 18px;
  font-weight: bold;
  margin: 4px 16px 0 0;
}

.block-goods-price--default-price .yen{
  font-weight: 400;
  margin-right: 4px;
}

.block-goods-price--price {
  font-size: 28px;
  font-weight: bold;
  color: #333;
}

.block-goods-term--sales-term {
  padding: 6px 0;
  font-size: 14px;
  color: #CB1925;
  display: none;
  width: 100%;
}

.block-goods-price .price::after,
.block-goods-price .default-price::after {
  content: "（税込）";
  font-size: 11px;
  font-weight: normal;
}

.goods-detail-description {
  display: flex;
  padding: 4px 0;
  display: none;
}

.goods-detail-description.block-goods-release-dt,
.goods-detail-description.block-goods-reservation-time,
.goods-detail-description.block-goods-item-code-list {
  display: flex;
}

.goods-detail-description dt {
  display: block;
  width: auto;
  min-width: 6.0em;
  font-weight: normal;
  position: relative;
  padding-right: 1em;
}

.goods-detail-description dt::after {
  content: "：";
  position: absolute;
  right: 0;
  top: 0;
}

.goods-detail-description dd {
  margin-left: 1em;
  display: block;
}

.block-goods-code {
  padding-top: 16px;
  margin-top: 12px;
  display: none;
}

.block-contact-about-goods {
  padding-top: 16px;
  margin-top: 12px;
  display: none;
}

.block-goods-stock {
  display: none;
}

.block-goods-not-available-method {
  margin: 16px 0 4px;
  padding: 16px 0 0;
  border-top: 1px dashed #707070;
}

.block-goods-qty{
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0 0 32px;
  width: 100%;
}

.block-goods-qty input{
  font-weight: 400;
  width: 132px;
  height: 44px;
  text-align: center;
  border: 1px solid #CCC;
  border-radius: 4px;
}

.block-goods-qty button{
  width: 44px;
  height: 44px;
  display: block;
  position: relative;
  background: #FFF;
  border: 1px solid #CCC;
  border-radius: 50%;
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
}

.block-goods-qty button::before{
  content: "";
  width: 12px;
  height: 2px;
  background: var(--color-main);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

.block-goods-qty button.block-goods-qty-plus::after{
  content: "";
  width: 2px;
  height: 12px;
  background: var(--color-main);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

.block-cart-wrap {
  display: flex;
  align-items: flex-end;
  gap: 20px;
  margin: 0 0 40px;
}

.block-cart-wrap > div:not(.block-goods-favorite) {
  width: calc(100% - 84px);
}

.block-add-cart--btn {
  font-size: 20px;
  font-weight: bold;
  width: 100%;
  height: 64px;
  margin: 0;
  padding: 0;
  border-radius: 32px;
  transition: transform .3s;
}

.block-add-cart--btn:not(.btn-fc-group)::before {
  content: "";
  display: inline-block;
  width: 32px;
  height: 32px;
  margin-right: 12px;
  vertical-align: bottom;
  background: url(../../img/usr/common/goods_cart_btn.png) center center / contain no-repeat;
}

.block-goods-favorite{
  width: 64px;
  height: 64px;
  flex-shrink: 0;
}

.block-goods-favorite--btn {
  font-size: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid #CCC;
  border-radius: 50%;
  margin: 0;
  padding: 0;
  position: relative;
}

.block-goods-favorite--btn::before {
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../../img/usr/common/goods_bookmark.png) center center / contain no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

.block-goods-favorite-registed--btn {
  font-size: 0;
  color: var(--color-accent);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid var(--color-accent);
  border-radius: 50%;
  position: absolute;
  margin: 0;
  padding: 0;
  position: relative;
}

.block-goods-favorite-registed--btn::before {
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../../img/usr/common/goods_bookmark_active.png) center center / contain no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

.block-contact-about-goods--btn {
  display: inline;
  padding: 0;
  border: 0;
  text-decoration: underline;
  font-size: 14px;
  background: none;
}

.block-drop-down,
.item_derection > div{
  margin: 0 0 40px;
}

.item_derection input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.block-drop-down__ttl,
.item_derection label{
  font-size: 24px;
  font-weight: bold;
  color: var(--color-text);
  text-align: left;
  display: block;
  width: 100%;
  background: none;
  border: none;
  border-bottom: 1px solid #CCC;
  margin: 0;
  padding: 16px 0;
  cursor: pointer;
  outline: none;
  position: relative;
}

.block-drop-down__ttl::after,
.item_derection label::after{
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%) rotate(45deg);
}

.block-drop-down__ttl.is-active::after,
.item_derection input:checked + label::after{
  top: calc(50% + 2px);
  transform: translateY(-50%) rotate(-135deg);
}

.block-drop-down__contents,
.item_derection input~div{
  display: none;
  padding: 32px 0 0;
}

.pane-goods-center {
  padding: 60px 0 0;
}

.pane-goods-center div.block-goods-comment1, .pane-goods-center div.block-goods-comment2, .pane-goods-center div.block-goods-comment3, .pane-goods-center div.block-goods-comment4, .pane-goods-center div.block-goods-comment5 {
  margin: 40px 0;
}

.pane-goods-center div[class^="block-goods-comment"] + div[class^="block-goods-comment"] {
  margin-top: 0;
}

/*CSSによる商品詳細画面の項目の並び順変更用*/
.pane-goods-right-side form {
  display: flex;
  flex-flow: column wrap;
}

.block-artist-name{
  order: 0;
}

.block-goods-name {
  order: 10;
}

.page-goods .block-icon {
  order: 20;
}

.block-goods-comment {
  order: 30;
}

.block-goods-comment2{
  order: 30;
}

.block-goods-price {
  order: 40;
}

.block-refill-goods {
  order: 45;
}

.block-goods-first-limited-order {
  order: 50;
}
.block-goods-set {
  order: 60;
}

.block-goods-coupon {
  order: 70;
}

.block-goods-promotion {
  order: 80;
}

.block-goods-sales-detail-append {
  order: 90;
}

.block-switch-goods {
  order: 100;
}

.block-goods-ship-schedule {
  order: 110;
}

.block-goods-not-available-method {
  order: 120;
}

.block-variation {
  order: 130;
}

.block-cart-wrap {
  order: 140;
}

.block-add-cart {
  order: 140;
}

.block-custom-order {
  order: 150;
}

.block-no-stock {
  order: 160;
}

.block-outside-sales-period {
  order: 170;
}

.block-arrival-notice {
  order: 180;
}

.block-variation-back-order {
  order: 190;
}

.block-goods-social-gift {
  order: 200;
}

.block-goods-favorite {
  order: 210;
}

.block-goods-store-stock {
  order: 220;
}

.block-goods-code {
  order: 230;
}

.block-goods-brand {
  order: 235;
}

.block-goods-item-code {
  order: 240;
}

.block-goods-item-code2 {
  order: 250;
}

.block-goods-item-code3 {
  order: 260;
}

.block-goods-release-dt {
  order: 270;
}

.block-goods-sns {
  order: 280;
}

.block-goods-class1 {
  order: 290;
}

.block-goods-class2 {
  order: 300;
}

.block-goods-attr1 {
  order: 310;
}

.block-goods-attr2 {
  order: 320;
}

.block-goods-attr3 {
  order: 330;
}

.block-goods-size {
  order: 382;
}

.block-goods-color {
  order: 382;
}

.block-goods-point {
  order: 360;
}

.block-goods-postage {
  order: 370;
}

.block-goods-stock {
  order: 380;
}

.block-goods-sales-time {
  order: 382;
}

.block-goods-item-code-list {
  order: 383;
}

.block-goods-spec {
  order: 390;
}

.block-contact-about-goods {
  order: 400;
}

.block-goods-link {
  order: 410;
}

.block-unisize {
  order: 420;
}

.block-accessory-list {
  order: 430;
}

/* ここまで usr/block.css のコピー */
