/* ==========================================================================
   Vinding — WooCommerce overrides
   Styles Woo's default markup to match the Vinding design system. We keep Woo
   templates where possible and only override layout-critical ones.
   ========================================================================== */

/* ---- Shop / archive ---------------------------------------------------- */
.woocommerce-products-header { text-align: center; padding: 140px var(--vd-gutter) 32px; background: var(--vd-cream); }
.woocommerce-products-header__title { font-family: var(--vd-font-serif); font-style: italic; font-weight: 300; font-size: var(--vd-fs-page); margin: 0; }

.vd-shop-layout { display: grid; grid-template-columns: 260px 1fr; gap: 48px; }
@media (max-width: 1024px) { .vd-shop-layout { grid-template-columns: 1fr; } }

.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--vd-gap);
	margin: 0; padding: 0; list-style: none;
}
.vd-shop-layout .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1024px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 600px)  { .woocommerce ul.products { grid-template-columns: 1fr !important; } }

.woocommerce ul.products li.product {
	background: var(--vd-surface);
	border: 1px solid var(--vd-border-soft);
	border-radius: var(--vd-radius-lg);
	overflow: hidden;
	margin: 0;
	text-align: left;
	transition: transform var(--vd-dur) var(--vd-ease), box-shadow var(--vd-dur) var(--vd-ease);
}
.woocommerce ul.products li.product:hover { transform: translateY(-4px); box-shadow: var(--vd-shadow-card); }
.woocommerce ul.products li.product a img { margin: 0; border-radius: 0; aspect-ratio: 4/5; object-fit: cover; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--vd-font-serif); font-style: italic; font-size: var(--vd-fs-h2);
	padding: 18px 20px 0; font-weight: 400;
}
.woocommerce ul.products li.product .price {
	display: block; padding: 6px 20px 0; color: var(--vd-ink); font-weight: 700; font-size: var(--vd-fs-h3);
}
.woocommerce ul.products li.product .price del { color: var(--vd-muted); font-weight: 400; }
.woocommerce ul.products li.product .button {
	margin: 16px 20px 22px;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--vd-ink); color: var(--vd-cream);
	border-radius: var(--vd-radius-pill); padding: 10px 22px;
	font-family: var(--vd-font-sans); font-weight: 700; text-transform: uppercase; font-size: var(--vd-fs-sm);
}
.woocommerce ul.products li.product .button:hover { background: var(--vd-ink-90); }
.woocommerce span.onsale {
	background: var(--vd-accent); color: var(--vd-ink); border-radius: 999px;
	min-height: auto; min-width: auto; padding: 4px 12px; font-weight: 700; font-size: var(--vd-fs-xs);
	top: 12px; left: 12px; margin: 0;
}

/* ---- Single product ---------------------------------------------------- */
.woocommerce div.product { max-width: var(--vd-container); margin: 0 auto; padding: 64px var(--vd-gutter); }
.woocommerce div.product div.images { border-radius: var(--vd-radius-lg); overflow: hidden; }
.woocommerce div.product .product_title { font-family: var(--vd-font-serif); font-style: italic; font-weight: 300; font-size: var(--vd-fs-page); }
.woocommerce div.product p.price,
.woocommerce div.product span.price { color: var(--vd-ink); font-weight: 700; font-size: var(--vd-fs-subtitle); }
.woocommerce div.product form.cart .button,
.woocommerce-page .button.single_add_to_cart_button {
	background: var(--vd-accent); color: var(--vd-ink);
	border-radius: var(--vd-radius-pill); padding: 16px 32px;
	font-family: var(--vd-font-sans); font-weight: 700; text-transform: uppercase; font-size: var(--vd-fs-body);
}
.woocommerce div.product form.cart .button:hover { background: #ecf86a; }
.woocommerce .quantity .qty {
	border: 1px solid var(--vd-border); border-radius: var(--vd-radius-sm); padding: 14px; height: auto;
}

/* Product custom-field meta panel (rendered by inc/product-display.php) */
.vd-product-attrs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 32px; margin: 24px 0; padding: 24px 0; border-block: 1px solid var(--vd-border-soft); }
.vd-product-attrs__item { display: flex; flex-direction: column; gap: 2px; }
.vd-product-attrs__label { font-size: var(--vd-fs-xs); text-transform: uppercase; letter-spacing: 1px; color: var(--vd-muted); }
.vd-product-attrs__value { font-weight: 700; }

.woocommerce-tabs ul.tabs li { background: transparent; border: 0; }
.woocommerce-tabs ul.tabs li.active a { color: var(--vd-ink); }
.woocommerce-tabs ul.tabs::before { border-color: var(--vd-border-soft); }

/* ---- Cart -------------------------------------------------------------- */
.woocommerce-cart .wp-block-page-content,
.woocommerce-cart-form,
.woocommerce-checkout #order_review,
.woocommerce-checkout #customer_details { font-family: var(--vd-font-sans); }
.woocommerce-cart table.cart,
.woocommerce table.shop_table { border: 1px solid var(--vd-border-soft); border-radius: var(--vd-radius-lg); overflow: hidden; }
.woocommerce table.shop_table th { background: var(--vd-surface); font-family: var(--vd-font-sans); }
.woocommerce-cart table.cart td.actions .button,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
	background: var(--vd-ink); color: var(--vd-cream); border-radius: var(--vd-radius-pill);
	text-transform: uppercase; font-weight: 700;
}
.woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt,
.wc-proceed-to-checkout a.checkout-button { background: var(--vd-accent) !important; color: var(--vd-ink) !important; }

/* Line-item meta (custom tour answers shown in cart/checkout) */
.woocommerce-cart .variation,
.woocommerce td.product-name dl.variation,
.wc-item-meta { font-size: var(--vd-fs-xs); color: var(--vd-muted); }
.wc-item-meta { list-style: none; margin: 8px 0 0; padding: 0; }
.wc-item-meta li { display: flex; gap: 6px; }
.wc-item-meta strong { font-weight: 700; color: var(--vd-ink); }

/* ---- Checkout ---------------------------------------------------------- */
.woocommerce-checkout .col2-set, .woocommerce-checkout #customer_details { margin-bottom: 32px; }
.woocommerce form .form-row label { font-family: var(--vd-font-sans); font-weight: 700; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container--default .select2-selection--single {
	border: 1px solid var(--vd-border); border-radius: var(--vd-radius-sm); padding: 12px 14px; height: auto;
}
#order_review, .woocommerce-checkout #payment { background: var(--vd-surface); border-radius: var(--vd-radius-lg); }
.woocommerce-checkout #payment { border: 1px solid var(--vd-border-soft); }
#place_order { background: var(--vd-accent) !important; color: var(--vd-ink) !important; width: 100%; height: 56px; }

/* ---- Notices ----------------------------------------------------------- */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	border-top-color: var(--vd-ink); border-radius: var(--vd-radius-sm);
	font-family: var(--vd-font-sans);
}
.woocommerce-message { border-top-color: var(--vd-success); }
.woocommerce-error { border-top-color: var(--vd-danger); }
