/* ============================================
   VERDANT NEST — WOOCOMMERCE STYLE OVERRIDES
   Unifies cart, checkout, my-account with brand
   ============================================ */

/* ── WRAPPER ── */
.vn-woo-wrapper {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 56px var(--pad-x);
}

/* ── GENERAL OVERRIDES ── */
.woocommerce h1, .woocommerce h2, .woocommerce h3 {
  font-family: var(--serif);
  font-weight: 300;
  color: var(--coal);
}

.woocommerce .woocommerce-breadcrumb {
  font-size: 12px;
  color: var(--stone);
  margin-bottom: 24px;
}
.woocommerce .woocommerce-breadcrumb a {
  color: var(--stone);
  text-decoration: none;
}
.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--coal);
}

/* ── BUTTONS ── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit,
.woocommerce .wc-block-components-button {
  display: inline-block;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  text-decoration: none;
  padding: 15px 36px !important;
  background: var(--coal) !important;
  color: var(--white) !important;
  border: 1.5px solid var(--coal) !important;
  border-radius: 0 !important;
  cursor: pointer;
  transition: background .3s, color .3s, transform .2s;
  line-height: 1.4 !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background: var(--olive) !important;
  border-color: var(--olive) !important;
  color: var(--white) !important;
  transform: translateY(-2px);
}

/* Disabled / loading */
.woocommerce a.button.disabled,
.woocommerce button.button:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/* ── SINGLE PRODUCT: ADD TO CART ── */
.woocommerce div.product form.cart .button.single_add_to_cart_button {
  width: 100%;
  padding: 18px !important;
  margin-bottom: 12px;
}

/* Variation selectors */
.woocommerce div.product form.cart .variations {
  margin-bottom: 24px;
}
.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
  padding: 8px 0;
  border: none;
  vertical-align: middle;
}
.woocommerce div.product form.cart .variations td.label label {
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--coal);
  font-weight: 500;
  font-family: var(--sans);
}
.woocommerce div.product form.cart .variations td.value select {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1.5px solid var(--border);
  padding: 12px 0;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink);
  outline: none;
  border-radius: 0;
  appearance: none;
  cursor: pointer;
}

/* Quantity */
.woocommerce div.product form.cart .quantity {
  margin-right: 16px;
}
.woocommerce .quantity .qty {
  width: 60px;
  text-align: center;
  border: 1.5px solid var(--border);
  padding: 12px 8px;
  font-family: var(--sans);
  font-size: 14px;
  border-radius: 0;
  outline: none;
}

/* ── NOTICES ── */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error {
  border-top: 2px solid var(--coal);
  background: var(--bg2);
  color: var(--coal);
  padding: 16px 24px;
  font-size: 13px;
  font-family: var(--sans);
  font-weight: 400;
  margin-bottom: 24px;
  border-radius: 0;
}
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before {
  color: var(--olive);
}
.woocommerce .woocommerce-error {
  border-top-color: #c44;
}

/* ── CART TABLE ── */
.woocommerce-cart table.shop_table {
  border: none;
  border-collapse: collapse;
}
.woocommerce-cart table.shop_table th {
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
  font-family: var(--sans);
  border-bottom: 1.5px solid var(--border);
  padding: 14px 0;
}
.woocommerce-cart table.shop_table td {
  font-size: 14px;
  color: var(--ink2);
  font-weight: 300;
  padding: 20px 12px 20px 0;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  font-family: var(--sans);
}
.woocommerce-cart table.shop_table td.product-name a {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 400;
  color: var(--coal);
  text-decoration: none;
}
.woocommerce-cart table.shop_table td.product-name a:hover {
  color: var(--olive);
}
.woocommerce-cart table.shop_table img {
  width: 80px;
  height: auto;
}

/* Cart totals */
.woocommerce .cart_totals {
  border: 1px solid var(--border);
  padding: 32px;
  background: var(--bg2);
}
.woocommerce .cart_totals h2 {
  font-size: clamp(24px, 2.5vw, 36px);
  margin-bottom: 24px;
}
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
  font-family: var(--sans);
  font-size: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}

/* ── CHECKOUT ── */
.woocommerce-checkout .woocommerce-checkout-review-order-table th {
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
}

