/*!
 * UrbanGreen — WooCommerce styles.
 * Visual restyle ONLY. No checkout / payment / shipping logic is altered here;
 * this file never changes form structure, field names, or gateway markup.
 */

/* ---------------------------------------------------------- Shop layout */
.ug-shop { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: clamp(24px, 3vw, 56px); align-items: start; padding-block: var(--ug-sp-6); max-width: 1600px; margin-inline: auto; padding-inline: clamp(16px, 3vw, 48px); }
.ug-shop__main { min-width: 0; }
.ug-shop__main ul.products, .ug-shop__main .product-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
/* WooCommerce injects inline width/float on loop items — neutralise so the grid governs. */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.ug-shop__main ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	clear: none !important;
}
.woocommerce ul.products { display: grid !important; }
.woocommerce ul.products::before, .woocommerce ul.products::after { display: none !important; content: none !important; }
.ug-shop--no-sidebar { grid-template-columns: 1fr; }
.ug-shop__header { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--ug-sp-4) var(--ug-sp-5); flex-wrap: wrap; margin: 0 auto; max-width: 1600px; padding: clamp(24px, 4vw, 48px) clamp(16px, 3vw, 48px) var(--ug-sp-4); }
.ug-shop__title { font-size: var(--ug-step-3); text-transform: uppercase; }
.ug-shop__count { color: var(--ug-muted); font-size: var(--ug-step-0); margin-left: 12px; font-weight: 400; }
.ug-shop__desc { color: var(--ug-muted); margin-top: 8px; max-width: 60ch; }
/* Clean catalog ordering dropdown */
.woocommerce-ordering { margin: 0; }
.woocommerce-ordering select, select.orderby {
	-webkit-appearance: none; -moz-appearance: none; appearance: none;
	border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius);
	padding: 12px 44px 12px 16px; background: var(--ug-bg);
	font-family: var(--ug-font-display); font-size: var(--ug-step--1);
	letter-spacing: .04em; text-transform: uppercase; font-weight: 600; cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%230A0A0A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 14px center;
	min-width: 200px; transition: border-color var(--ug-dur) var(--ug-ease);
}
.woocommerce-ordering select:focus, select.orderby:focus { outline: none; border-color: var(--ug-ink); }
.ug-shop__count { color: var(--ug-muted); font-size: var(--ug-step--1); }

/* Sidebar / filters */
.shop-sidebar { position: sticky; top: calc(var(--ug-header-h) + 16px); display: grid; gap: var(--ug-sp-5); }
.filter-group { border-bottom: 1px solid var(--ug-line); padding-bottom: var(--ug-sp-4); }
.filter-group__title { font-family: var(--ug-font-display); font-size: var(--ug-step--1); letter-spacing: .14em; text-transform: uppercase; margin-bottom: var(--ug-sp-3); display: flex; justify-content: space-between; align-items: center; }
.filter-list { display: grid; gap: var(--ug-sp-2); max-height: 220px; overflow-y: auto; }
.filter-check { display: flex; align-items: center; gap: var(--ug-sp-2); font-size: var(--ug-step--1); cursor: pointer; }
.filter-check input { width: 17px; height: 17px; accent-color: var(--ug-accent); }
.filter-check__count { margin-left: auto; color: var(--ug-muted); font-size: 12px; }
.color-swatches { display: flex; flex-wrap: wrap; gap: 8px; }
.color-swatch { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--ug-line); position: relative; cursor: pointer; }
.color-swatch input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.color-swatch.is-checked { box-shadow: 0 0 0 2px var(--ug-bg), 0 0 0 4px var(--ug-accent); }
.size-pills { display: flex; flex-wrap: wrap; gap: 6px; }
.size-pill { border: 1px solid var(--ug-line); border-radius: var(--ug-radius); padding: 7px 12px; font-size: var(--ug-step--1); cursor: pointer; position: relative; min-width: 42px; text-align: center; }
.size-pill input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.size-pill.is-checked { background: var(--ug-ink); color: var(--ug-paper); border-color: var(--ug-ink); }
.price-range { display: grid; gap: var(--ug-sp-3); }
.price-range__values { display: flex; justify-content: space-between; font-size: var(--ug-step--1); font-weight: 600; }
.price-range__sliders { position: relative; height: 28px; }
.price-range__sliders input[type="range"] { position: absolute; left: 0; right: 0; top: 8px; width: 100%; -webkit-appearance: none; appearance: none; background: none; pointer-events: none; height: 4px; }
.price-range__sliders input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; pointer-events: auto; width: 18px; height: 18px; border-radius: 50%; background: var(--ug-ink); cursor: pointer; border: 2px solid var(--ug-bg); }
.price-range__sliders input[type="range"]::-moz-range-thumb { pointer-events: auto; width: 18px; height: 18px; border-radius: 50%; background: var(--ug-ink); cursor: pointer; border: 2px solid var(--ug-bg); }
.price-range__track { position: absolute; left: 0; right: 0; top: 12px; height: 4px; border-radius: 4px; background: var(--ug-line); }
.filter-reset { font-size: var(--ug-step--1); text-decoration: underline; color: var(--ug-muted); }

