/* ============================================================
   縮時森林 GROVYN × WooCommerce — 森林精品店
   美學：Aesop × Jo Malone × 森林精選
   特徵：克制留白、無圓角、細線、拉丁副標、雜誌排版
   ============================================================ */

/* ---- 商店全頁 ---- */

.shop-page {
  background: var(--ts-cream);
  min-height: 100vh;
  padding-bottom: var(--ts-sp-8);
}

/* ---- 頁首：editorial split ---- */

.shop-head {
  position: relative;
  padding: 130px var(--ts-sp-4) var(--ts-sp-6);
  max-width: 1320px;
  margin: 0 auto;
}

.shop-head__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--ts-sp-4);
  flex-wrap: wrap;
}

.shop-head__main {
  margin-top: var(--ts-sp-5);
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--ts-sp-7);
  align-items: end;
}

.shop-head__title-block {
  display: grid;
  gap: var(--ts-sp-3);
}

.shop-head__display {
  font-family: var(--ts-font-serif-en-display);
  font-weight: 300;
  font-size: clamp(48px, 9vw, 130px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  color: var(--ts-navy);
  margin: 0;
}

.shop-head__display em {
  font-style: italic;
  font-weight: 400;
  color: var(--ts-forest);
}

.shop-head__display-zh {
  font-family: var(--ts-font-serif-zh);
  font-size: clamp(20px, 2vw, 24px);
  font-weight: 500;
  letter-spacing: 0.4em;
  color: var(--ts-ink-soft);
  margin: 0;
}

.shop-head__narrative {
  font-family: var(--ts-font-serif-zh);
  font-size: 14px;
  line-height: 2.1;
  color: var(--ts-ink-soft);
  letter-spacing: 0.04em;
  margin: 0;
  max-width: 32em;
}

.shop-head__rule {
  margin: var(--ts-sp-6) 0 0;
  height: 1px;
  background: var(--ts-line);
  border: none;
}

/* ---- 商店主體 ---- */

.shop-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 var(--ts-sp-4);
}

/* ---- WooCommerce Notices（提示）---- */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  font-family: var(--ts-font-sans-zh) !important;
  font-size: 13px !important;
  letter-spacing: 0.04em !important;
  border-top: 1px solid var(--ts-forest) !important;
  background: rgba(73, 84, 52, 0.05) !important;
  color: var(--ts-navy) !important;
  border-radius: 0 !important;
  padding: var(--ts-sp-3) var(--ts-sp-4) !important;
}

/* ---- 排序 + 結果計數 ---- */

.woocommerce-result-count {
  font-family: var(--ts-font-mono);
  font-size: 11px;
  color: var(--ts-ink-mute);
  letter-spacing: 0.18em;
  margin: var(--ts-sp-4) 0 0;
  text-transform: uppercase;
}

.woocommerce-ordering {
  margin: var(--ts-sp-4) 0 0;
}

.woocommerce-ordering select {
  font-family: var(--ts-font-serif-en);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--ts-navy);
  border: none;
  border-bottom: 1px solid var(--ts-line);
  background: transparent;
  padding: 8px 24px 8px 0;
  cursor: pointer;
  border-radius: 0;
  appearance: none;
  text-transform: uppercase;
}

.woocommerce-ordering select:focus {
  outline: none;
  border-bottom-color: var(--ts-forest);
}

/* ---- 商品 Grid（3 欄克制）---- */

ul.products {
  list-style: none;
  padding: 0;
  margin: var(--ts-sp-6) 0 var(--ts-sp-7);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ts-sp-5) var(--ts-sp-4);
}

/* ---- 商品卡（無圓角、無陰影、徹底貼合）---- */

ul.products li.product,
.woocommerce ul.products li.product {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  float: none !important;
}

li.product .woocommerce-loop-product__link,
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
  display: block;
  text-decoration: none !important;
  background: transparent !important;
}