/* Checkout form fields */
.woocommerce form .form-row label {
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink2);
  font-weight: 500;
  font-family: var(--sans);
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1.5px solid var(--border);
  padding: 12px 0;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink);
  outline: none;
  border-radius: 0;
  transition: border-color .3s;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--coal);
}

/* Order review */
.woocommerce-checkout-review-order {
  background: var(--bg2);
  padding: 32px;
  border: 1px solid var(--border);
}

/* ── MY ACCOUNT ── */
.woocommerce-account .woocommerce-MyAccount-navigation {
  width: 240px;
  float: left;
  margin-right: 48px;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 12px 0;
  font-size: 13px;
  color: var(--ink2);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  font-family: var(--sans);
  font-weight: 300;
  transition: color .2s;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  color: var(--coal);
  font-weight: 500;
}
.woocommerce-account .woocommerce-MyAccount-content {
  overflow: hidden;
}

/* ── PRICE DISPLAY ── */
/* 隐藏 WooCommerce 默认注入的价格元素（页面已用 .prod-price-main 自定义渲染） */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  display: none !important;
}

/* .prod-price-main 内部的价格 amount 样式 */
.prod-price-main .woocommerce-Price-amount,
.prod-price-main .price {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  color: var(--coal);
}
.prod-price-main del .woocommerce-Price-amount {
  color: var(--stone);
  font-weight: 300;
  font-size: 22px;
}
.prod-price-main ins {
  text-decoration: none;
}
/* 移除 WooCommerce 在价格后追加的 "Price range: …" 无障碍文本 */
.prod-price-main .screen-reader-text,
.woocommerce div.product .price .screen-reader-text {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
}

/* ── TABS (if using default) — hide and let ACF sections take over ── */
.woocommerce-tabs {
  display: none;
}

/* ── STAR RATING ── */
.woocommerce .star-rating {
  color: var(--coal);
  font-size: 13px;
}

/* ── PLACEHOLDER IMAGE ── */
.vn-placeholder {
  background: var(--bg2);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .woocommerce-account .woocommerce-MyAccount-navigation {
    width: 100%;
    float: none;
    margin-right: 0;
    margin-bottom: 32px;
  }
  .woocommerce-cart table.shop_table img {
    width: 60px;
  }
}

/* ── WPFORMS STYLE OVERRIDES ── */
.wpforms-container .wpforms-form .wpforms-field-label {
  font-size: 11px !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  color: var(--ink2) !important;
  font-weight: 500 !important;
  font-family: var(--sans) !important;
}
.wpforms-container .wpforms-form input[type="text"],
.wpforms-container .wpforms-form input[type="email"],
.wpforms-container .wpforms-form input[type="tel"],
.wpforms-container .wpforms-form input[type="url"],
.wpforms-container .wpforms-form textarea,
.wpforms-container .wpforms-form select {
  background: transparent !important;
  border: none !important;
  border-bottom: 1.5px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 12px 0 !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  color: var(--ink) !important;
  outline: none !important;
  box-shadow: none !important;
}
.wpforms-container .wpforms-form input:focus,
.wpforms-container .wpforms-form textarea:focus,
.wpforms-container .wpforms-form select:focus {
  border-bottom-color: var(--coal) !important;
}
.wpforms-container .wpforms-form button[type="submit"],
.wpforms-container .wpforms-form .wpforms-submit {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  padding: 15px 36px !important;
  background: var(--coal) !important;
  color: var(--white) !important;
  border: 1.5px solid var(--coal) !important;
  border-radius: 0 !important;
  cursor: pointer;
  transition: background .3s, transform .2s;
}
.wpforms-container .wpforms-form button[type="submit"]:hover {
  background: var(--olive) !important;
  border-color: var(--olive) !important;
  transform: translateY(-2px);
}

/* ============================================
   SWATCH VARIATION OVERRIDES
   追加到 woo-overrides.css 末尾
   ============================================ */

/* ── 隐藏WooCommerce默认的变体表格样式 ── */
.woocommerce div.product form.cart .variations {
  border: none !important;
  margin-bottom: 0 !important;
}
.woocommerce div.product form.cart .variations tr {
  display: none !important;
}
.woocommerce div.product form.cart .variations .reset_variations {
  display: none !important;
}

/* ── 隐藏数量选择器 ── */
.woocommerce div.product form.cart .quantity {
  display: none !important;
}