/* Shop toolbar */
.shop-toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--ug-sp-3); margin-bottom: var(--ug-sp-4); flex-wrap: wrap; }
.shop-toolbar__count { color: var(--ug-muted); font-size: var(--ug-step-0); }
.shop-toolbar__actions { display: flex; align-items: center; gap: clamp(16px, 2vw, 32px); }
.shop-toolbar__btn { display: inline-flex; align-items: center; gap: 8px; background: none; border: none; cursor: pointer; font-size: var(--ug-step-0); font-weight: 500; color: var(--ug-fg); }
.shop-toolbar__btn .ug-icon { width: 18px; height: 18px; }
.shop-toolbar__btn:hover { color: var(--ug-accent); }
.shop-toolbar__sort .orderby, .shop-toolbar__select { border: none; background: none; font-size: var(--ug-step-0); font-weight: 500; cursor: pointer; padding: 4px 0; color: var(--ug-fg); }
/* Hide filters: collapse the sidebar column, widen the grid */
.ug-shop--filters-hidden { grid-template-columns: 1fr; }
.ug-shop--filters-hidden .shop-sidebar { display: none; }
.ug-shop--filters-hidden .ug-shop__main ul.products { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.filter-toggle { display: none; }

/* The product grid is loaded into [data-shop-grid] */
[data-shop-grid] { position: relative; transition: opacity var(--ug-dur) var(--ug-ease); }
[data-shop-grid].is-loading { opacity: .5; pointer-events: none; }
.shop-loadmore { display: flex; justify-content: center; margin-top: var(--ug-sp-7); }

/* ---------------------------------------------------------- Single product */
.single-product__wrap { display: block; }
.single-product .product__layout { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(24px, 5vw, 72px); align-items: start; padding-block: var(--ug-sp-6); }
.single-product .woocommerce-tabs { clear: both; width: 100%; }
.product__gallery { position: sticky; top: calc(var(--ug-header-h) + 16px); display: grid; grid-template-columns: 74px 1fr; gap: 14px; align-items: start; }
.product__gallery-stage { position: relative; }
.product__gallery-main { aspect-ratio: 1/1; overflow: hidden; border-radius: var(--ug-radius); background: #fff; }
.product__gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.product__thumbs { display: flex; flex-direction: column; gap: 10px; max-height: 560px; overflow-y: auto; scrollbar-width: thin; }
.product__thumbs::-webkit-scrollbar { width: 0; }
.product__thumb { width: 74px; aspect-ratio: 1/1; border-radius: var(--ug-radius); overflow: hidden; border: 1.5px solid var(--ug-line); cursor: pointer; background: #fff; flex: none; transition: border-color var(--ug-dur) var(--ug-ease); }
.product__thumb:hover { border-color: var(--ug-gray-400); }
.product__thumb.is-active { border-color: var(--ug-ink); }
.product__thumb img { width: 100%; height: 100%; object-fit: cover; }
.product__gallery-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; width: 44px; height: 44px; border-radius: 50%; background: var(--ug-bg); box-shadow: var(--ug-shadow-md); display: inline-flex; align-items: center; justify-content: center; color: var(--ug-fg); transition: background var(--ug-dur) var(--ug-ease); }
.product__gallery-arrow:hover { background: var(--ug-surface-2); }
.product__gallery-arrow--prev { left: 12px; }
.product__gallery-arrow--next { right: 12px; }
@media (max-width: 600px) {
	.product__gallery { grid-template-columns: 1fr; }
	.product__thumbs { flex-direction: row; max-height: none; order: 2; overflow-x: auto; }
	.product__gallery-stage { order: 1; }
}
.product__summary { display: grid; gap: var(--ug-sp-4); }
.product__eyebrow { font-size: var(--ug-step--1); letter-spacing: .14em; text-transform: uppercase; color: var(--ug-muted); }
.product__title { font-size: var(--ug-step-3); text-transform: uppercase; }
.product__price { font-family: var(--ug-font-display); font-size: var(--ug-step-2); font-weight: 600; }
.product__price del { color: var(--ug-muted); font-weight: 400; margin-right: 10px; }
.product__price ins { text-decoration: none; color: var(--ug-sale); }
.product__sizes { display: grid; gap: var(--ug-sp-2); }
.product__sizes-head { display: block; margin: 4px 0 8px; }
.size-guide-link { font-size: var(--ug-step--1); text-decoration: underline; }
.product__purchase { display: grid; gap: var(--ug-sp-3); }
.product .quantity { display: inline-flex; align-items: center; border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); overflow: hidden; }
.product .quantity input { width: 56px; text-align: center; border: none; background: transparent; padding: 12px 0; }
.product__meta { font-size: var(--ug-step--1); color: var(--ug-muted); display: grid; gap: 4px; padding-top: var(--ug-sp-4); }

/* WC tabs / reviews */
.woocommerce-tabs { padding-block: var(--ug-sp-7); border-top: 1px solid var(--ug-line); margin-top: var(--ug-sp-6); }
.woocommerce-tabs ul.tabs { display: flex; gap: var(--ug-sp-6); border-bottom: 1px solid var(--ug-line); margin: 0 0 var(--ug-sp-5); padding: 0; flex-wrap: wrap; list-style: none; }
.woocommerce-tabs ul.tabs::before, .woocommerce-tabs ul.tabs::after { display: none; }
.woocommerce-tabs ul.tabs li { padding: 0 0 var(--ug-sp-3); margin: 0; background: none; border: none; border-radius: 0; }
.woocommerce-tabs ul.tabs li::before, .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce-tabs ul.tabs li a { font-family: var(--ug-font-display); font-size: var(--ug-step--1); letter-spacing: .12em; text-transform: uppercase; font-weight: 600; color: var(--ug-muted); padding: 0; }
.woocommerce-tabs ul.tabs li.active a { color: var(--ug-fg); }
.woocommerce-tabs ul.tabs li.active { box-shadow: inset 0 -2px 0 var(--ug-ink); }
.woocommerce-tabs .panel { max-width: 820px; }
.woocommerce-tabs .panel h2 { font-size: var(--ug-step-2); text-transform: uppercase; margin-bottom: var(--ug-sp-3); }
.woocommerce-tabs .panel p { margin-bottom: 1em; color: var(--ug-gray-600); }

/* Size guide modal */
.size-guide-table { width: 100%; border-collapse: collapse; }
.size-guide-table th, .size-guide-table td { border: 1px solid var(--ug-line); padding: 10px 14px; text-align: center; font-size: var(--ug-step--1); }
.size-guide-table th { background: var(--ug-surface); font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .08em; }

/* Sticky ATC (mobile) */
.sticky-atc { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--ug-z-overlay); background: var(--ug-bg); border-top: 1px solid var(--ug-line); padding: var(--ug-sp-3) var(--ug-gutter); display: flex; align-items: center; gap: var(--ug-sp-3); transform: translateY(110%); transition: transform var(--ug-dur) var(--ug-ease); box-shadow: 0 -6px 24px rgba(10,10,10,.1); }
.sticky-atc.is-visible { transform: none; }
.sticky-atc__price { font-family: var(--ug-font-display); font-weight: 600; }
.sticky-atc .btn { margin-left: auto; }

