@charset "UTF-8";
:root {
  --gold: #aa8d48;
  --gold-dark: #937223;
  --header-h: 100px;
}

/* * 客製全域
 * */
body.cus-body {
  padding-top: 0;
}

.container-lg {
  width: 1640px;
  padding-left: 20px;
  padding-right: 20px;
  margin: 0 auto;
  position: relative;
}

.g-maincont {
  overflow: hidden;
  font-size: 16px;
  margin-top: var(--header-h);
}
.g-maincont img {
  max-width: 100%;
  height: auto!important;
}
.g-maincont .p-breadcrumb {
  margin: 0 auto;
  padding: 25px 0;
  max-width: none;
}
.g-maincont * {
  outline: 1px dashed rgba(160, 100, 30, 0);
}

.pv-sec-subhead {
  font-size: 1.625em;
  color: #222;
  font-weight: 600;
  line-height: 1.2;
  display: block;
  border-bottom: 2px solid #333;
  padding: 10px 10px 15px;
  margin: 0 auto;
}

.pv-select {
  width: 100%;
  font-size: 1em;
  height: auto;
  padding: 10px 40px 10px 10px;
  border-radius: 5px;
  border: 1px solid #ddd;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%23bbb' d='M24 30.8 12 18.8 14.15 16.65 24 26.5 33.85 16.65 36 18.8Z'/%3E%3C/svg%3E") no-repeat calc(100% - 10px) center/auto 30px;
}
.pv-select:focus {
  border-color: var(--gold);
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%23aa8d48 ' d='M24 30.8 12 18.8 14.15 16.65 24 26.5 33.85 16.65 36 18.8Z'/%3E%3C/svg%3E") no-repeat calc(100% - 10px) center/auto 30px;
}
.pv-select::-ms-expand {
  display: none;
}

.pv-caculate {
  height: 38px;
  width: 100%;
  max-width: 154px;
  white-space: nowrap;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  padding: 0 45px;
  margin: 0;
  background-color: transparent;
  border-radius: 50px;
  border: 1px solid transparent;
}
.pv-caculate:hover {
  background-color: #fff;
  border-color: #aa8d48;
}
.pv-caculate .numbtn {
  width: 30px;
  height: 30px;
  border-radius: 50px;
  top: 50%;
  margin-top: -15px;
  bottom: 0;
  border: none;
  background: #ededed;
  color: #333;
  font-size: 1.125em;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  position: absolute;
  padding: 0;
  font-family: "Araial", sans-serif;
  -webkit-transition: background 0.15s, color 0.15s;
  -o-transition: background 0.15s, color 0.15s;
  transition: background 0.15s, color 0.15s;
}
.pv-caculate .numbtn:hover {
  background: var(--gold);
  color: #fff;
}
.pv-caculate .numbtn.dec {
  left: 2px;
}
.pv-caculate .numbtn.inc {
  right: 2px;
}
.pv-caculate .numinput {
  text-align: center;
  border: none;
  background: none;
  display: inline-block;
  padding: 0 5px;
  width: 100%;
  height: 36px;
  font-size: 1.0625em;
  color: #333;
}

/* * 客製header
 * */
.g-header {
  z-index: 300;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #ddd;
}
.g-header > div {
  height: var(--header-h);
}

.g-logo {
  width: 232px;
  position: absolute;
  left: 20px;
  top: 50%;
  margin: 0;
  padding: 0;
  font-size: 0;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}
.g-logo a {
  display: block;
}
.g-logo img {
  display: block;
  max-width: 100%;
  height: auto;
}

.g-search {
  position: absolute;
  right: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}
.g-search form {
  position: relative;
  width: 100%;
  max-width: 300px;
}

.g-search-switch {
  display: none;
}

.g-search-input {
  height: 50px;
  width: 100%;
  border: 1px solid #000;
  background: #fff;
  padding: 0 60px 0 20px;
  border-radius: 50px;
}

