/**
 * OpenLabs brand styling for WooCommerce-generated surfaces (cart page,
 * checkout, My Account, notices, buttons, form fields). app.css styles the
 * bespoke storefront; this file brands the standard WC markup that app.css
 * does not cover. Enqueued after app.css, so all --tokens resolve.
 */

/* ----------------------------- Buttons ----------------------------- */
.woocommerce .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.wc-block-components-button,
.wp-element-button,
#place_order,
.checkout-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: 'Inter', system-ui, sans-serif;
	font-weight: 600;
	font-size: 0.95rem;
	line-height: 1;
	padding: 0.85rem 1.5rem;
	border: 0;
	border-radius: 999px;
	color: #fff;
	background: var(--grad);
	box-shadow: var(--shadow-violet);
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
	text-decoration: none;
}
.woocommerce .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
#place_order:hover,
.checkout-button:hover {
	transform: translateY(-1px);
	box-shadow: 0 16px 36px -12px var(--violet-glow);
	color: #fff;
}
.woocommerce .button:disabled,
.woocommerce button.button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
}
/* Secondary / outline buttons (e.g. "Update cart", "Apply coupon") */
.woocommerce button.button[name='update_cart'],
.woocommerce .button.alt--outline,
.woocommerce-cart .coupon .button {
	background: #fff;
	color: var(--violet-600);
	border: 1.5px solid var(--line-2);
	box-shadow: none;
}
.woocommerce button.button[name='update_cart']:hover,
.woocommerce-cart .coupon .button:hover {
	border-color: var(--violet-300);
	color: var(--violet-600);
}

/* ----------------------------- Notices ----------------------------- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
.wc-block-components-notice-banner {
	border-radius: var(--radius);
	border: 1px solid var(--line);
	background: var(--mist);
	color: var(--ink-2);
	padding: 1rem 1.2rem;
	box-shadow: var(--shadow-sm);
	border-left: 4px solid var(--violet);
	list-style: none;
}
.woocommerce-error {
	border-left-color: #d23b6f;
}
.woocommerce-message .button,
.woocommerce-info .button {
	box-shadow: none;
}

/* --------------------------- Form fields --------------------------- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce table.cart td.actions .coupon .input-text,
.select2-container--default .select2-selection--single,
.woocommerce #order_comments {
	width: 100%;
	font-family: 'Inter', system-ui, sans-serif;
	font-size: 0.98rem;
	color: var(--text);
	background: #fff;
	border: 1.5px solid var(--line-2);
	border-radius: var(--radius-sm);
	padding: 0.7rem 0.9rem;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus,
.woocommerce #order_comments:focus {
	outline: none;
	border-color: var(--violet-300);
	box-shadow: 0 0 0 3px var(--violet-100);
}
.woocommerce form .form-row {
	display: block;
	margin: 0 0 1.1rem;
}
.woocommerce form .form-row label {
	display: block;
	font-weight: 500;
	color: var(--ink-2);
	margin-bottom: 0.35rem;
}
.woocommerce form .form-row-first,
.woocommerce form .form-row-last {
	width: 48%;
	display: inline-block;
	vertical-align: top;
}
.woocommerce form .form-row-first { margin-right: 3%; }
.woocommerce .col2-set { display: block; }
.woocommerce .col2-set .col-1,
.woocommerce .col2-set .col-2 { width: 100%; }
.woocommerce-checkout .checkbox,
.woocommerce form .form-row.openlabs-ruo-consent label {
	display: inline;
}

/* ----------------------------- Tables ------------------------------ */
.woocommerce table.shop_table {
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
	background: #fff;
	box-shadow: var(--shadow-sm);
}
.woocommerce table.shop_table th {
	font-family: 'Inter', sans-serif;
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--muted);
	padding: 1rem 1.1rem;
	border-bottom: 1px solid var(--line);
}
.woocommerce table.shop_table td {
	padding: 1rem 1.1rem;
	border-top: 1px solid var(--line);
	color: var(--ink-2);
	vertical-align: middle;
}
.woocommerce table.shop_table .product-thumbnail img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: var(--radius-sm);
	border: 1px solid var(--line);
}
/* The cart/checkout "remove" control is styled as a clean icon-only "X" in
   wc-cart.css (no circle/box). Intentionally not branded here so that file owns
   it without an !important fight. */
.woocommerce .amount,
.woocommerce .price,
.woocommerce .order-total .amount {
	font-family: ui-monospace, 'SFMono-Regular', Menlo, Consolas, monospace;
	color: var(--violet-600);
	font-weight: 700;
}
.woocommerce table.shop_table td.product-name a {
	color: var(--ink);
	font-weight: 600;
	text-decoration: none;
}

/* --------------------------- Cart layout --------------------------- */
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review,
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	background: #fff;
}
.woocommerce-cart .cart_totals h2,
.woocommerce-checkout #order_review_heading,
.woocommerce-column__title,
.woocommerce-billing-fields h3,
.woocommerce-additional-fields h3 {
	font-family: 'Inter', sans-serif;
	font-size: 1.3rem;
	color: var(--ink);
	margin-bottom: 1rem;
}
.woocommerce .quantity .qty {
	width: 4.5rem;
	text-align: center;
	border: 1.5px solid var(--line-2);
	border-radius: var(--radius-sm);
	padding: 0.55rem 0.4rem;
	font-family: ui-monospace, Menlo, monospace;
}
.woocommerce-cart table.cart td.actions .coupon {
	display: flex;
	gap: 0.6rem;
	align-items: center;
}

/* ----------------------------- Checkout ---------------------------- */
.woocommerce-checkout #payment {
	background: var(--mist);
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	padding: 0.5rem 1.2rem;
}
.woocommerce-checkout #payment ul.payment_methods {
	border-bottom: 1px solid var(--line);
}
.woocommerce-checkout #payment div.payment_box {
	background: #fff;
	border-radius: var(--radius);
	color: var(--muted);
}
.woocommerce-checkout #payment div.payment_box::before {
	border-bottom-color: #fff;
}

/* RUO research-use acknowledgement at checkout */
.openlabs-ruo-consent {
	display: flex;
	gap: 0.7rem;
	align-items: flex-start;
	margin: 1rem 0 1.2rem;
	padding: 1rem 1.1rem;
	background: var(--violet-100);
	border: 1px solid var(--violet-300);
	border-radius: var(--radius);
	color: var(--ink-2);
	font-size: 0.92rem;
	line-height: 1.5;
}
.openlabs-ruo-consent input[type='checkbox'] {
	margin-top: 0.2rem;
	width: 1.1rem;
	height: 1.1rem;
	accent-color: var(--violet);
	flex: 0 0 auto;
}

/* --------------------------- My Account ---------------------------- */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.3rem;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 0.7rem 0.95rem;
	border-radius: var(--radius-sm);
	color: var(--ink-2);
	text-decoration: none;
	font-weight: 500;
	transition: background 0.15s ease, color 0.15s ease;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	background: var(--violet-100);
	color: var(--violet-600);
}

/* ----------------------- Breadcrumb / misc ------------------------- */
.woocommerce .woocommerce-breadcrumb {
	color: var(--muted);
	font-size: 0.85rem;
	margin-bottom: 1.5rem;
}
.woocommerce .woocommerce-breadcrumb a {
	color: var(--violet-600);
	text-decoration: none;
}
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
	color: var(--muted);
	font-size: 0.9rem;
}