/* ---------------------------------------------------------- Cart / Checkout
   Light cosmetic touches only — layout/flow untouched so payments & shipping
   behave exactly as WooCommerce core / gateways expect. */
.woocommerce-cart .shop_table, .woocommerce-checkout .shop_table { border: 1px solid var(--ug-line); border-radius: var(--ug-radius); border-collapse: separate; border-spacing: 0; width: 100%; }
.woocommerce-cart .shop_table th { font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .08em; font-size: var(--ug-step--1); padding: var(--ug-sp-3); text-align: left; }
.woocommerce-cart .shop_table td { padding: var(--ug-sp-3); border-top: 1px solid var(--ug-line); vertical-align: middle; }
.woocommerce .cart_totals, .woocommerce-checkout #order_review { border: 1px solid var(--ug-line); border-radius: var(--ug-radius); padding: var(--ug-sp-5); }
.woocommerce form .form-row label { font-size: var(--ug-step--1); font-weight: 600; margin-bottom: 4px; display: block; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select, .select2-container .select2-selection { border: 1.5px solid var(--ug-line) !important; border-radius: var(--ug-radius) !important; padding: 12px 14px !important; background: var(--ug-bg); min-height: 48px; }
.woocommerce #payment, .woocommerce-checkout #payment { background: var(--ug-surface); border-radius: var(--ug-radius); }
.woocommerce #payment ul.payment_methods { padding: var(--ug-sp-4); }
.woocommerce-checkout #payment div.payment_box { background: var(--ug-bg); border-radius: var(--ug-radius); }
.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
	background: var(--ug-ink); color: var(--ug-paper); border-radius: var(--ug-radius);
	font-family: var(--ug-font-display); font-weight: 600; text-transform: uppercase; letter-spacing: .06em;
	padding: 14px 26px; border: 1.5px solid var(--ug-ink); transition: transform var(--ug-dur) var(--ug-ease);
}
.woocommerce #respond input#submit:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover { transform: translateY(-2px); color: var(--ug-paper); }
.woocommerce .button.alt, .woocommerce #place_order { background: var(--ug-accent); border-color: var(--ug-accent); color: var(--ug-accent-ink); width: 100%; }
.woocommerce-message, .woocommerce-info, .woocommerce-error { border-top-color: var(--ug-accent); border-radius: var(--ug-radius); }
.woocommerce-message { border-top-color: var(--ug-accent); }

/* My account */
.woocommerce-account .woocommerce-MyAccount-navigation ul { display: grid; gap: 4px; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 12px 16px; border-radius: var(--ug-radius); font-weight: 600; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--ug-ink); color: var(--ug-paper); }
.woocommerce-account .woocommerce-MyAccount-content { border: 1px solid var(--ug-line); border-radius: var(--ug-radius); padding: var(--ug-sp-5); }

/* Wishlist page */
.ug-wishlist-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--ug-gutter); }
.ug-wishlist-empty { text-align: center; padding: var(--ug-sp-8); color: var(--ug-muted); }

/* ---------------------------------------------------------- Responsive */
@media (max-width: 1024px) {
	.single-product .product__layout { grid-template-columns: 1fr; }
	.product__gallery { position: static; }
}
@media (max-width: 860px) {
	.ug-shop { grid-template-columns: 1fr; }
	.filter-toggle { display: inline-flex; }
	.shop-sidebar { position: fixed; top: 0; left: 0; height: 100dvh; width: min(360px, 88vw); background: var(--ug-bg); z-index: var(--ug-z-drawer); padding: var(--ug-sp-5); transform: translateX(-100%); transition: transform var(--ug-dur) var(--ug-ease); overflow-y: auto; box-shadow: var(--ug-shadow-lg); }
	.shop-sidebar.is-open { transform: none; }
}
@media (min-width: 861px) {
	.sticky-atc { display: none; }
}