/* 商品圖：直角貼合、aspect-ratio fixed、hover 微縮放 */
li.product .woocommerce-loop-product__link img,
.woocommerce ul.products li.product .woocommerce-loop-product__link img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
  margin: 0 !important;
  border-radius: 0;
  box-shadow: none;
  background: var(--ts-warm);
  transition: transform 1.2s var(--ts-ease-natural), opacity var(--ts-dur-base);
}

li.product:hover .woocommerce-loop-product__link img {
  transform: scale(1.04);
}

/* 商品標題（中文 serif） */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--ts-font-serif-zh) !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: var(--ts-navy) !important;
  padding: var(--ts-sp-3) 0 var(--ts-sp-1) !important;
  margin: 0 !important;
  line-height: 1.6 !important;
  letter-spacing: 0.06em !important;
}

/* 價格（mono、森林綠） */
.woocommerce ul.products li.product .price,
ul.products li.product .price {
  font-family: var(--ts-font-mono) !important;
  font-size: 12px !important;
  color: var(--ts-forest) !important;
  letter-spacing: 0.1em !important;
  padding: 0 0 var(--ts-sp-3) !important;
  margin: 0 !important;
  display: block !important;
}

.woocommerce ul.products li.product .price del,
ul.products li.product .price del {
  color: var(--ts-ink-mute) !important;
  font-size: 11px !important;
  opacity: 0.6 !important;
  margin-right: 6px !important;
}

.woocommerce ul.products li.product .price ins,
ul.products li.product .price ins {
  text-decoration: none !important;
  background: transparent !important;
  font-weight: 600 !important;
}

/* 售完標籤（極簡細邊） */
.onsale,
.woocommerce span.onsale {
  background: transparent !important;
  color: var(--ts-forest) !important;
  border: 1px solid var(--ts-forest) !important;
  border-radius: 0 !important;
  font-family: var(--ts-font-mono) !important;
  font-size: 9px !important;
  letter-spacing: 0.25em !important;
  padding: 4px 8px !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1 !important;
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  text-transform: uppercase;
}

/* 加入購物車按鈕（細線） */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
ul.products li.product .button,
ul.products li.product a.button {
  display: inline-block !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--ts-navy) !important;
  border-radius: 0 !important;
  color: var(--ts-navy) !important;
  font-family: var(--ts-font-serif-en) !important;
  font-style: italic !important;
  font-size: 11px !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  padding: 4px 0 6px !important;
  margin: 0 0 var(--ts-sp-3) !important;
  text-decoration: none !important;
  cursor: pointer !important;
  width: auto !important;
  text-align: left !important;
  transition: color var(--ts-dur-quick), border-color var(--ts-dur-quick) !important;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover {
  background: transparent !important;
  color: var(--ts-forest) !important;
  border-color: var(--ts-forest) !important;
}

/* 售完商品 */
.woocommerce ul.products li.product.outofstock .price {
  opacity: 0.5;
}

/* 會員價提示（未登入訪客看到的引導） */
.grovyn-member-price {
  display: inline-block;
  font-family: var(--ts-font-serif-en);
  font-style: italic;
  font-size: 11px;
  color: var(--ts-forest);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-left: 8px;
  padding: 2px 8px;
  border: 1px solid var(--ts-forest);
  background: rgba(73, 84, 52, 0.04);
}

.grovyn-member-price .woocommerce-Price-amount {
  font-family: var(--ts-font-mono) !important;
  font-style: normal !important;
  color: var(--ts-forest) !important;
  font-size: 11px !important;
}

li.product .grovyn-member-price {
  display: inline-block;
  margin: 4px 0 0 0;
  font-size: 10px;
  letter-spacing: 0.15em;
}

/* ---- 空商店狀態 ---- */

.woocommerce-info {
  font-family: var(--ts-font-serif-zh);
  font-size: 16px;
  color: var(--ts-ink-soft);
  text-align: center;
  border: none !important;
  background: transparent !important;
  padding: var(--ts-sp-8) !important;
  letter-spacing: 0.06em;
}

/* ---- 分頁 ---- */

.woocommerce-pagination {
  margin-top: var(--ts-sp-7);
  padding-top: var(--ts-sp-5);
  border-top: 1px solid var(--ts-line);
}