/* ── Add to Cart 按钮全宽样式 ── */
.woocommerce div.product form.cart .single_add_to_cart_button {
  width: 100% !important;
  display: block !important;
  padding: 18px !important;
  margin-bottom: 12px !important;
  font-size: 12px !important;
}

/* ── 不可用的swatch按钮 ── */
.swatch.swatch-disabled {
  opacity: .35;
  cursor: not-allowed;
  text-decoration: line-through;
}

/* ── 价格显示优化（隐藏范围价格中的分） ── */
.woocommerce div.product .prod-price-main .woocommerce-Price-amount {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  color: var(--coal);
}

/* ── 变体描述隐藏 ── */
.woocommerce div.product form.cart .woocommerce-variation-description {
  display: none;
}

/* ── 变体价格（选中后的价格）── */
.woocommerce div.product form.cart .woocommerce-variation-price {
  display: none;
}

/* ── 库存信息样式 ── */
.woocommerce div.product form.cart .woocommerce-variation-availability {
  margin-bottom: 16px;
}
.woocommerce div.product form.cart .woocommerce-variation-availability .stock {
  font-size: 12px;
  color: var(--olive);
  font-weight: 400;
}


/* ============================================
   LAYOUT REFACTOR v2
   1. Below-fold strip (trust + shipping)
   2. Gallery video thumbnail
   ============================================ */

/* ── 1. BELOW-FOLD STRIP ────────────────────────────────────── */
.below-fold-wrap {
  background: var(--bg);
  border-top: 1px solid var(--border);
  padding: 52px var(--pad-x);
}
.below-fold-inner {
  max-width: var(--max-w);
  margin: 0 auto;
}

/* Trust bar:横排，items之间竖线分隔 */
.below-fold-trust {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  border-bottom: 1px solid var(--border);
  padding-bottom: 40px;
  margin-bottom: 40px;
}
.below-fold-trust .trust-item {
  padding: 0 32px 0 0;
  border-right: 1px solid var(--border);
}
.below-fold-trust .trust-item:last-child {
  border-right: none;
  padding-right: 0;
}
.below-fold-trust .trust-label {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--coal);
  margin-bottom: 6px;
}
.below-fold-trust .trust-detail {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 300;
  color: var(--ink2);
  line-height: 1.55;
}

/* Shipping details: 横排，允许换行 */
.below-fold-ship {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 32px 48px;
}
.below-fold-ship .ship-block {
  /* inherits existing .ship-q / .ship-a styles */
}

/* ── 2. GALLERY VIDEO THUMBNAIL ─────────────────────────────── */
.gallery-thumb--video {
  background: #1a1a1a;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
/* Dark overlay so play icon is always readable over the poster image */
.gallery-thumb--video::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.32);
  transition: background .2s;
}
.gallery-thumb--video:hover::after {
  background: rgba(0,0,0,.15);
}
.gallery-thumb-video-icon {
  position: relative;
  z-index: 1; /* sit above the ::after overlay */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: #fff;
  transition: transform .2s;
}
.gallery-thumb--video:hover .gallery-thumb-video-icon {
  transform: scale(1.1);
}
.gallery-thumb-video-icon svg {
  width: 32px;
  height: 32px;
  filter: drop-shadow(0 1px 4px rgba(0,0,0,.5));
}
.gallery-thumb-video-icon span {
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-shadow: 0 1px 3px rgba(0,0,0,.6);
}
.gallery-thumb--video.active {
  outline: 2px solid var(--coal);
  outline-offset: -2px;
}

/* Close button inside video slot */
#gallery-video-close {
  position: absolute;
  top: 12px;
  right: 14px;
  z-index: 10;
  background: rgba(0,0,0,.6);
  border: none;
  color: #fff;
  font-size: 18px;
  line-height: 1;
  padding: 5px 10px;
  cursor: pointer;
  font-family: var(--sans);
  transition: background .2s;
}
#gallery-video-close:hover {
  background: rgba(0,0,0,.9);
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .below-fold-wrap {
    padding: 36px var(--pad-x);
  }
  .below-fold-trust {
    grid-template-columns: 1fr 1fr;
  }
  .below-fold-trust .trust-item {
    border-right: none;
    padding-right: 0;
    border-bottom: 1px solid var(--border);
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
  .below-fold-trust .trust-item:last-child {
    border-bottom: none;
    margin-bottom: 0;
  }
  .below-fold-ship {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