/* ---------------------------------------------------------- Single ATC button (override WC default purple) */
.woocommerce div.product form.cart .button,
.woocommerce .single_add_to_cart_button,
.woocommerce button.single_add_to_cart_button {
	background: var(--ug-ink) !important;
	color: var(--ug-paper) !important;
	border: 1.5px solid var(--ug-ink) !important;
	border-radius: var(--ug-radius) !important;
	font-family: var(--ug-font-display);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	padding: 16px 32px !important;
	width: 100%;
	transition: transform var(--ug-dur) var(--ug-ease), opacity var(--ug-dur) var(--ug-ease);
}
.woocommerce .single_add_to_cart_button:hover { transform: translateY(-2px); opacity: .92; }
.woocommerce .single_add_to_cart_button.disabled,
.woocommerce .single_add_to_cart_button:disabled {
	background: var(--ug-gray-300) !important;
	border-color: var(--ug-gray-300) !important;
	color: var(--ug-gray-600) !important;
	cursor: not-allowed;
	transform: none;
}
/* Variation select styling */
.woocommerce div.product form.cart .variations select { border: 1.5px solid var(--ug-line) !important; border-radius: var(--ug-radius) !important; padding: 12px 14px !important; min-height: 48px; background: var(--ug-bg); min-width: 200px; }
.woocommerce div.product form.cart .variations th { font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .08em; font-size: var(--ug-step--1); text-align: left; padding-right: 16px; }
.woocommerce div.product .quantity .qty { border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); padding: 12px 8px; width: 64px; text-align: center; }

/* ---------------------------------------------------------- Loop card polish */
.ug-shop__main li.product .product-card__eyebrow,
.ug-shop__main li.product .product-card__title { white-space: normal; }
.ug-shop__main li.product .product-card__atc { white-space: nowrap; width: 100%; padding-inline: 12px; }
.ug-shop__main li.product .woocommerce-loop-product__title,
.ug-shop__main li.product .product-card__title { font-size: var(--ug-step-0); line-height: 1.25; }