.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul {
  display: flex !important;
  justify-content: center !important;
  gap: var(--ts-sp-3) !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}

.woocommerce-pagination ul li,
.woocommerce nav.woocommerce-pagination ul li {
  border: none !important;
  margin: 0 !important;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 36px !important;
  height: 36px !important;
  padding: 0 8px !important;
  background: transparent !important;
  font-family: var(--ts-font-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.18em !important;
  color: var(--ts-ink-mute) !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
  border-radius: 0 !important;
  transition: color var(--ts-dur-quick), border-color var(--ts-dur-quick) !important;
}

.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li span.current {
  color: var(--ts-forest) !important;
  border-color: var(--ts-forest) !important;
}

.woocommerce-pagination ul li a:hover {
  color: var(--ts-navy) !important;
  border-color: var(--ts-navy) !important;
}

/* ============================================================
   單品頁 — Single Product
   ============================================================ */

body.single-product .l-main {
  background: var(--ts-cream);
}

.woocommerce div.product {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 130px var(--ts-sp-4) var(--ts-sp-7) !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: var(--ts-sp-7) !important;
  align-items: start !important;
  position: relative !important;
}

/* 商品圖（直角，無陰影） */
.woocommerce div.product .woocommerce-product-gallery {
  width: 100% !important;
  float: none !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  box-shadow: none !important;
}

.woocommerce div.product .woocommerce-product-gallery__image img,
.woocommerce div.product .woocommerce-product-gallery .flex-control-thumbs li img {
  border-radius: 0 !important;
  box-shadow: none !important;
}

.woocommerce-product-gallery__trigger {
  background: rgba(238, 234, 231, 0.85) !important;
  border-radius: 0 !important;
  border: 1px solid var(--ts-line) !important;
  box-shadow: none !important;
}

/* 商品資訊側 */
.woocommerce div.product .entry-summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: var(--ts-sp-3) 0 !important;
}

/* 商品名稱 */
.woocommerce div.product .product_title.entry-title {
  font-family: var(--ts-font-serif-zh) !important;
  font-size: clamp(28px, 4vw, 44px) !important;
  font-weight: 500 !important;
  letter-spacing: 0.05em !important;
  color: var(--ts-navy) !important;
  margin: 0 0 var(--ts-sp-3) !important;
  line-height: 1.4 !important;
}

/* 評分 */
.woocommerce div.product .woocommerce-product-rating {
  margin-bottom: var(--ts-sp-3) !important;
}

/* 價格 */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--ts-font-mono) !important;
  font-size: 20px !important;
  color: var(--ts-forest) !important;
  letter-spacing: 0.1em !important;
  margin: 0 0 var(--ts-sp-4) !important;
  display: block !important;
}

/* 短描述 */
.woocommerce div.product .woocommerce-product-details__short-description {
  font-family: var(--ts-font-serif-zh) !important;
  font-size: 15px !important;
  color: var(--ts-ink-soft) !important;
  line-height: 2.1 !important;
  letter-spacing: 0.04em !important;
  margin-bottom: var(--ts-sp-5) !important;
  padding-top: var(--ts-sp-3) !important;
  border-top: 1px solid var(--ts-line) !important;
}

/* 數量輸入 */
.woocommerce div.product form.cart {
  margin-bottom: var(--ts-sp-5) !important;
}

.woocommerce div.product form.cart .quantity {
  margin-right: var(--ts-sp-3) !important;
}

.woocommerce div.product form.cart .quantity input {
  font-family: var(--ts-font-mono) !important;
  font-size: 14px !important;
  border: none !important;
  border-bottom: 1px solid var(--ts-line) !important;
  border-radius: 0 !important;
  width: 64px !important;
  text-align: center !important;
  color: var(--ts-navy) !important;
  background: transparent !important;
  padding: 12px 4px !important;
  letter-spacing: 0.1em !important;
}

