/* ==========================================================================
   WooCommerce Blocks
   Cart Block, Checkout Block, and related block component overrides.
   ========================================================================== */

/* ── 1. Block Theme Tokens ──────────────────────────────────────────────── */

:root {
	--wc-block-style-active-color: var(--color-primary);
}

/* ── 2. Checkbox & Radio Accent ─────────────────────────────────────────── */

.wc-block-components-checkbox input[type="checkbox"],
.wc-block-components-radio-control input[type="radio"],
.woocommerce-page input[type="checkbox"],
.woocommerce-page input[type="radio"] {
	accent-color: var(--color-primary);
}

/* ── 3. Text Inputs ──────────────────────────────────────────────────────── */

.wc-block-components-text-input input,
.wc-block-components-select select,
.wc-block-components-country-input input,
.wc-block-components-combobox input,
.wc-block-components-phone-input input {
	font-family: var(--font-body) !important;
	font-size: 0.9375rem !important;
	color: var(--color-text) !important;
	border-color: var(--color-border) !important;
	border-radius: var(--radius-input) !important;
}

.wc-block-components-text-input.is-active input,
.wc-block-components-text-input input:focus,
.wc-block-components-select select:focus,
.wc-block-components-country-input input:focus,
.wc-block-components-combobox input:focus {
	border-color: var(--color-primary) !important;
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent) !important;
	outline: none !important;
}

/* ── 4. Labels ───────────────────────────────────────────────────────────── */

.wc-block-components-form .wc-block-components-text-input label,
.wc-block-components-form .wc-block-components-select label {
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--color-heading);
	font-weight: 500;
}

/* ── 5. Block Cart Buttons ───────────────────────────────────────────────── */

.wc-block-cart__submit-button,
.wc-block-cart__submit-container .wc-block-cart__submit-button {
	background-color: var(--color-btn-bg) !important;
	color: var(--color-btn-text) !important;
	border-color: transparent !important;
	border-radius: var(--radius-button) !important;
	font-family: var(--font-body) !important;
	font-size: 0.9375rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
	transition: background-color var(--transition-fast) !important;
}

.wc-block-cart__submit-button:hover {
	background-color: var(--color-btn-hover-bg) !important;
	color: var(--color-btn-hover-text) !important;
}

/* ── 6. Block Checkout Place Order ──────────────────────────────────────── */

.wc-block-components-checkout-place-order-button,
.wp-block-woocommerce-checkout .wc-block-components-checkout-place-order-button {
	background-color: var(--color-btn-bg) !important;
	color: var(--color-btn-text) !important;
	border-color: transparent !important;
	border-radius: var(--radius-button) !important;
	font-family: var(--font-body) !important;
	font-size: 0.9375rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
}

.wc-block-components-checkout-place-order-button:hover {
	background-color: var(--color-btn-hover-bg) !important;
	color: var(--color-btn-hover-text) !important;
}

/* ── 7. Generic WP Element Buttons inside WC blocks ─────────────────────── */

.wp-block-woocommerce-cart .wp-element-button,
.wp-block-woocommerce-checkout .wp-element-button {
	background-color: var(--color-btn-bg);
	color: var(--color-btn-text);
	border-color: transparent;
	border-radius: var(--radius-button);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 700;
}

.wp-block-woocommerce-cart .wp-element-button:hover,
.wp-block-woocommerce-checkout .wp-element-button:hover {
	background-color: var(--color-btn-hover-bg);
	color: var(--color-btn-hover-text);
}

/* ── 8. Block Notices ────────────────────────────────────────────────────── */

.wc-block-components-notice-banner {
	display: flex;
	align-items: center;
	gap: 0.875rem;
	padding: 0.875rem 1.25rem;
	margin-block-end: 1.5rem;
	border-radius: var(--radius-base);
	border: 1px solid;
	font-size: 0.9375rem;
}

.wc-block-components-notice-banner.is-success {
	background: #f0fdf4;
	border-color: #bbf7d0;
	color: #15803d;
}

.wc-block-components-notice-banner.is-error {
	background: #fef2f2;
	border-color: #fecaca;
	color: #b91c1c;
}

.wc-block-components-notice-banner.is-info {
	background: #eff6ff;
	border-color: #bfdbfe;
	color: #1d4ed8;
}

/* ── 9. Coupon Block ────────────────────────────────────────────────────── */

.wc-block-components-totals-coupon__form .wc-block-components-button {
	background-color: var(--color-btn-bg) !important;
	color: var(--color-btn-text) !important;
	border-radius: var(--radius-button) !important;
	font-weight: 600 !important;
}