/* ---------------------------------------------------------- Related products */
.related-products { border-top: 1px solid var(--ug-line); padding-block: clamp(40px,6vw,80px); margin-top: var(--ug-sp-6); }
.related-products .section__head { margin-bottom: var(--ug-sp-5); }
.related-products .products { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) { .related-products .products { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .related-products .products { grid-template-columns: repeat(2, 1fr); } }

/* ---------------------------------------------------------- Size boxes (variation buttons) */
.ug-select-hidden { position: absolute !important; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.size-boxes { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.size-box {
	min-width: 52px; padding: 12px 16px; border: 1.5px solid var(--ug-line);
	border-radius: var(--ug-radius); background: var(--ug-bg); font-family: var(--ug-font-display);
	font-weight: 600; font-size: var(--ug-step--1); letter-spacing: .04em; text-transform: uppercase;
	cursor: pointer; transition: border-color var(--ug-dur) var(--ug-ease), background var(--ug-dur) var(--ug-ease), color var(--ug-dur) var(--ug-ease);
}
.size-box:hover { border-color: var(--ug-ink); }
.size-box.is-selected { background: var(--ug-ink); color: var(--ug-paper); border-color: var(--ug-ink); }
.size-box.is-disabled { opacity: .4; cursor: not-allowed; text-decoration: line-through; }
/* Hide the WC "Clear" link until a selection is made — cleaner look */
.woocommerce-variation-add-to-cart .reset_variations { font-size: var(--ug-step--1); color: var(--ug-muted); text-decoration: underline; margin-left: 12px; }

/* ---------------------------------------------------------- Quantity + ATC row alignment */
/* Single clean column: qty (row with button), then full-width buttons. */
.woocommerce div.product form.cart { display: flex; flex-direction: column; align-items: stretch; gap: 12px; margin: 0; max-width: 440px; }
.woocommerce div.product form.cart .variations { width: 100%; margin-bottom: 4px; }
.woocommerce div.product form.cart::before, .woocommerce div.product form.cart::after { display: none; content: none; }
/* qty + ADD TO CART share one row, button fills remaining width */
.woocommerce div.product form.cart .quantity { margin: 0; display: block; width: 96px; flex: 0 0 auto; }
.woocommerce div.product form.cart .quantity .qty { height: 54px; width: 100%; border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); text-align: center; }
.woocommerce div.product form.cart .single_add_to_cart_button { width: 100%; min-height: 54px; margin: 0; }
/* Simple product: wrap qty + button into a row */
.woocommerce div.product form.cart:not(.variations_form) { display: grid; grid-template-columns: 96px 1fr; gap: 12px; align-items: stretch; }
.woocommerce div.product form.cart:not(.variations_form) .quantity { width: auto; }
/* Variable products: WC groups qty+button here — put them on one row */
.woocommerce div.product form.cart .woocommerce-variation-add-to-cart { display: grid; grid-template-columns: 96px 1fr; gap: 12px; align-items: stretch; width: 100%; }
.woocommerce div.product form.cart .variations { width: 100%; margin-bottom: 4px; }
.woocommerce div.product .woocommerce-variation { width: 100%; }
.woocommerce div.product .woocommerce-variation-price { font-family: var(--ug-font-display); font-size: var(--ug-step-1); font-weight: 600; margin-bottom: 8px; }
.woocommerce div.product .stock { font-size: var(--ug-step--1); color: var(--ug-accent); font-weight: 600; margin-bottom: 4px; }

/* ---------------------------------------------------------- Features tab */
.ug-features__list { display: grid; gap: 10px; margin: 0; padding: 0; list-style: none; }
.ug-features__list li { position: relative; padding-left: 26px; color: var(--ug-gray-600); }
.ug-features__list li::before { content: ""; position: absolute; left: 0; top: 9px; width: 14px; height: 2px; background: var(--ug-accent); }

/* ---------------------------------------------------------- Product accordions (Nike-style) */
.product__accordions { margin-top: var(--ug-sp-4); border-top: 1px solid var(--ug-line); }
.accordion { border-bottom: 1px solid var(--ug-line); }
.accordion__head { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 18px 0; text-align: left; font-family: var(--ug-font-display); font-size: var(--ug-step-0); font-weight: 600; cursor: pointer; gap: 12px; }
.accordion__icon { display: inline-flex; transition: transform var(--ug-dur) var(--ug-ease); color: var(--ug-muted); }
.accordion.is-open .accordion__icon { transform: rotate(180deg); }
.accordion__body { max-height: 0; overflow: hidden; transition: max-height var(--ug-dur) var(--ug-ease); }
.accordion__inner { padding: 0 0 18px; color: var(--ug-gray-600); font-size: var(--ug-step-0); line-height: 1.6; }
.accordion__inner p { margin: 0; }

/* ---------------------------------------------------------- Accordion rich content */
.accordion__inner p { margin-bottom: 1em; }
.accordion__inner p:last-child { margin-bottom: 0; }
.accordion__inner ul { display: grid; gap: 8px; margin: 0; padding: 0; list-style: none; }
.accordion__inner ul li { position: relative; padding-left: 22px; }
.accordion__inner ul li::before { content: ""; position: absolute; left: 0; top: 9px; width: 12px; height: 2px; background: var(--ug-accent); }
.accordion__inner table.woocommerce-product-attributes, .accordion__inner .shop_attributes { width: 100%; border-collapse: collapse; }
.accordion__inner .shop_attributes th, .accordion__inner .shop_attributes td { text-align: left; padding: 8px 0; border-bottom: 1px solid var(--ug-line); font-size: var(--ug-step--1); }
.accordion__inner .shop_attributes th { font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .04em; width: 38%; }

/* Reviews modal */
.ug-link-btn { background: none; border: none; padding: 0; font: inherit; color: inherit; cursor: pointer; text-decoration: underline; }
.reviews-modal { position: fixed; inset: 0; z-index: 500; display: flex; align-items: center; justify-content: center; padding: 16px; opacity: 0; transition: opacity var(--ug-dur) var(--ug-ease); }
.reviews-modal.is-open { opacity: 1; }
.reviews-modal[hidden] { display: none; }
.reviews-modal__overlay { position: absolute; inset: 0; background: rgba(10,10,10,.55); }
.reviews-modal__dialog { position: relative; z-index: 1; background: var(--ug-bg); border-radius: var(--ug-radius); width: min(640px, 100%); max-height: 88vh; overflow-y: auto; padding: clamp(24px,4vw,44px); box-shadow: var(--ug-shadow-lg); transform: translateY(14px); transition: transform var(--ug-dur) var(--ug-ease); }
.reviews-modal.is-open .reviews-modal__dialog { transform: none; }
.reviews-modal__close { position: absolute; top: 12px; right: 14px; width: 42px; height: 42px; border-radius: 50%; font-size: 26px; line-height: 1; color: var(--ug-fg); transition: background var(--ug-dur) var(--ug-ease); }
.reviews-modal__close:hover { background: var(--ug-surface-2); }
.reviews-modal__body .comment-reply-title, .reviews-modal__body #reply-title { font-family: var(--ug-font-display); font-size: var(--ug-step-2); text-transform: uppercase; margin-bottom: 16px; }
.reviews-modal__body .comment-form { display: grid; gap: 14px; }
.reviews-modal__body .comment-form input[type="text"], .reviews-modal__body .comment-form input[type="email"], .reviews-modal__body .comment-form textarea {
	border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); padding: 12px 14px; width: 100%; font: inherit;
}
.reviews-modal__body .comment-form textarea:focus, .reviews-modal__body .comment-form input:focus { outline: none; border-color: var(--ug-accent); }
.reviews-modal__body .commentlist { display: grid; gap: 22px; margin: 0 0 28px; padding: 0; list-style: none; }
.reviews-modal__body .stars a { color: var(--ug-accent); }
.reviews-modal__body .form-submit input { background: var(--ug-ink); color: var(--ug-paper); border: none; border-radius: var(--ug-radius); padding: 14px 28px; font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; cursor: pointer; }

/* ---------------------------------------------------------- Short desc + read more */
.product__desc { color: var(--ug-gray-600); margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--ug-line); max-width: 52ch; }
.product__desc p { margin: 0 0 8px; }
.product__desc p { margin: 0 0 8px; }
.product__readmore { display: inline-block; margin-top: 4px; font-family: var(--ug-font-display); font-size: var(--ug-step--1); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; text-decoration: underline; cursor: pointer; }
.product__readmore:hover { color: var(--ug-accent); }