/* Add to cart 按鈕（精品細邊） */
.woocommerce div.product form.cart .button,
.woocommerce div.product form.cart button[type="submit"],
.woocommerce div.product .single_add_to_cart_button,
.single_add_to_cart_button {
  background: var(--ts-navy) !important;
  color: var(--ts-cream) !important;
  border: 1px solid var(--ts-navy) !important;
  border-radius: 0 !important;
  padding: 14px 36px !important;
  font-family: var(--ts-font-serif-en) !important;
  font-style: italic !important;
  font-size: 12px !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background var(--ts-dur-base) var(--ts-ease-natural), color var(--ts-dur-base) var(--ts-ease-natural) !important;
  width: auto !important;
  box-shadow: none !important;
}

.woocommerce div.product form.cart .button:hover,
.single_add_to_cart_button:hover {
  background: var(--ts-forest) !important;
  border-color: var(--ts-forest) !important;
}

/* SKU 與分類 meta */
.woocommerce div.product .product_meta {
  font-family: var(--ts-font-mono) !important;
  font-size: 11px !important;
  color: var(--ts-ink-mute) !important;
  letter-spacing: 0.15em !important;
  border-top: 1px solid var(--ts-line) !important;
  padding-top: var(--ts-sp-3) !important;
  margin-top: var(--ts-sp-4) !important;
}

.woocommerce div.product .product_meta > span {
  display: block;
  margin-bottom: 6px;
}

.woocommerce div.product .product_meta a {
  color: var(--ts-forest) !important;
  font-family: var(--ts-font-serif-en) !important;
  font-style: italic;
  letter-spacing: 0.18em;
  text-decoration: none;
}

/* ---- 商品 Tabs ---- */

.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1 !important;
  border-top: 1px solid var(--ts-line) !important;
  padding-top: var(--ts-sp-6) !important;
  margin-top: var(--ts-sp-7) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex !important;
  gap: var(--ts-sp-5) !important;
  list-style: none !important;
  padding: 0 0 var(--ts-sp-3) !important;
  margin: 0 0 var(--ts-sp-5) !important;
  border-bottom: 1px solid var(--ts-line) !important;
  border-radius: 0 !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
  display: none !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-block !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--ts-font-serif-en) !important;
  font-style: italic !important;
  font-size: 12px !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  color: var(--ts-ink-mute) !important;
  text-decoration: none !important;
  padding: 8px 0 !important;
  display: block !important;
  border-bottom: 1px solid transparent !important;
  margin-bottom: -1px !important;
  transition: color var(--ts-dur-quick), border-color var(--ts-dur-quick) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--ts-forest) !important;
  border-bottom-color: var(--ts-forest) !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
  font-family: var(--ts-font-serif-zh) !important;
  font-size: 15px !important;
  line-height: 2.1 !important;
  color: var(--ts-ink) !important;
  letter-spacing: 0.04em !important;
  padding: 0 !important;
  margin: 0 !important;
}

.woocommerce div.product .woocommerce-tabs .panel h2:first-child {
  display: none;
}

/* 相關商品 */
.related.products {
  grid-column: 1 / -1 !important;
  border-top: 1px solid var(--ts-line) !important;
  padding-top: var(--ts-sp-7) !important;
  margin-top: var(--ts-sp-7) !important;
}

.related.products > h2,
.upsells.products > h2 {
  font-family: var(--ts-font-serif-en) !important;
  font-style: italic !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  color: var(--ts-moss) !important;
  margin: 0 0 var(--ts-sp-5) !important;
  text-align: center;
}

/* ============================================================
   響應式
   ============================================================ */

@media (max-width: 1024px) {
  ul.products {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 900px) {
  .shop-head__main {
    grid-template-columns: 1fr;
    gap: var(--ts-sp-4);
  }

  .woocommerce div.product {
    grid-template-columns: 1fr !important;
    gap: var(--ts-sp-5) !important;
    padding-top: 100px !important;
  }
}

@media (max-width: 640px) {
  .shop-head {
    padding-top: 100px;
  }

  ul.products {
    grid-template-columns: 1fr;
    gap: var(--ts-sp-5);
  }

  .woocommerce div.product .woocommerce-tabs ul.tabs {
    flex-wrap: wrap;
    gap: var(--ts-sp-3) !important;
  }
}