/* ── 10. Checkout Step Headings ──────────────────────────────────────────── */

.wc-block-checkout__step-heading {
	color: var(--color-heading);
	font-family: var(--font-heading);
	font-weight: 700;
	line-height: var(--font-line-height-heading);
}

/* ── 11. Block Checkout ─────────────────────────────────────────────────── */

.woocommerce-checkout .wp-block-woocommerce-checkout {
	padding-block-start: 0;
}

.woocommerce-checkout .wc-block-components-sidebar-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 390px);
	align-items: flex-start;
	gap: 2rem;
	margin-block-end: 0;
}

.woocommerce-checkout .wc-block-checkout__main {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-xs);
	padding: 1.5rem;
	inline-size: auto;
}

.woocommerce-checkout .wc-block-checkout__sidebar {
	padding-inline-start: 0;
	position: static;
	inset-block-start: auto;
	width: auto; /* intentionally physical — layout container width */
}

.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block {
	background: var(--color-bg-secondary);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-sm);
	overflow: hidden;
}

.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-checkout-order-summary__title {
	background: var(--color-bg);
	border-block-end: 1px solid var(--color-border);
	margin: 0;
	padding: 1rem 1.125rem;
}
.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-checkout-order-summary__title .wc-block-components-checkout-order-summary__title-text {
	margin: unset;
}