/* ---------------------------------------------------------- Variations: label beside boxes */
.woocommerce div.product form.cart table.variations { border: none; margin: 0 0 8px; width: 100%; }
.woocommerce div.product form.cart table.variations tbody, 
.woocommerce div.product form.cart table.variations tr { display: flex; align-items: center; flex-wrap: wrap; gap: 16px; }
.woocommerce div.product form.cart table.variations td, 
.woocommerce div.product form.cart table.variations th { display: block; padding: 0; border: none; }
.woocommerce div.product form.cart table.variations th.label { flex: 0 0 auto; }
.woocommerce div.product form.cart table.variations th.label label { font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .08em; font-size: var(--ug-step--1); font-weight: 700; margin: 0; }
.woocommerce div.product form.cart table.variations td.value { flex: 1 1 auto; }
.woocommerce div.product form.cart .size-boxes { margin-top: 0; }
/* Hide the "Clear" link until a variation is chosen (cleaner) */
.woocommerce div.product .variations_form .reset_variations { display: inline-block; margin-left: 8px; font-size: var(--ug-step--1); }

/* ---------------------------------------------------------- Size guide modal */
.sizeguide-modal { position: fixed; inset: 0; z-index: 500; display: flex; align-items: center; justify-content: center; padding: 16px; opacity: 0; transition: opacity var(--ug-dur) var(--ug-ease); }
.sizeguide-modal.is-open { opacity: 1; }
.sizeguide-modal[hidden] { display: none; }
.sizeguide-modal__overlay { position: absolute; inset: 0; background: rgba(10,10,10,.55); }
.sizeguide-modal__dialog { position: relative; z-index: 1; background: var(--ug-bg); border-radius: var(--ug-radius); width: min(720px, 100%); max-height: 88vh; overflow-y: auto; padding: clamp(24px,4vw,44px); box-shadow: var(--ug-shadow-lg); transform: translateY(14px); transition: transform var(--ug-dur) var(--ug-ease); }
.sizeguide-modal.is-open .sizeguide-modal__dialog { transform: none; }
.sizeguide-modal__close { position: absolute; top: 12px; right: 14px; width: 42px; height: 42px; border-radius: 50%; font-size: 26px; line-height: 1; color: var(--ug-fg); transition: background var(--ug-dur) var(--ug-ease); }
.sizeguide-modal__close:hover { background: var(--ug-surface-2); }
.sizeguide-modal__title { font-family: var(--ug-font-display); font-size: var(--ug-step-2); text-transform: uppercase; margin-bottom: 18px; }
.sizeguide-modal__body table { width: 100%; border-collapse: collapse; }
.sizeguide-modal__body th, .sizeguide-modal__body td { border: 1px solid var(--ug-line); padding: 10px 14px; text-align: center; font-size: var(--ug-step--1); }
.sizeguide-modal__body th { background: var(--ug-surface); font-family: var(--ug-font-display); text-transform: uppercase; letter-spacing: .06em; }

/* ---------------------------------------------------------- Product star rating */
.product__rating { display: flex; align-items: center; gap: 12px; margin: -4px 0 4px; }
.product__rating .star-rating { font-size: 1em; color: var(--ug-accent); overflow: hidden; position: relative; height: 1.2em; width: 6.2em; font-family: star; line-height: 1.2; }
.product__rating .star-rating::before { content: "\73\73\73\73\73"; color: var(--ug-gray-300); float: left; top: 0; left: 0; position: absolute; }
.product__rating .star-rating span { overflow: hidden; float: left; top: 0; left: 0; position: absolute; padding-top: 1.5em; }
.product__rating .star-rating span::before { content: "\53\53\53\53\53"; top: 0; position: absolute; left: 0; color: var(--ug-accent); }
.product__rating-count { font-size: var(--ug-step--1); color: var(--ug-muted); text-decoration: underline; cursor: pointer; }
.product__rating-count:hover { color: var(--ug-accent); }

/* ---------------------------------------------------------- Related carousel (Nike-style) */
.related-products[data-carousel] .section__head { display: flex; align-items: center; justify-content: space-between; }
.carousel-nav { display: flex; gap: 8px; }
.carousel-nav__btn { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--ug-line); display: inline-flex; align-items: center; justify-content: center; background: var(--ug-bg); color: var(--ug-fg); transition: background var(--ug-dur) var(--ug-ease), opacity var(--ug-dur) var(--ug-ease); }
.carousel-nav__btn:hover { background: var(--ug-surface-2); }
.carousel-nav__btn:disabled { opacity: .35; cursor: default; }
.related-carousel { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(240px, 1fr); gap: 20px; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 8px; margin: 0; list-style: none; scrollbar-width: none; }
.related-carousel::-webkit-scrollbar { display: none; }
.related-carousel > li { scroll-snap-align: start; }
@media (min-width: 1100px) { .related-carousel { grid-auto-columns: minmax(0, calc(25% - 15px)); } }
@media (max-width: 600px) { .related-carousel { grid-auto-columns: minmax(70%, 1fr); } }