.g-search-send {
  width: 48px;
  height: 48px;
  position: absolute;
  top: 1px;
  right: 1px;
  border-radius: 50%;
  border: none;
  background-color: #000;
  font-size: 0;
}
.g-search-send::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22'%3E%3Cpath fill='%23fff' d='M20.616,19.521l-6.347-6.346c1.152-1.301,1.864-3.004,1.864-4.875c0-4.066-3.309-7.375-7.375-7.375 S1.384,4.234,1.384,8.3c0,4.067,3.309,7.375,7.375,7.375c1.401,0,2.702-0.408,3.818-1.088l6.487,6.486L20.616,19.521z M3.384,8.3 c0-2.964,2.411-5.375,5.375-5.375s5.375,2.411,5.375,5.375s-2.411,5.375-5.375,5.375S3.384,11.264,3.384,8.3z'/%3E%3C/svg%3E") no-repeat 0 0/contain;
}
.g-search-send:hover {
  background: #333;
}

/* * 客製上部
 * */
.pv-btn {
  height: 54px;
  width: 50%;
  background: #999;
  color: #fff;
  font-size: 1em;
  text-align: center;
  line-height: 54px;
  border: none;
  font-weight: 600;
  -webkit-transition: background 0.25s, color 0.25s;
  -o-transition: background 0.25s, color 0.25s;
  transition: background 0.25s, color 0.25s;
}
.pv-btn:hover {
  background: #aaa;
  color: #fff;
}
.pv-btn.black {
  background: #111;
}
.pv-btn.black:hover {
  background: #333;
}
.pv-btn.gold {
  background: var(--gold);
}
.pv-btn.gold:hover {
  background: #b69547;
}

.has-full-bg {
  position: relative;
}
.has-full-bg > * {
  position: relative;
  z-index: 10;
}
.has-full-bg .full-bg {
  z-index: 0;
  background: #f7f7f7;
}

.full-bg {
  width: max(100%, 100vw);
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  top: 0;
  height: 100%;
  z-index: 0;
}

.pv-top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-line-pack: start;
      align-content: flex-start;
  padding-top: 25px;
  padding-bottom: 50px;
}

.pv-left {
  width: 58%;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 58%;
          flex: 0 0 58%;
  padding-right: 60px;
  position: relative;
}

.pv-mode-content {
  position: relative;
  overflow: hidden;
}
@media (min-width: 992px) {
  .pv-left .pv-brand, .pv-left .pv-name {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
  }
}
.pv-mode-content .p-tag:not(.sale){
  width: max(120px, 25%);
  margin-left: min(-60px, -12.5%);
  line-height: 45px;
  height: 45px;
  font-size: 1.0625rem;
  margin-top: min(-30px,-5%);
}
@media (max-width: 599px) {
  .pv-mode-content .p-tag:not(.sale){
    margin-left: min(-65px, -12.5%);
    line-height: 35px;
    height: 35px;
    font-size: 0.9375rem;
    margin-top: -30px;
  }
}
.pv-right {
  width: 42%;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 42%;
          flex: 1 1 42%;
  padding-left: 5%;
  position: relative;
}

.pv-brand {
  display: inline-block;
  color: var(--gold);
  font-weight: 600;
  font-size: 1.125em;
  line-height: 1.4;
}
.pv-brand:hover {
  color: var(--gold-dark);
}

.pv-name {
  display: block;
  padding: 0;
  margin: 5px 0 15px 0;
  line-height: 1.4;
  font-weight: 600;
  font-size: 2.25em;
  color: #222;
}

.pv-mode-tabs {
  position: absolute;
  right: 0;
  top: 0;
  width: 60px;
}

.pv-mode-tab {
  position: relative;
  display: block;
  border: none;
  width: 60px;
  height: 60px;
  background: #ccc;
  font-size: 0;
  margin-bottom: 1px;
}
.pv-mode-tab::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 30px;
  height: 30px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0;
}
.pv-mode-tab.current {
  background: var(--gold);
}
.pv-mode-tab.current:hover {
  background: var(--gold-dark);
}
.pv-mode-tab:hover {
  background: #888;
}
.pv-mode-tab.mode1::before {
  background-image: url("../images/pv_mode1.png");
}
.pv-mode-tab.mode2::before {
  background-image: url("../images/pv_mode2.png");
}

.pv-mode-panel {
  display: none;
}
.pv-mode-panel.current {
  display: block;
  -webkit-animation: ani_fadeIn 0.5s both;
          animation: ani_fadeIn 0.5s both;
}