.woocommerce-checkout .wc-block-components-order-summary {
	padding: 0;
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item {
	gap: 0.875rem;
	padding: 1rem 1.125rem;
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item + .wc-block-components-order-summary-item {
	border-block-start: 1px solid var(--color-border);
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item__description {
	gap: 0.25rem;
	padding: 0;
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-product-name {
	border-block-end: 0;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 650;
	line-height: 1.35;
	margin: 0;
	max-inline-size: none;
	padding: 0;
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item__total-price {
	font-weight: 700;
	padding-block-start: 0;
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-product-metadata,
.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-product-price {
	color: var(--color-text-muted);
	font-size: 0.8125rem;
}

.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item__image img {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-base);
}

.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-totals-wrapper {
	border-block-start-color: var(--color-border);
}

.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-totals-block .wc-block-components-totals-wrapper {
	padding-block-end: 0;
}

.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block :has(.wc-block-components-totals-footer-item) {
	padding: unset;
}

.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-totals-footer-item {
	background: var(--color-bg);
	padding: 1rem 1.125rem;
	border-radius: 0 0 var(--radius-card) var(--radius-card);
}

/* ── 12. Block Checkout — Split layout support ───────────────────────────── */

.stw-checkout-split .wp-block-woocommerce-checkout {
	display: grid;
	grid-template-columns: 1fr 400px;
	gap: 3rem;
	align-items: start;
}

.stw-checkout-split .wc-block-checkout__main {
	grid-column: 1;
}

.stw-checkout-split .wc-block-checkout__sidebar {
	grid-column: 2;
	position: static;
	inset-block-start: auto;
}

.stw-checkout-sticky-form .wc-block-checkout__main,
.stw-checkout-sticky-summary .wc-block-checkout__sidebar {
	position: sticky;
	inset-block-start: calc(var(--header-height, 70px) + 1rem);
	align-self: start;
}

@media (max-width: 768px) {
	.woocommerce-checkout .wc-block-components-sidebar-layout,
	.stw-checkout-split .wp-block-woocommerce-checkout {
		display: grid;
		grid-template-columns: 1fr;
	}

	.woocommerce-checkout .wc-block-checkout__main,
	.woocommerce-checkout .wc-block-checkout__sidebar {
		inline-size: auto;
	}

	.woocommerce-checkout .wc-block-checkout__main {
		padding: 1rem;
	}

	.woocommerce-checkout .wc-block-checkout__sidebar,
	.stw-checkout-sticky-form .wc-block-checkout__main,
	.stw-checkout-sticky-summary .wc-block-checkout__sidebar,
	.stw-checkout-split .wc-block-checkout__sidebar {
		position: static;
		inset-block-start: auto;
	}
}

/* ── 13. Checkout Page Redesign ─────────────────────────────────────────── */

.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout {
	padding: 0;
	margin: 0;
	inline-size: 100%;
	max-inline-size: none;
	background: transparent;
	border: 0;
	box-shadow: none;
	container-type: inline-size;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-sidebar-layout,
.woocommerce-checkout.stw-checkout-split .stcheckout-page .wp-block-woocommerce-checkout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 390px);
	align-items: start;
	gap: clamp(20px, 3vw, 34px);
	margin: 0;
	padding: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__main {
	display: grid;
	gap: 14px;
	padding: 0;
	inline-size: auto;
	background: transparent;
	border: 0;
	box-shadow: none;
	overflow: visible;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__form {
	display: grid;
	gap: 12px;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar {
	padding-inline-start: 0;
	inline-size: auto;
	position: static;
	inset-block-start: auto;
}

.woocommerce-checkout.stw-checkout-sticky-form .stcheckout-page .wc-block-checkout__main,
.woocommerce-checkout.stw-checkout-sticky-summary .stcheckout-page .wc-block-checkout__sidebar {
	position: sticky;
	inset-block-start: calc(var(--header-height, 70px) + 1rem);
	align-self: start;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step {
	position: relative;
	margin: 0;
	padding: clamp(14px, 1.9vw, 20px);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	background: linear-gradient(180deg, var(--color-bg), color-mix(in srgb, var(--color-bg-secondary) 58%, var(--color-bg)));
	box-shadow: var(--shadow-sm);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
	overflow: visible;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step.wc-block-checkout__shipping-fields {
	z-index: 1;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step:focus-within,
.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step:hover {
	border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
	box-shadow: var(--shadow-md);
	transform: translateY(-1px);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__heading-container {
	margin-block-end: 12px;
	padding-block-end: 10px;
	border-block-end: 1px solid var(--color-border);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__terms {
	margin-block-end: 10px;
	padding-block-start: 10px;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__actions {
	margin-block-end: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__heading {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__title {
	margin: 0;
	font-family: var(--font-heading);
	font-size: clamp(1.2rem, 1.8vw, 1.55rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--color-heading);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__heading-content,
.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__description,
.woocommerce-checkout .stcheckout-page .wc-block-components-formatted-money-amount,
.woocommerce-checkout .stcheckout-page .wc-block-components-text-input p,
.woocommerce-checkout .stcheckout-page .wc-block-components-checkbox__label,
.woocommerce-checkout .stcheckout-page .wc-block-components-address-form__address_2-toggle {
	color: var(--color-text-muted);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-text-input input,
.woocommerce-checkout .stcheckout-page .wc-block-components-select select,
.woocommerce-checkout .stcheckout-page .wc-block-components-country-input input,
.woocommerce-checkout .stcheckout-page .wc-block-components-combobox input,
.woocommerce-checkout .stcheckout-page .wc-block-components-phone-input input {
	min-block-size: 52px;
	padding-block: 14px;
	padding-inline: 14px;
	background: var(--color-bg);
	border: 1.5px solid var(--color-border) !important;
	border-radius: var(--radius-input) !important;
	box-shadow: none !important;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast) !important;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-text-input.is-active input,
.woocommerce-checkout .stcheckout-page .wc-block-components-text-input input:focus,
.woocommerce-checkout .stcheckout-page .wc-block-components-select select:focus,
.woocommerce-checkout .stcheckout-page .wc-block-components-country-input input:focus,
.woocommerce-checkout .stcheckout-page .wc-block-components-combobox input:focus,
.woocommerce-checkout .stcheckout-page .wc-block-components-phone-input input:focus {
	background: var(--color-bg);
	border-color: var(--color-primary) !important;
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 16%, transparent) !important;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-validation-error,
.woocommerce-checkout .stcheckout-page .wc-block-components-text-input.has-error label,
.woocommerce-checkout .stcheckout-page .wc-block-components-text-input.has-error .wc-block-components-text-input__label {
	color: #cc1818 !important;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-text-input.has-error input,
.woocommerce-checkout .stcheckout-page .wc-block-components-text-input input[aria-invalid="true"],
.woocommerce-checkout .stcheckout-page .wc-block-components-select.has-error select,
.woocommerce-checkout .stcheckout-page .wc-block-components-select select[aria-invalid="true"] {
	border-color: #cc1818 !important;
	box-shadow: 0 0 0 3px color-mix(in srgb, #cc1818 18%, transparent) !important;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-text-input label,
.woocommerce-checkout .stcheckout-page .wc-block-components-select label,
.woocommerce-checkout .stcheckout-page .wc-block-components-checkbox label,
.woocommerce-checkout .stcheckout-page .wc-block-components-radio-control label {
	font-family: var(--font-body);
	font-weight: 500;
	color: var(--color-heading);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-address-form {
	gap: 14px;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-address-form__address_2-hidden-input {
	left: auto !important;
	right: auto !important;
	inline-size: 1px !important;
	block-size: 1px !important;
	margin: -1px !important;
	padding: 0 !important;
	border: 0 !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	clip-path: inset(50%) !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-place-order-button,
.woocommerce-checkout .stcheckout-page .wp-element-button.wc-block-components-checkout-place-order-button {
	min-block-size: 58px;
	border-radius: var(--radius-button) !important;
	box-shadow: var(--shadow-md);
	font-size: 1rem !important;
	font-weight: 700 !important;
	transition: transform var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast) !important;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-place-order-button:hover {
	transform: translateY(-1px);
	box-shadow: var(--shadow-lg);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-return-to-cart-button,
.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-return-to-cart-button a {
	color: var(--color-heading);
	font-weight: 500;
	text-decoration: none;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-sidebar,
.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout-order-summary-block,
.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout-order-summary-totals-block {
	background: transparent;
}

.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout-order-summary-block {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	background: var(--color-bg);
	box-shadow: var(--shadow-sm);
	overflow: hidden;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-order-summary__title {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto auto;
	align-items: center;
	gap: 10px;
	margin: 0;
	padding-block: 16px;
	padding-inline: 18px;
	border-block-end: 1px solid var(--color-border);
	background: linear-gradient(180deg, var(--color-bg), var(--color-bg-secondary));
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-order-summary__title-text {
	font-family: var(--font-heading);
	font-size: 1.45rem;
	font-weight: 700;
	color: var(--color-heading);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-order-summary__title-price {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-primary);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary {
	padding: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr) auto;
	gap: 12px;
	align-items: center;
	padding-block: 16px;
	padding-inline: 18px;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item + .wc-block-components-order-summary-item {
	border-block-start: 1px solid var(--color-border);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item__image img {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-corner);
	box-shadow: var(--shadow-xs);
	background: var(--color-bg-secondary);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item__description {
	gap: 4px;
	padding: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-product-name {
	font-family: var(--font-heading);
	font-size: 0.98rem;
	font-weight: 700;
	color: var(--color-heading);
	line-height: 1.3;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-product-metadata,
.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-product-price,
.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item__quantity {
	font-size: 0.82rem;
	color: var(--color-text-muted);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item__total-price {
	font-size: 0.98rem;
	font-weight: 700;
	color: var(--color-primary);
	padding: 0;
}

.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout-order-summary-cart-items-block,
.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout-order-summary-coupon-form-block,
.woocommerce-checkout .stcheckout-page .wp-block-woocommerce-checkout-order-summary-totals-block {
	margin: 0;
	border-block-start: 1px solid var(--color-border);
	background: var(--color-bg);
	padding: unset;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-wrapper {
	padding: 0;
	border: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-item,
.woocommerce-checkout .stcheckout-page .wc-block-components-totals-footer-item {
	padding-block: 14px;
	padding-inline: 18px;
	margin: 0;
	font-size: 0.95rem;
	border-block-start: 1px solid var(--color-border);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-item__label,
.woocommerce-checkout .stcheckout-page .wc-block-components-totals-item__value {
	font-weight: 500;
	color: var(--color-heading);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-footer-item {
	background: linear-gradient(180deg, var(--color-bg), var(--color-bg-secondary));
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.woocommerce-checkout .stcheckout-page .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	font-family: var(--font-heading);
	font-size: 1.16rem;
	font-weight: 700;
	color: var(--color-heading);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-footer-item .wc-block-formatted-money-amount {
	color: var(--color-primary);
}

.woocommerce-checkout .stcheckout-page .wc-block-components-totals-coupon {
	padding-block: 14px;
	padding-inline: 18px;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-footer {
	margin-block-start: 12px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	background: var(--color-bg);
	box-shadow: var(--shadow-sm);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options {
	padding: 0;
	background: transparent;
	border: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options > .wp-block-woocommerce-checkout-shipping-methods-block,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options > .wp-block-woocommerce-checkout-payment-block {
	margin: 0;
	padding-block: 14px;
	padding-inline: 18px;
	background: transparent;
	border: 0;
	box-shadow: none;
	border-block-end: 1px solid var(--color-border);
	border-radius: unset;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options > .wp-block-woocommerce-checkout-payment-block {
	border-block-end: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkout-step__heading-container {
	margin-block-end: 10px;
	padding-block-end: 10px;
	border-block-end: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-title,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkout-step__title {
	font-family: var(--font-body);
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--color-heading);
	margin: 0;
	text-transform: none;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-radio-control,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkbox {
	padding-block: 10px;
	padding-inline: 12px;
	margin: 0;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-input);
	background: transparent;
	transition: background var(--transition-fast), border-color var(--transition-fast);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-radio-control:hover,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkbox:hover {
	background: var(--color-bg);
	border-color: var(--color-primary);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-radio-control + .wc-block-components-radio-control,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkbox + .wc-block-components-checkbox {
	margin-block-start: 8px;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-radio-control input,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkbox input {
	accent-color: var(--color-primary);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-radio-control input:checked + label,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkbox input:checked + label {
	color: var(--color-primary);
	font-weight: 600;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-radio-control__option-layout,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-components-checkbox__label {
	font-size: 0.9rem;
	color: var(--color-heading);
	font-weight: 500;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options .wc-block-checkout__no-payment-methods-notice {
	margin: 0;
	border-radius: var(--radius-input);
	font-size: 0.85rem;
	padding-block: 10px;
	padding-inline: 12px;
	background: rgba(239, 68, 68, 0.06);
	border: 1px solid rgba(239, 68, 68, 0.2);
	color: #cc1818;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon {
	background: transparent;
	padding: 14px 18px;
	border-block-end: 1px solid var(--color-border);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wp-block-woocommerce-checkout-order-summary-coupon-form-block {
	margin: 0;
	border: 0;
	background: transparent;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon {
	padding: unset;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-panel__button {
	display: block;
	align-content: center;
	min-block-size: 44px;
	padding: 0;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--color-heading);
	text-transform: none;
	margin-block-end: unset;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-panel__button:hover {
	color: var(--color-primary);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-panel__button-icon {
	margin-inline-end: 6px;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: start;
	gap: 10px;
	margin-block-start: 10px;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__form .wc-block-components-text-input {
	margin: 0;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-text-input input,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__input,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__form input[type="text"] {
	inline-size: 100%;
	min-block-size: 50px;
	/* padding-block: 12px;
	padding-inline: 14px; */
	border-radius: var(--radius-input) !important;
	background: var(--color-bg) !important;
	box-sizing: border-box;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-text-input label {
	inset-inline-start: 14px;
	padding-inline: 4px;
	background: var(--color-bg);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__button {
	min-block-size: 50px;
	block-size: 50px;
	padding-inline: 16px;
	border-radius: var(--radius-button) !important;
	font-weight: 700;
	align-self: start;
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__button:disabled,
.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__button[aria-disabled="true"] {
	opacity: .6;
	filter: saturate(.8);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-place-order {
	padding-block: 16px 18px;
	padding-inline: 18px;
	border-block-start: 1px solid var(--color-border);
	background: linear-gradient(180deg, var(--color-bg-secondary) 0%, var(--color-bg) 100%);
	border-radius: 0 0 var(--radius-card) var(--radius-card);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-place-order .wc-block-components-checkout-place-order-button {
	inline-size: 100%;
	margin: 0;
	min-block-size: 52px;
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-place-order .wc-block-components-checkout-place-order-button:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.woocommerce-checkout .stcheckout-page .wc-block-checkout__actions:has(.wc-block-components-checkout-place-order-button) {
	display: grid;
	gap: 10px;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__content .wc-block-components-notices,
.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step__content .wc-block-components-notice-banner {
	margin-block-end: 12px;
}

.woocommerce-checkout .stcheckout-page .wc-block-components-validation-error,
.woocommerce-checkout .stcheckout-page .wc-block-components-validation-error * {
	color: #cc1818 !important;
}

@container (max-width: 960px) {
	.woocommerce-checkout .stcheckout-page .wc-block-components-sidebar-layout,
	.woocommerce-checkout.stw-checkout-split .stcheckout-page .wp-block-woocommerce-checkout {
		grid-template-columns: 1fr;
	}

	.woocommerce-checkout .stcheckout-page .wc-block-checkout__main,
	.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar {
		position: static;
		inset-block-start: auto;
	}
}

@media (max-width: 680px) {
	.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-step {
		padding: 14px;
	}

	.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item {
		grid-template-columns: 56px minmax(0, 1fr);
	}

	.woocommerce-checkout .stcheckout-page .wc-block-components-order-summary .wc-block-components-order-summary-item__total-price {
		grid-column: 2;
		justify-self: start;
	}

	.woocommerce-checkout .stcheckout-page .wc-block-components-checkout-order-summary__title {
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-coupon .wc-block-components-totals-coupon__form {
		grid-template-columns: 1fr;
	}

	.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options > .wp-block-woocommerce-checkout-shipping-methods-block,
	.woocommerce-checkout .stcheckout-page .wc-block-checkout__sidebar .stw-order-summary-options > .wp-block-woocommerce-checkout-payment-block {
		padding-inline: 14px;
	}
}