/* ---------------------------------------------------------- Product wishlist button */
.product__wishlist { display: inline-flex; align-items: center; justify-content: center; gap: 10px; width: 100%; max-width: 440px; min-height: 54px; margin-top: 0; padding: 0 24px; border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); background: var(--ug-bg); font-family: var(--ug-font-display); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; font-size: var(--ug-step--1); cursor: pointer; transition: border-color var(--ug-dur) var(--ug-ease), color var(--ug-dur) var(--ug-ease); }
.product__wishlist:hover { border-color: var(--ug-ink); }
.product__wishlist .ug-icon { width: 20px; height: 20px; transition: fill var(--ug-dur) var(--ug-ease); }
.product__wishlist.is-active { border-color: var(--ug-accent); color: var(--ug-accent); }
.product__wishlist.is-active .ug-icon { fill: var(--ug-accent); }
.product__purchase { display: flex; flex-direction: column; gap: 12px; }

/* Empty star rating (no reviews yet) */
.star-rating--empty { color: var(--ug-gray-300); }
.star-rating--empty::before { content: "\73\73\73\73\73"; color: var(--ug-gray-300); }

/* ---------------------------------------------------------- Nike-style collapsible filters */
.shop-sidebar { font-size: var(--ug-step-0); }
.filter-group { border-bottom: 1px solid var(--ug-line); padding: 0; }
.filter-group:first-child { border-top: 1px solid var(--ug-line); }
.filter-group__title { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 18px 0; background: none; border: none; cursor: pointer; font-family: var(--ug-font-display); font-weight: 600; font-size: var(--ug-step-0); letter-spacing: .02em; text-align: left; color: var(--ug-fg); }
.filter-group__chevron { display: inline-flex; color: var(--ug-muted); transition: transform var(--ug-dur) var(--ug-ease); }
.filter-group__chevron .ug-icon { width: 18px; height: 18px; }
.filter-group:not(.is-open) .filter-group__chevron { transform: rotate(-90deg); }
.filter-group__body { overflow: hidden; max-height: 1000px; transition: max-height var(--ug-dur) var(--ug-ease), opacity var(--ug-dur) var(--ug-ease), padding var(--ug-dur) var(--ug-ease); padding-bottom: 20px; }
.filter-group:not(.is-open) .filter-group__body { max-height: 0; opacity: 0; padding-bottom: 0; }
.filter-list { display: grid; gap: 12px; }
.filter-check { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: var(--ug-step-0); }
.filter-check input { width: 18px; height: 18px; accent-color: var(--ug-ink); }
.filter-check__count { margin-left: auto; color: var(--ug-muted); font-size: var(--ug-step--1); }
.size-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.size-pill { position: relative; }
.size-pill span { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 38px; padding: 0 10px; border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); font-size: var(--ug-step--1); font-weight: 600; cursor: pointer; transition: border-color var(--ug-dur) var(--ug-ease); }
.size-pill input { position: absolute; opacity: 0; }
.size-pill input:checked + span { border-color: var(--ug-ink); background: var(--ug-ink); color: var(--ug-paper); }
.color-swatches { display: flex; flex-wrap: wrap; gap: 12px; }
.color-swatch { width: 32px; height: 32px; border-radius: 50%; cursor: pointer; position: relative; border: 2px solid var(--ug-line); }
.color-swatch input { position: absolute; opacity: 0; }
.color-swatch input:checked + span, .color-swatch:has(input:checked) { outline: 2px solid var(--ug-ink); outline-offset: 2px; }

/* Wider product grid on shop */
.ug-shop__main ul.products, .ug-shop__main .product-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: clamp(16px, 2vw, 32px) clamp(12px, 1.5vw, 20px); }
@media (min-width: 1400px) { .ug-shop__main ul.products { grid-template-columns: repeat(3, 1fr); } }