#merge-layer {
  width: 100% !important;
}

.pcv-slider {
  padding: 0;
  margin: auto;
}
.pcv-slider:after {
  content: "";
  width: 40px;
  height: 40px;
  z-index: 10;
  pointer-events: none;
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%23888888' d='M39.8 41.95 26.65 28.8Q25.15 30.1 23.15 30.825Q21.15 31.55 18.9 31.55Q13.5 31.55 9.75 27.8Q6 24.05 6 18.75Q6 13.45 9.75 9.7Q13.5 5.95 18.85 5.95Q24.15 5.95 27.875 9.7Q31.6 13.45 31.6 18.75Q31.6 20.9 30.9 22.9Q30.2 24.9 28.8 26.65L42 39.75ZM18.85 28.55Q22.9 28.55 25.75 25.675Q28.6 22.8 28.6 18.75Q28.6 14.7 25.75 11.825Q22.9 8.95 18.85 8.95Q14.75 8.95 11.875 11.825Q9 14.7 9 18.75Q9 22.8 11.875 25.675Q14.75 28.55 18.85 28.55ZM20.3 24.3H17.3V20.2H13.2V17.2H17.3V13.15H20.3V17.2H24.35V20.2H20.3Z'/%3E%3C/svg%3E") no-repeat 0 0/contain;
}
.pcv-slider .slick-arrow {
  position: absolute;
  z-index: 10;
  top: 50%;
  margin-top: -30px;
  width: 40px;
  height: 60px;
  font-size: 0;
  background: rgba(255, 255, 255, 0.3);
  outline: none;
  border: none;
  -webkit-transition: backgorund 0.25s;
  -o-transition: backgorund 0.25s;
  transition: backgorund 0.25s;
}
.pcv-slider .slick-arrow:hover, .pcv-slider .slick-arrow:active {
  background: rgba(255, 255, 255, 0.8);
}
.pcv-slider .slick-arrow::before {
  content: "";
  position: absolute;
  width: 14px;
  height: 14px;
  margin-top: -7px;
  top: 50%;
  border-style: solid;
  border-color: #333;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.pcv-slider .slick-prev {
  left: 0;
}
.pcv-slider .slick-prev::before {
  left: 50%;
  margin-left: -6px;
  border-width: 0 0 2px 2px;
}
.pcv-slider .slick-next {
  left: auto;
  right: 0;
}
.pcv-slider .slick-next::before {
  right: 50%;
  margin-right: -6px;
  border-width: 2px 2px 0 0;
}

.pcv-thumbnail {
  margin: 20px auto 0;
  font-size: 0;
}
.pcv-thumbnail .item {
  width: calc(16.6666666667% - 10px);
  margin: 0 5px 10px;
  cursor: pointer;
  max-width: 140px;
  display: inline-block;
  vertical-align: top;
}
.pcv-thumbnail .item.current {
  outline: 3px solid var(--gold);
}

.pv-type-group {
  position: relative;
}

.pv-filters {
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ddd;
  padding-top: 15px;
  padding-bottom: 15px;
  margin-top: 15px;
  margin-bottom: 15px;
}