/* ---------------------------------------------------------- UGC "How Others Are Wearing It" */
.ugc { border-top: 1px solid var(--ug-line); padding-block: clamp(40px,6vw,80px); }
.ugc__head { margin-bottom: 24px; }
.ugc__title { font-family: var(--ug-font-display); font-size: var(--ug-step-3); text-transform: uppercase; }
.ugc__sub { color: var(--ug-muted); margin: 8px 0 16px; }
.ugc__cta { display: inline-flex; }
.ugc__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.ugc__item { aspect-ratio: 1/1; overflow: hidden; border-radius: var(--ug-radius); background: var(--ug-surface); display: block; }
.ugc__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ug-ease); }
.ugc__item:hover img { transform: scale(1.05); }
.ugc__item--empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; text-align: center; padding: 24px; background: var(--ug-surface); }
.ugc__empty-text { font-family: var(--ug-font-display); font-size: var(--ug-step-1); font-weight: 600; max-width: 16ch; }
.ugc__empty-plus { width: 52px; height: 52px; border-radius: 50%; background: var(--ug-ink); color: var(--ug-paper); display: inline-flex; align-items: center; justify-content: center; font-size: 28px; line-height: 1; }
@media (max-width: 600px) { .ugc__grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------------------------------------------------------- UGC upload modal */
.upload-modal { position: fixed; inset: 0; z-index: 600; display: flex; align-items: center; justify-content: center; padding: 20px; }
.upload-modal[hidden] { display: none; }
.upload-modal__overlay { position: absolute; inset: 0; background: rgba(10,10,10,.6); }
.upload-modal__dialog { position: relative; z-index: 1; width: min(560px, 100%); max-height: 90vh; overflow-y: auto; background: var(--ug-bg); border-radius: 22px; padding: clamp(24px, 4vw, 44px); box-shadow: var(--ug-shadow-lg); }
.upload-modal__close { position: absolute; top: 18px; right: 18px; width: 40px; height: 40px; border-radius: 50%; background: var(--ug-surface-2); font-size: 22px; line-height: 1; display: inline-flex; align-items: center; justify-content: center; color: var(--ug-fg); }
.upload-modal__close:hover { background: var(--ug-line); }
.upload-steps { display: flex; gap: clamp(12px, 4vw, 40px); border-bottom: 1px solid var(--ug-line); margin: 8px 0 28px; padding-bottom: 0; }
.upload-step { position: relative; padding: 0 0 14px; font-size: var(--ug-step--1); color: var(--ug-muted); font-weight: 500; }
.upload-step.is-active { color: var(--ug-fg); }
.upload-step.is-active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--ug-ink); }
.upload-step.is-done { color: var(--ug-fg); }
.upload-panel { display: none; }
.upload-panel.is-active { display: block; }
.upload-panel__title { font-family: var(--ug-font-display); font-size: var(--ug-step-2); margin-bottom: 22px; }
.upload-source { display: flex; align-items: center; justify-content: center; width: 100%; min-height: 64px; border: 1.5px solid var(--ug-line); border-radius: 999px; margin-bottom: 14px; font-weight: 600; cursor: pointer; background: var(--ug-bg); color: var(--ug-fg); transition: border-color var(--ug-dur) var(--ug-ease); text-decoration: none; }
.upload-source:hover { border-color: var(--ug-ink); }
.upload-drop { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; min-height: 340px; border-radius: var(--ug-radius); background: var(--ug-surface); cursor: pointer; text-align: center; padding: 24px; }
.upload-drop__plus { width: 64px; height: 64px; border-radius: 50%; background: var(--ug-ink); color: var(--ug-paper); display: inline-flex; align-items: center; justify-content: center; font-size: 32px; line-height: 1; }
.upload-drop__title { font-family: var(--ug-font-display); font-weight: 600; font-size: var(--ug-step-1); }
.upload-drop__hint { color: var(--ug-muted); font-size: var(--ug-step--1); }
.upload-review { display: flex; align-items: flex-start; gap: 16px; border: 1px solid var(--ug-line); border-radius: var(--ug-radius); padding: 16px; margin-bottom: 24px; }
.upload-review__thumb { width: 90px; height: 90px; flex: none; border-radius: 8px; overflow: hidden; background: var(--ug-surface); }
.upload-review__thumb img { width: 100%; height: 100%; object-fit: cover; }
.upload-review__field { flex: 1; }
.upload-review__field label { display: block; color: var(--ug-muted); font-size: var(--ug-step--1); margin-bottom: 6px; }
.upload-review__field textarea { width: 100%; border: 1px solid var(--ug-line); border-radius: 8px; padding: 8px 10px; font: inherit; resize: vertical; }
.upload-review__remove { width: 32px; height: 32px; flex: none; color: var(--ug-muted); }
.upload-review__remove:hover { color: var(--ug-sale); }
.upload-review__remove .ug-icon { width: 18px; height: 18px; }
.upload-field { margin-bottom: 18px; }
.upload-field label { display: block; font-weight: 600; font-size: var(--ug-step--1); margin-bottom: 6px; }
.upload-field input { width: 100%; border: 1.5px solid var(--ug-line); border-radius: var(--ug-radius); padding: 13px 15px; font: inherit; }
.upload-field input:focus { outline: none; border-color: var(--ug-accent); }
.upload-consent { display: flex; gap: 10px; align-items: flex-start; font-size: var(--ug-step--1); color: var(--ug-gray-600); line-height: 1.5; margin: 6px 0 22px; }
.upload-consent input { margin-top: 3px; width: 18px; height: 18px; flex: none; accent-color: var(--ug-ink); }
.upload-hp { position: absolute; left: -9999px; }
.btn--block { width: 100%; }
.upload-result { margin-top: 14px; padding: 12px 14px; border-radius: var(--ug-radius); font-size: var(--ug-step--1); }
.upload-result.is-ok { background: rgba(31,111,67,.1); color: var(--ug-accent); }
.upload-result.is-err { background: rgba(180,35,24,.08); color: var(--ug-sale); }

/* ---------------------------------------------------------- Payment QR (thank-you page) */
.ug-pay-qr { max-width: 520px; margin: clamp(24px,4vw,40px) auto; padding: clamp(20px,3vw,32px); border: 1px solid var(--ug-line); border-radius: var(--ug-radius); text-align: center; }
.ug-pay-qr__title { font-family: var(--ug-font-display); font-size: var(--ug-step-2); text-transform: uppercase; margin-bottom: 18px; }
.ug-pay-qr__code { display: inline-block; padding: 12px; background: #fff; border: 1px solid var(--ug-line); border-radius: var(--ug-radius); }
.ug-pay-qr__img { width: 240px; height: 240px; object-fit: contain; display: block; }
.ug-pay-qr__note { margin-top: 16px; color: var(--ug-muted); font-size: var(--ug-step-0); max-width: 42ch; margin-inline: auto; }