.pv-filter-item {
  margin: 0 2px 4px 0;
  cursor: pointer;
}
.pv-filter-item input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.pv-filter-item input:checked + span {
  background-color: #333;
  color: #fff;
  border-color: #333;
}
.pv-filter-item span {
  line-height: 1;
  padding: 8px;
  border-radius: 5px;
  display: inline-block;
  position: relative;
  font-size: 0.9em;
  font-weight: 500;
  background-color: #fff;
  border: 1px solid #ddd;
  color: #555;
  white-space: nowrap;
  overflow: hidden;
}
.pv-filter-item:not(.pv-filter-lack):hover input:not(:checked) + span {
  background-color: #f2f2f2;
  color: #111;
}
.pv-filter-item.pv-filter-preorder span::after {
  content: "預";
  display: inline-block;
  vertical-align: top;
  border-radius: 3px;
  background: var(--gold);
  color: #fff;
  font-size: 13px;
  width: auto;
  height: auto;
  padding: 4px;
  margin: -3px 0 -2px 3px;
  line-height: 1;
}
.pv-filter-item.pv-filter-preorder span::before {
  content: "";
  display: block;
  width: 1px;
}
.pv-filter-item.pv-filter-lack {
  cursor: not-allowed;
}
.pv-filter-item.pv-filter-lack span {
  color: #888;
  background-color: #f3f3f3;
  background-size: 0.6em 0.6em;
  background-image: -o-repeating-linear-gradient(135deg, #e0e0e0 0, #e0e0e0 1px, #f5f5f5 0, #f5f5f5 50%);
  background-image: repeating-linear-gradient(-45deg, #e0e0e0 0, #dedede 1px, #f5f5f5 0, #f5f5f5 50%);
}

.pv-filter-item.pv-filter-lack input:checked + span {
  border-color: #666;
  background-color: #888;
  background-image: -o-repeating-linear-gradient(135deg, #aaa 0, #999 1px, #888 0, #888 50%);
  background-image: repeating-linear-gradient(-45deg, #aaa 0, #999 1px, #888 0, #888 50%);
}

.pv-type-msg {
  font-weight: 600;
  padding-top: 15px;
  margin-top: 15px;
  border-top: 1px solid #ddd;
  font-size: 1em;
}

.pv-intro-btns {
  margin-top: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.pv-intro-btns > .pv-btn {
  width: calc(50% - 2px);
  -webkit-box-flex: 0;
      -ms-flex: 0 1 calc(50% - 2px);
          flex: 0 1 calc(50% - 2px);
  margin: 0 1px 10px;
  display: inline-block;
  vertical-align: top;
}
.pv-intro-btns > .pv-btn.full {
  width: 100%;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
}
.pv-type {
  position: relative;
  width: 100%;
  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;
  font-size: 1.0625em;
  line-height: 1.4;
  margin: 5px 0;
  padding: 5px 10px;
}
.pv-type.full {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.pv-type.full .pv-type-tit {
  width: 100%;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
  margin-bottom: 10px;
}

.pv-price {
  position: absolute !important;
  top: 0;
  right: 0;
  text-align: right;
  color: red;
  font-weight: 600;
  font-size: 2.94em !important;
  line-height: 0.6;
  white-space: nowrap;
  display: block;
  width: 200px;
  padding: 0;
}
.pv-price .pv-type-tit {
  display: none;
}
.pv-price .pv-type-cont {
  width: 100%;
}
.pv-price ~ .pv-type {
  padding-right: 200px;
}

.pv-type-tit {
  width: 120px;
  padding: 0 10px 0 0;
  margin: 0;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 120px;
          flex: 0 0 120px;
  font-weight: 600;
}
.pv-type-tith1, .pv-type-tith2, .pv-type-tith3, .pv-type-tith4, .pv-type-tith5, .pv-type-tith6 {
  font-size: inherit;
}

.pv-type-cont {
  width: calc(100% - 120px);
  -webkit-box-flex: 1;
      -ms-flex: 1 1 calc(100% - 120px);
          flex: 1 1 calc(100% - 120px);
}

/* * 間隔：30
 * * 圖片：140 + 間隔 = 170
 * * 購物按鈕：150
 * * 購物按鈕：70 + 間隔 = 100
 * */
.pv-add-wrap {
  padding-top: 70px;
  padding-bottom: 50px;
}

.pv-add-item {
  border-bottom: 1px solid #ddd;
  padding: 25px 12px;
  position: relative;
}
.pv-add-item .pv-btn {
  width: 150px;
  height: 44px;
  line-height: 44px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 150px;
          flex: 0 0 150px;
}
.pv-add-item .pv-btn.added {
  padding-right: 12px;
}
.pv-add-item .pv-btn.added::before {
  content: "";
  width: 22px;
  height: 22px;
  margin: -2px 5px -2px 0;
  display: inline-block;
  vertical-align: middle;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%23fff' d='M18.9 35.7 7.7 24.5 9.85 22.35 18.9 31.4 38.1 12.2 40.25 14.35Z'/%3E%3C/svg%3E") no-repeat 0 0/contain;
}

.pv-add-added {
  color: #666;
  font-size: 0.9375rem;
}
.pv-add-added span {
  display: inline-block;
  border: 1px solid #ccc;
  border-radius: 4px;
  line-height: 1.2;
  padding: 4px 5px;
  margin: 0 0 5px 5px;
  font-size: 0.875rem;
}

.pv-add-head {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.pv-add-img {
  width: 140px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 140px;
          flex: 0 0 140px;
  margin-right: 30px;
  position: relative;
  border: 1px solid #ddd;
}
.pv-add-img img {
  max-width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}

.pv-add-name {
  padding: 0;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 100px;
          flex: 1 1 100px;
}

.pv-add-switch {
  display: block;
  height: 44px;
  position: relative;
  font-size: 0;
  margin: 0 0 0 30px;
  width: 70px;
  cursor: pointer;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 70px;
          flex: 0 0 70px;
  border-radius: 5px;
  border: 1px solid transparent;
}
.pv-add-switch::before {
  content: "";
  width: 13px;
  height: 13px;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -7px;
  margin-top: -9px;
  border-style: solid;
  border-width: 0 0 1px 1px;
  border-color: #666;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transition: -webkit-transform 0.25s;
  transition: -webkit-transform 0.25s;
  -o-transition: transform 0.25s;
  transition: transform 0.25s;
  transition: transform 0.25s, -webkit-transform 0.25s;
}
.pv-add-switch:hover {
  background: #f5f5f5;
  border-color: #ddd;
}
.pv-add-switch:hover::before {
  border-color: var(--gold);
}

.pv-add-item.is-open .pv-add-switch::before {
  -webkit-transform: rotate(135deg);
      -ms-transform: rotate(135deg);
          transform: rotate(135deg);
  margin-top: -3px;
}

.pv-add-body {
  padding: 0 250px 0 170px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.5s, margin 0.5s;
  -o-transition: max-height 0.5s, margin 0.5s;
  transition: max-height 0.5s, margin 0.5s;
}

.pv-add-item.is-open .pv-add-body {
  max-height: 1000px;
}

.pv-add-spec-list {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 55%;
          flex: 1 1 55%;
}
.pv-add-spec-list .item {
  display: block;
}
.pv-add-spec-list .item input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.pv-add-spec-list .item input + span {
  position: relative;
  padding-left: 32px;
  cursor: pointer;
}
.pv-add-spec-list .item input + span i {
  font-style: normal;
  margin-left: 5px;
}
.pv-add-spec-list .item input + span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 5px;
  width: 16px;
  height: 16px;
  -webkit-box-shadow: 0 0 0 1px #959595;
          box-shadow: 0 0 0 1px #959595;
  border: 3px solid #fff;
  background: #fff;
  border-radius: 50px;
}
.pv-add-spec-list .item input:checked + span::before {
  background: var(--gold);
}

.sub-spec {
  width: calc(100% - 20px);
  padding-left: 30px;
  margin: 0 0 10px 10px;
  border-left: 2px solid #ddd;
  padding: 5px 5px 5px 17px;
  position: relative;
  display: none;
}
.sub-spec .item {
  font-size: 0.9375rem;
  margin: 5px 0 5px 25px;
  line-height: 1.8;
}
.sub-spec .item input + span {
  padding-left: 0;
}
.sub-spec .item input + span::before {
  margin-left: -25px;
  width: 13px;
  height: 13px;
  top: 3px;
}

.pv-add-spec-img {
  width: 45%;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 45%;
          flex: 1 1 45%;
  max-width: 550px;
  -ms-flex-item-align: center;
      align-self: center;
}
.pv-add-spec-img img {
  border: 1px solid #ddd;
}

.pv-details-wrap {
  padding-top: 60px;
  position: relative;
}

.pv-details-cur {
  display: none;
}

.pv-details-tabs {
  z-index: 200;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100%;
  max-width: 1600px;
}
.pv-details-tabs.is-fixed {
  position: fixed;
  top: var(--header-h);
}
.pv-details-tabs.is-fixed > ul > li > a {
  padding: 7px 10px 6px 10px;
}
.pv-details-tabs > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-line-pack: stretch;
      align-content: stretch;
}
.pv-details-tabs > ul > li {
  display: inline-block;
  vertical-align: top;
  width: 33%;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 33%;
          flex: 1 1 33%;
}
.pv-details-tabs > ul > li > a {
  display: block;
  width: 100%;
  border: 1px solid #ddd;
  border-bottom: 1px solid #333;
  background: #f4f4f4;
  color: #222;
  font-weight: 600;
  text-align: center;
  padding: 12px 10px 10px 10px;
  font-size: 1.0625em;
  margin: 0 -1px;
}
.pv-details-tabs > ul > li.current > a {
  border-color: #000;
  background: #000;
  color: #fff;
}

@media (min-width: 992px) {
  .pv-details-tabs {
    min-width: 1630px;
  }
}
.pv-details-sec {
  width: 100%;
  max-width: 1430px;
  border-top: 1px solid #333;
  padding-top: 80px;
  margin: 0 auto 80px;
}
.pv-details-sec:first-of-type {
  border-top: none;
}

@media (min-width: 992px) {
  .pv-details-sec {
    min-width: 1430px;
  }
}
.pv-details-sec-subhead {
  text-align: center;
  font-size: 2.25em;
  font-weight: 900;
  color: #222;
  margin: 0 auto;
  padding: 20px 0;
}

.pv-related-wrap {
  position: relative;
  padding-bottom: 50px;
}

.pv-related-sec-subhead {
  background: #333;
  color: #fff;
  font-weight: 700;
  font-size: 1.5em;
  display: block;
  padding: 15px;
  margin: 0 auto 20px;
}

.pv-related-slider {
  padding-bottom: 70px;
}
.pv-related-slider .slick-list {
  margin: 30px auto;
}
.pv-related-slider .slick-list::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 1px;
  background: #fff;
  z-index: 15;
}
.pv-related-slider .slick-arrow {
  bottom: 5px;
  left: 50%;
  width: 50px;
  height: 50px;
  border-radius: 50px;
  border: 1px solid #ccc;
  position: absolute;
  font-size: 0;
  background: #fff;
}
.pv-related-slider .slick-arrow::before {
  content: "";
  width: 13px;
  height: 13px;
  display: block;
  position: absolute;
  top: 50%;
  margin-top: -7px;
  border-style: solid;
  border-width: 1px 1px 0 0;
  border-color: #666;
  -webkit-transition: -webkit-transform 0.25s;
  transition: -webkit-transform 0.25s;
  -o-transition: transform 0.25s;
  transition: transform 0.25s;
  transition: transform 0.25s, -webkit-transform 0.25s;
}
.pv-related-slider .slick-arrow:active {
  background: #666;
}
.pv-related-slider .slick-arrow:active::before {
  border-color: #fff;
}
.pv-related-slider .slick-prev {
  -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
          transform: translateX(-100%);
  margin-left: -10px;
}
.pv-related-slider .slick-prev::before {
  left: 50%;
  margin-left: -4px;
  -webkit-transform: rotate(-135deg);
      -ms-transform: rotate(-135deg);
          transform: rotate(-135deg);
}
.pv-related-slider .slick-next {
  margin-right: -10px;
}
.pv-related-slider .slick-next::before {
  left: auto;
  right: 50%;
  margin-right: -4px;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}

.pv-related-item {
  position: relative;
  padding-left: 10px;
  padding-right: 10px;
}
.pv-related-item:first-of-type::before {
  display: none !important;
}
.pv-related-item::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1px;
  width: 1px;
  background: #ddd;
}
.pv-related-item > a {
  max-width: 250px;
  display: block;
  margin: 0 auto;
}
.pv-related-item > a:hover .img::before, .pv-related-item > a:hover .img::after {
  opacity: 1;
}
.pv-related-item > a:hover .img::after {
  -webkit-transform: translate(-50%, -50%) rotateX(0deg);
          transform: translate(-50%, -50%) rotateX(0deg);
}
.pv-related-item .img {
  aspect-ratio: 1;
  text-align: left;
  width: 100%;
  display: block;
  margin: 0 auto;
  max-width: 200px;
  position: relative;
  overflow: hidden;
}
.pv-related-item .img::before, .pv-related-item .img::after {
  pointer-events: none;
  position: absolute;
  opacity: 0;
  z-index: 2;
  -webkit-transition: opacity 0.25s, -webkit-transform 0.45s 0.2s;
  transition: opacity 0.25s, -webkit-transform 0.45s 0.2s;
  -o-transition: opacity 0.25s, transform 0.45s 0.2s;
  transition: opacity 0.25s, transform 0.45s 0.2s;
  transition: opacity 0.25s, transform 0.45s 0.2s, -webkit-transform 0.45s 0.2s;
}
.pv-related-item .img::before {
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.15);
}
.pv-related-item .img:after {
  content: "view";
  width: 50px;
  height: 24px;
  line-height: 20px;
  border: 1px solid rgba(255, 255, 255, 0.5);
  color: #fff;
  text-align: center;
  font-size: 0.75rem;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotateX(90deg);
          transform: translate(-50%, -50%) rotateX(90deg);
}
.pv-related-item img {
  display: inline-block;
}
.pv-related-item .title {
  font-size: 1.1875em;
  margin: 10px auto 0;
  padding: 0;
  color: #222;
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  -o-text-overflow: ellipsis;
     text-overflow: ellipsis;
  overflow: hidden;
}
.pv-related-item .price {
  display: block;
  margin: 5px auto 0;
  padding: 0;
  font-style: normal;
  color: red;
  font-size: 1.0625em;
  font-weight: 600;
}

/* * 客製化商品詳細樣板
 * */    
.theme-pcv-detail {
  overflow: hidden;
  position: relative;
}

.theme-pcv-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 -20px;
}
.theme-pcv-row > * {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 50%;
          flex: 1 1 50%;
  padding: 0 20px;
}

.theme-pcv-half {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.theme-pcv-video {
  position: relative;
  z-index: 10;
  margin-top: 40px;
  padding-top: 30px;
  padding-bottom: 40px;
}
.theme-pcv-video > * {
  position: relative;
  z-index: 10;
}
.theme-pcv-video::before {
  content: "";
  width: max(100%, 100vw);
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  top: 0;
  bottom: min(30%, 150px);
  z-index: 0;
  background: #f4f4f4;
}
.theme-pcv-video iframe {
  width: 100% !important;
}

.theme-pcv-iframe {
  position: relative;
  width: 100%;
  max-width: 1020px;
  margin: 20px auto;
  padding: 0;
}
.theme-pcv-iframe::before {
  content: "";
  display: block;
  padding-bottom: 56.25%;
}
.theme-pcv-iframe iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.theme-pcv-notice {
  padding: 45px;
  background: #f8f8f8;
  margin: 50px auto;
}
.theme-pcv-notice strong {
  color: #222;
  font-weight: 600;
}

.theme-pcv-notice-subhead {
  font-size: 1.25em;
  line-height: 1.2;
  border-bottom: 1px solid #666;
  display: inline-block;
  font-weight: 600;
  color: #222;
  padding: 5px;
  margin: 0 0 20px;
}

.theme-pcv-btn {
  border-radius: 4px;
  border: 1px solid rgba(170, 141, 72, 0.5);
  background: #fff;
  color: var(--gold);
  font-size: 1em;
  padding: 5px 15px;
  min-width: 120px;
  display: inline-block;
  vertical-align: middle;
  margin: 5px;
}
.theme-pcv-btn:hover, .theme-pcv-btn:active {
  border: 1px solid var(--gold);
  background: var(--gold);
  color: #fff;
}

.theme-pcv-subhead {
  display: block;
  font-size: 2.25em;
  line-height: 1.4;
  font-weight: 900;
  color: #222;
  margin: 0 auto 20px;
  padding: 20px 0;
}

.theme-pcv-table-wrap {
  overflow-x: auto;
  overflow-y: hidden;
}

.theme-pcv-table {
  min-width: 400px;
  border-collapse: collapse;
  border: none;
  width: 100%;
  margin: 0 auto;
}
.theme-pcv-table th, .theme-pcv-table td {
  padding: 10px max(15px, 3%);
}
.theme-pcv-table thead th, .theme-pcv-table thead td {
  color: #fff;
  background: #999;
  font-weight: 600;
}
.theme-pcv-table tbody th, .theme-pcv-table tbody td {
  color: #333;
  border-bottom: 1px solid #ccc;
}