/**
 * B2B Quote Suite public styles.
 *
 * @package RAQ_B2B_Suite
 */

/* ==========================================================================
   Base
   ========================================================================== */

.raq-b2b-quote-form *,
.raq-b2b-quote-button-wrap *,
.raq-b2b-quote-success *,
.raq-b2b-message *,
.raq-b2b-catalog-mode-notice *,
.raq-b2b-price-replacement,
.raq-b2b-price-replacement *,
.raq-b2b-modal,
.raq-b2b-modal *,
.raq-b2b-modal *::before,
.raq-b2b-modal *::after {
	box-sizing: border-box;
}

.raq-b2b-message,
.raq-b2b-quote-form-section,
.raq-b2b-quote-button-wrap,
.raq-b2b-quote-success,
.raq-b2b-catalog-mode-notice,
.raq-b2b-price-replacement,
.raq-b2b-modal {
	font-family: inherit;
}

/* ==========================================================================
   Messages
   ========================================================================== */

.raq-b2b-message {
	margin: 16px 0;
	padding: 12px 14px;
	border-radius: 10px;
	border: 1px solid transparent;
	font-size: 15px;
	line-height: 1.5;
}

.raq-b2b-message--success {
	background: #ecfdf5;
	border-color: #a7f3d0;
	color: #065f46;
}

.raq-b2b-message--error {
	background: #fef2f2;
	border-color: #fecaca;
	color: #991b1b;
}

.raq-b2b-message--info {
	background: #eff6ff;
	border-color: #bfdbfe;
	color: #1e40af;
}

.raq-b2b-inline-error {
	margin-top: 0;
	margin-bottom: 16px;
}

.raq-b2b-quote-form .raq-b2b-message {
	width: 100%;
}

/* ==========================================================================
   Quote Button
   ========================================================================== */

.raq-b2b-quote-button-wrap {
	margin: 12px 0;
	clear: both;
}

.raq-b2b-quote-button-wrap--context-loop,
.raq-b2b-quote-button--context-loop {
	width: 100%;
}

.raq-b2b-quote-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	padding: 10px 18px;
	border-radius: 10px;
	border: 1px solid transparent;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.2;
	text-decoration: none;
	cursor: pointer;
	transition:
		background-color 180ms ease,
		border-color 180ms ease,
		color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease;
}

.raq-b2b-quote-button:hover,
.raq-b2b-quote-button:focus {
	text-decoration: none;
}

.raq-b2b-quote-button:focus-visible {
	outline: 3px solid rgba(167, 243, 208, 0.85);
	outline-offset: 2px;
}

.raq-b2b-quote-button:active {
	transform: translateY(1px);
}

.raq-b2b-quote-button--primary {
	background: #0f766e;
	border-color: #0f766e;
	color: #ffffff;
	box-shadow: 0 8px 18px rgba(15, 118, 110, 0.18);
}

.raq-b2b-quote-button--primary:hover,
.raq-b2b-quote-button--primary:focus {
	background: #0b5f59;
	border-color: #0b5f59;
	color: #ffffff;
	box-shadow: 0 10px 22px rgba(15, 118, 110, 0.24);
}

.raq-b2b-quote-button--secondary {
	background: #ffffff;
	border-color: #0f766e;
	color: #0f766e;
}

.raq-b2b-quote-button--secondary:hover,
.raq-b2b-quote-button--secondary:focus {
	background: #eaf7f1;
	border-color: #0b5f59;
	color: #0b5f59;
}

.raq-b2b-quote-button--text {
	min-height: auto;
	padding: 0;
	background: transparent;
	border-color: transparent;
	color: #0f766e;
	border-radius: 0;
	box-shadow: none;
}

.raq-b2b-quote-button--text:hover,
.raq-b2b-quote-button--text:focus {
	background: transparent;
	color: #0b5f59;
	text-decoration: underline;
	box-shadow: none;
}

.raq-b2b-quote-button--loop,
.raq-b2b-quote-button--context-loop {
	width: 100%;
	margin-top: 8px;
}

.raq-b2b-quote-button--context-single_after_summary,
.raq-b2b-quote-button--context-single_after_add_to_cart,
.raq-b2b-quote-button--context-single_after_meta,
.raq-b2b-quote-button--context-single_before_tabs {
	margin-top: 4px;
}

/* ==========================================================================
   Modal
   ========================================================================== */

body.raq-b2b-modal-open {
	overflow: hidden;
}

.raq-b2b-modal {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition:
		opacity 180ms ease,
		visibility 180ms ease;
}

.raq-b2b-modal.is-open,
.raq-b2b-modal[aria-hidden="false"] {
	display: flex;
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.raq-b2b-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.58);
	backdrop-filter: blur(6px);
	cursor: pointer;
}

.raq-b2b-modal__dialog {
	position: relative;
	z-index: 1;
	width: min(920px, 100%);
	max-height: calc(100vh - 48px);
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	background: #ffffff;
	border: 1px solid rgba(220, 231, 226, 0.95);
	border-radius: 22px;
	box-shadow: 0 26px 70px rgba(15, 23, 42, 0.28);
	transform: translateY(8px) scale(0.985);
	transition:
		transform 220ms ease,
		opacity 220ms ease;
}

.raq-b2b-modal.is-open .raq-b2b-modal__dialog,
.raq-b2b-modal[aria-hidden="false"] .raq-b2b-modal__dialog {
	transform: translateY(0) scale(1);
}

.raq-b2b-modal__close {
	position: sticky;
	top: 14px;
	left: calc(100% - 50px);
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	margin: 14px 14px -52px auto;
	padding: 0;
	background: #ffffff;
	border: 1px solid #dce7e2;
	border-radius: 999px;
	color: #334155;
	font-size: 26px;
	font-weight: 400;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 8px 18px rgba(15, 23, 42, 0.10);
	transition:
		background-color 180ms ease,
		border-color 180ms ease,
		color 180ms ease,
		box-shadow 180ms ease;
}

.raq-b2b-modal__close:hover,
.raq-b2b-modal__close:focus {
	background: #eaf7f1;
	border-color: #a7f3d0;
	color: #0b5f59;
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.14);
}

.raq-b2b-modal__close:focus-visible {
	outline: 3px solid rgba(167, 243, 208, 0.85);
	outline-offset: 2px;
}

.raq-b2b-modal .raq-b2b-quote-form-section {
	margin: 0;
}

.raq-b2b-modal .raq-b2b-quote-form {
	max-width: none;
}

.raq-b2b-modal .raq-b2b-quote-form__inner {
	border: 0;
	border-radius: 22px;
	box-shadow: none;
	padding: 30px;
}

.raq-b2b-modal .raq-b2b-message {
	margin-top: 0;
}

/* ==========================================================================
   Quote Form
   ========================================================================== */

.raq-b2b-quote-form-section {
	margin: 24px 0;
}

.raq-b2b-quote-form-section:target {
	scroll-margin-top: 90px;
}

.raq-b2b-quote-form {
	width: 100%;
	max-width: 780px;
	margin: 0;
}

.raq-b2b-quote-form__inner {
	position: relative;
	padding: 24px;
	background:
		linear-gradient(180deg, rgba(234, 247, 241, 0.68) 0%, rgba(255, 255, 255, 0) 180px),
		#ffffff;
	border: 1px solid #dce7e2;
	border-radius: 18px;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

.raq-b2b-quote-form__header {
	margin: 0 0 18px;
	padding-right: 42px;
}

.raq-b2b-quote-form__title {
	margin: 0 0 8px;
	font-size: 25px;
	line-height: 1.25;
	font-weight: 800;
	color: #0f172a;
	letter-spacing: -0.02em;
}

.raq-b2b-quote-form__description {
	margin: 0;
	max-width: 680px;
	font-size: 15px;
	line-height: 1.65;
	color: #475569;
}

.raq-b2b-quote-form__product {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: stretch;
	justify-content: space-between;
	margin: 0 0 20px;
	padding: 14px;
	background: #f7faf9;
	border: 1px solid #dce7e2;
	border-radius: 14px;
	font-size: 14px;
	line-height: 1.45;
	color: #334155;
}

.raq-b2b-quote-form__product-main {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.raq-b2b-quote-form__product-label {
	display: block;
	color: #64748b;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.raq-b2b-quote-form__product strong {
	display: block;
	color: #0f172a;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.35;
	word-break: break-word;
}

.raq-b2b-quote-form__sku {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	align-self: center;
	padding: 8px 10px;
	background: #ffffff;
	border: 1px solid #dce7e2;
	border-radius: 999px;
	color: #64748b;
	font-size: 13px;
	line-height: 1.2;
}

.raq-b2b-quote-form__sku span {
	font-weight: 700;
}

.raq-b2b-quote-form__sku code {
	padding: 0;
	background: transparent;
	color: #0b5f59;
	font-size: 13px;
	font-weight: 800;
}

.raq-b2b-quote-form__body {
	margin: 0;
}

.raq-b2b-quote-form__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px 16px;
}

.raq-b2b-quote-form__field {
	margin: 0;
}

.raq-b2b-quote-form__field--full {
	margin-top: 14px;
}

.raq-b2b-quote-form label {
	display: block;
	margin: 0 0 6px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
	color: #0f172a;
}

.raq-b2b-quote-form .required {
	color: #ef4444;
}

.raq-b2b-quote-form input[type="text"],
.raq-b2b-quote-form input[type="email"],
.raq-b2b-quote-form input[type="url"],
.raq-b2b-quote-form input[type="tel"],
.raq-b2b-quote-form input[type="number"],
.raq-b2b-quote-form textarea,
.raq-b2b-quote-form select {
	display: block;
	width: 100%;
	min-height: 44px;
	padding: 10px 12px;
	background: #ffffff;
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	color: #0f172a;
	font: inherit;
	font-size: 15px;
	line-height: 1.45;
	box-shadow: 0 1px 0 rgba(15, 23, 42, 0.02);
	transition:
		border-color 160ms ease,
		box-shadow 160ms ease,
		background-color 160ms ease;
}

.raq-b2b-quote-form textarea {
	min-height: 118px;
	resize: vertical;
}

.raq-b2b-quote-form input:focus,
.raq-b2b-quote-form textarea:focus,
.raq-b2b-quote-form select:focus {
	border-color: #14b8a6;
	outline: none;
	box-shadow: 0 0 0 3px rgba(167, 243, 208, 0.75);
}

.raq-b2b-quote-form input::placeholder,
.raq-b2b-quote-form textarea::placeholder {
	color: #94a3b8;
}

.raq-b2b-quote-form input.raq-b2b-field-error,
.raq-b2b-quote-form textarea.raq-b2b-field-error,
.raq-b2b-quote-form select.raq-b2b-field-error {
	border-color: #ef4444;
	box-shadow: 0 0 0 3px rgba(254, 202, 202, 0.7);
}

.raq-b2b-quote-form__footer {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 16px;
	align-items: center;
	justify-content: space-between;
	margin: 18px 0 0;
}

.raq-b2b-quote-form__actions {
	margin: 18px 0 0;
}

.raq-b2b-quote-form__submit,
.raq-b2b-quote-form__submit.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 11px 22px;
	background: #0f766e;
	border: 1px solid #0f766e;
	border-radius: 10px;
	color: #ffffff;
	font: inherit;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.2;
	cursor: pointer;
	box-shadow: 0 8px 18px rgba(15, 118, 110, 0.18);
	text-decoration: none;
	transition:
		background-color 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease;
}

.raq-b2b-quote-form__submit:hover,
.raq-b2b-quote-form__submit:focus,
.raq-b2b-quote-form__submit.button:hover,
.raq-b2b-quote-form__submit.button:focus {
	background: #0b5f59;
	border-color: #0b5f59;
	color: #ffffff;
	box-shadow: 0 10px 22px rgba(15, 118, 110, 0.24);
}

.raq-b2b-quote-form__submit:focus-visible {
	outline: 3px solid rgba(167, 243, 208, 0.85);
	outline-offset: 2px;
}

.raq-b2b-quote-form__submit:active {
	transform: translateY(1px);
}

.raq-b2b-quote-form__submit[disabled],
.raq-b2b-quote-form.is-submitting .raq-b2b-quote-form__submit {
	opacity: 0.68;
	cursor: not-allowed;
	box-shadow: none;
}

.raq-b2b-quote-form__privacy-note {
	margin: 0;
	max-width: 360px;
	color: #64748b;
	font-size: 13px;
	line-height: 1.5;
}

/* ==========================================================================
   Quote Success
   ========================================================================== */

.raq-b2b-quote-success {
	margin: 24px 0;
}

.raq-b2b-quote-success__inner {
	max-width: 760px;
	padding: 22px;
	background: #ecfdf5;
	border: 1px solid #a7f3d0;
	border-radius: 14px;
	color: #065f46;
}

.raq-b2b-quote-success__title {
	margin: 0 0 8px;
	font-size: 22px;
	line-height: 1.3;
	font-weight: 700;
	color: #064e3b;
}

.raq-b2b-quote-success__message,
.raq-b2b-quote-success__reference,
.raq-b2b-quote-success__next {
	margin: 8px 0;
	font-size: 15px;
	line-height: 1.55;
}

.raq-b2b-quote-success__actions {
	margin: 16px 0 0;
}

.raq-b2b-quote-success__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 9px 16px;
	background: #0f766e;
	border: 1px solid #0f766e;
	border-radius: 8px;
	color: #ffffff;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	text-decoration: none;
}

.raq-b2b-quote-success__button:hover,
.raq-b2b-quote-success__button:focus {
	background: #0b5f59;
	border-color: #0b5f59;
	color: #ffffff;
	text-decoration: none;
}

/* ==========================================================================
   Catalog Mode
   ========================================================================== */

.raq-b2b-price-replacement {
	display: inline-flex;
	align-items: center;
	padding: 4px 9px;
	background: #eaf7f1;
	border: 1px solid #dce7e2;
	border-radius: 999px;
	color: #0b5f59;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.35;
}

.raq-b2b-catalog-mode-notice {
	margin: 12px 0;
	padding: 11px 13px;
	background: #eaf7f1;
	border: 1px solid #dce7e2;
	border-left: 4px solid #0f766e;
	border-radius: 8px;
	color: #334155;
	font-size: 14px;
	line-height: 1.5;
}

.raq-b2b-hide-add-to-cart .single_add_to_cart_button,
.raq-b2b-add-to-cart-hidden .single_add_to_cart_button,
.raq-b2b-hide-add-to-cart .add_to_cart_button,
.raq-b2b-add-to-cart-hidden .add_to_cart_button,
.raq-b2b-hide-add-to-cart form.cart button[name="add-to-cart"],
.raq-b2b-add-to-cart-hidden form.cart button[name="add-to-cart"] {
	display: none !important;
}

/*
 * Do not hide form.cart. WooCommerce variable products need it for
 * model/attribute selectors, variation_id, reset links, and quantity.
 */
.raq-b2b-hide-add-to-cart form.cart,
.raq-b2b-add-to-cart-hidden form.cart {
	display: block !important;
}

.raq-b2b-hide-prices .price,
.raq-b2b-prices-hidden .price {
	color: #0b5f59;
}

/* ==========================================================================
   WooCommerce alignment helpers
   ========================================================================== */

.woocommerce div.product .raq-b2b-quote-button-wrap {
	margin-top: 14px;
	margin-bottom: 14px;
}

.woocommerce div.product .summary .raq-b2b-quote-button-wrap {
	clear: both;
}

.woocommerce div.product .product_meta .raq-b2b-quote-button-wrap {
	margin-top: 12px;
}

.woocommerce ul.products li.product .raq-b2b-quote-button-wrap {
	margin-top: 10px;
	margin-bottom: 8px;
}

.woocommerce ul.products li.product .raq-b2b-quote-button {
	width: 100%;
	min-height: 40px;
	padding: 9px 14px;
	font-size: 14px;
}

.woocommerce div.product .raq-b2b-quote-form-section {
	margin-top: 28px;
}

.woocommerce div.product .raq-b2b-modal .raq-b2b-quote-form-section {
	margin-top: 0;
}

/* Elementor / block theme compatibility */
.elementor-widget-woocommerce-product-add-to-cart .raq-b2b-quote-button-wrap,
.wp-block-woocommerce-product-button .raq-b2b-quote-button-wrap {
	margin-top: 12px;
}

/* ==========================================================================
   Accessibility / Utilities
   ========================================================================== */

.raq-b2b-hp-field {
	position: absolute !important;
	left: -9999px !important;
	top: auto !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

.raq-b2b-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.raq-b2b-is-hidden {
	display: none !important;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 768px) {
	.raq-b2b-modal {
		padding: 12px;
		align-items: flex-end;
	}

	.raq-b2b-modal__dialog {
		width: 100%;
		max-height: calc(100vh - 24px);
		border-radius: 18px 18px 0 0;
	}

	.raq-b2b-modal .raq-b2b-quote-form__inner {
		padding: 22px 18px 18px;
		border-radius: 18px 18px 0 0;
	}

	.raq-b2b-modal__close {
		top: 10px;
		width: 36px;
		height: 36px;
		margin: 10px 10px -46px auto;
		font-size: 24px;
	}

	.raq-b2b-quote-form__inner,
	.raq-b2b-quote-success__inner {
		padding: 18px;
		border-radius: 14px;
	}

	.raq-b2b-quote-form__header {
		padding-right: 34px;
	}

	.raq-b2b-quote-form__grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.raq-b2b-quote-form__title,
	.raq-b2b-quote-success__title {
		font-size: 21px;
	}

	.raq-b2b-quote-button,
	.raq-b2b-quote-form__submit,
	.raq-b2b-quote-success__button {
		width: 100%;
	}

	.raq-b2b-quote-form__footer {
		display: block;
	}

	.raq-b2b-quote-form__privacy-note {
		margin-top: 10px;
		max-width: none;
		text-align: center;
	}
}

@media (max-width: 480px) {
	.raq-b2b-message,
	.raq-b2b-quote-form-section,
	.raq-b2b-quote-success {
		margin: 18px 0;
	}

	.raq-b2b-modal .raq-b2b-message {
		margin: 0 0 14px;
	}

	.raq-b2b-quote-form__inner,
	.raq-b2b-quote-success__inner {
		padding: 16px;
	}

	.raq-b2b-modal .raq-b2b-quote-form__inner {
		padding: 20px 16px 16px;
	}

	.raq-b2b-quote-form__product {
		display: grid;
		gap: 10px;
	}

	.raq-b2b-quote-form__sku {
		width: 100%;
		justify-content: space-between;
		border-radius: 10px;
	}

	.raq-b2b-quote-form__product span,
	.raq-b2b-quote-form__product strong {
		margin: 2px 0;
	}

	.raq-b2b-quote-form__title {
		font-size: 20px;
	}
}

/* ==========================================================================
   Reduced motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.raq-b2b-quote-button,
	.raq-b2b-quote-form__submit,
	.raq-b2b-quote-success__button,
	.raq-b2b-quote-form input,
	.raq-b2b-quote-form textarea,
	.raq-b2b-quote-form select,
	.raq-b2b-modal,
	.raq-b2b-modal__dialog,
	.raq-b2b-modal__close {
		transition: none;
	}

	.raq-b2b-quote-button:active,
	.raq-b2b-quote-form__submit:active {
		transform: none;
	}
}
/* ==========================================================================
   Quote Cart v2.0
   ========================================================================== */

.raq-b2b-quote-cart,
.raq-b2b-quote-cart *,
.raq-b2b-quote-cart *::before,
.raq-b2b-quote-cart *::after,
.raq-b2b-quote-button__message,
.raq-b2b-quote-button__message *,
.raq-b2b-quote-cart-count,
.raq-b2b-quote-cart-count * {
	box-sizing: border-box;
}

.raq-b2b-quote-cart {
	width: 100%;
	max-width: 980px;
	margin: 28px auto;
	font-family: inherit;
	color: #0f172a;
}

.raq-b2b-quote-cart__header {
	display: flex;
	flex-wrap: wrap;
	gap: 14px 20px;
	align-items: flex-end;
	justify-content: space-between;
	margin: 0 0 18px;
	padding: 0 0 14px;
	border-bottom: 1px solid #dce7e2;
}

.raq-b2b-quote-cart__title {
	margin: 0;
	font-size: 28px;
	line-height: 1.22;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: #0f172a;
}

.raq-b2b-quote-cart__header-summary {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	align-items: center;
	color: #64748b;
	font-size: 14px;
	line-height: 1.4;
}

.raq-b2b-quote-cart__summary-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 7px 10px;
	background: #f7faf9;
	border: 1px solid #dce7e2;
	border-radius: 999px;
}

.raq-b2b-quote-cart__summary-label {
	color: #64748b;
	font-weight: 600;
}

.raq-b2b-quote-cart__item-count,
.raq-b2b-quote-cart__quantity-count {
	color: #0b5f59;
	font-variant-numeric: tabular-nums;
}

.raq-b2b-quote-cart__notice {
	margin: 0 0 16px;
}

.raq-b2b-quote-cart__empty {
	padding: 28px;
	background:
		linear-gradient(180deg, rgba(234, 247, 241, 0.82) 0%, rgba(255, 255, 255, 0) 180px),
		#ffffff;
	border: 1px solid #dce7e2;
	border-radius: 18px;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	text-align: center;
}

.raq-b2b-quote-cart__empty-text {
	margin: 0 0 16px;
	color: #475569;
	font-size: 16px;
	line-height: 1.6;
}

.raq-b2b-quote-cart__form {
	margin: 0;
}

.raq-b2b-quote-cart__items {
	display: grid;
	gap: 14px;
	margin: 0;
}

.raq-b2b-quote-cart__item {
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr) 180px;
	gap: 16px;
	align-items: center;
	padding: 16px;
	background: #ffffff;
	border: 1px solid #dce7e2;
	border-radius: 18px;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
	transition:
		border-color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease;
}

.raq-b2b-quote-cart__item:hover {
	border-color: #a7f3d0;
	box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.raq-b2b-quote-cart__item.is-loading {
	opacity: 0.72;
	pointer-events: none;
}

.raq-b2b-quote-cart__item--missing {
	background: #fff7ed;
	border-color: #fed7aa;
}

.raq-b2b-quote-cart__item-media {
	width: 88px;
	height: 88px;
	min-width: 88px;
}

.raq-b2b-quote-cart__image-link,
.raq-b2b-quote-cart__image {
	display: block;
	width: 88px;
	height: 88px;
}

.raq-b2b-quote-cart__image {
	object-fit: cover;
	background: #f7faf9;
	border: 1px solid #dce7e2;
	border-radius: 14px;
}

.raq-b2b-quote-cart__image-placeholder {
	width: 88px;
	height: 88px;
	background:
		linear-gradient(135deg, rgba(234, 247, 241, 0.9), rgba(247, 250, 249, 0.95));
	border: 1px solid #dce7e2;
	border-radius: 14px;
}

.raq-b2b-quote-cart__item-main {
	min-width: 0;
}

.raq-b2b-quote-cart__item-title {
	margin: 0 0 8px;
	font-size: 17px;
	line-height: 1.35;
	font-weight: 800;
	color: #0f172a;
}

.raq-b2b-quote-cart__item-title a {
	color: #0f172a;
	text-decoration: none;
}

.raq-b2b-quote-cart__item-title a:hover,
.raq-b2b-quote-cart__item-title a:focus {
	color: #0b5f59;
	text-decoration: underline;
}

.raq-b2b-quote-cart__item-meta {
	display: grid;
	gap: 5px;
	color: #64748b;
	font-size: 13px;
	line-height: 1.45;
}

.raq-b2b-quote-cart__meta-line {
	display: block;
}

.raq-b2b-quote-cart__meta-label {
	font-weight: 700;
	color: #334155;
}

.raq-b2b-quote-cart__meta-value {
	color: #64748b;
}

.raq-b2b-quote-cart__missing-note {
	display: inline-flex;
	width: fit-content;
	margin-top: 4px;
	padding: 5px 8px;
	background: #ffedd5;
	border: 1px solid #fed7aa;
	border-radius: 999px;
	color: #9a3412;
	font-size: 12px;
	font-weight: 700;
}

.raq-b2b-quote-cart__item-actions {
	display: grid;
	gap: 8px;
	justify-items: stretch;
	align-items: center;
}

.raq-b2b-quote-cart__qty-label {
	display: block;
	margin: 0;
	color: #334155;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.3;
}

.raq-b2b-quote-cart__qty-input {
	display: block;
	width: 100%;
	min-height: 40px;
	padding: 8px 10px;
	background: #ffffff;
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	color: #0f172a;
	font: inherit;
	font-size: 15px;
	line-height: 1.35;
	text-align: center;
	font-variant-numeric: tabular-nums;
	transition:
		border-color 160ms ease,
		box-shadow 160ms ease,
		background-color 160ms ease;
}

.raq-b2b-quote-cart__qty-input:focus {
	border-color: #14b8a6;
	outline: none;
	box-shadow: 0 0 0 3px rgba(167, 243, 208, 0.75);
}

.raq-b2b-quote-cart__item-buttons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.raq-b2b-quote-cart__summary {
	display: grid;
	gap: 8px;
	margin: 18px 0 0;
	padding: 16px;
	background: #f7faf9;
	border: 1px solid #dce7e2;
	border-radius: 16px;
}

.raq-b2b-quote-cart__summary-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	color: #334155;
	font-size: 15px;
	line-height: 1.4;
}

.raq-b2b-quote-cart__summary-row strong {
	color: #0b5f59;
	font-variant-numeric: tabular-nums;
}

.raq-b2b-quote-cart__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	justify-content: flex-end;
	margin: 18px 0 0;
}

.raq-b2b-quote-cart__continue {
	margin-right: auto;
}

.raq-b2b-quote-cart__submit-placeholder {
	margin: 22px 0 0;
	padding: 16px;
	background: #eaf7f1;
	border: 1px dashed #a7f3d0;
	border-radius: 14px;
	color: #334155;
	font-size: 14px;
	line-height: 1.55;
}

.raq-b2b-quote-cart__submit-placeholder p {
	margin: 0;
}

/* ==========================================================================
   Generic quote buttons
   ========================================================================== */

.raq-b2b-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	padding: 10px 16px;
	background: #ffffff;
	border: 1px solid #dce7e2;
	border-radius: 10px;
	color: #0f766e;
	font: inherit;
	font-size: 14px;
	font-weight: 800;
	line-height: 1.2;
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	transition:
		background-color 180ms ease,
		border-color 180ms ease,
		color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease,
		opacity 180ms ease;
}

.raq-b2b-button:hover,
.raq-b2b-button:focus {
	text-decoration: none;
}

.raq-b2b-button:focus-visible {
	outline: 3px solid rgba(167, 243, 208, 0.85);
	outline-offset: 2px;
}

.raq-b2b-button:active {
	transform: translateY(1px);
}

.raq-b2b-button[disabled],
.raq-b2b-button.is-loading {
	opacity: 0.68;
	cursor: not-allowed;
	box-shadow: none;
}

.raq-b2b-button--primary {
	background: #0f766e;
	border-color: #0f766e;
	color: #ffffff;
	box-shadow: 0 8px 18px rgba(15, 118, 110, 0.18);
}

.raq-b2b-button--primary:hover,
.raq-b2b-button--primary:focus {
	background: #0b5f59;
	border-color: #0b5f59;
	color: #ffffff;
	box-shadow: 0 10px 22px rgba(15, 118, 110, 0.24);
}

.raq-b2b-button--secondary {
	background: #ffffff;
	border-color: #0f766e;
	color: #0f766e;
}

.raq-b2b-button--secondary:hover,
.raq-b2b-button--secondary:focus {
	background: #eaf7f1;
	border-color: #0b5f59;
	color: #0b5f59;
}

.raq-b2b-button--text {
	min-height: auto;
	padding: 0;
	background: transparent;
	border-color: transparent;
	color: #0f766e;
	border-radius: 0;
	box-shadow: none;
}

.raq-b2b-button--text:hover,
.raq-b2b-button--text:focus {
	background: transparent;
	color: #0b5f59;
	text-decoration: underline;
	box-shadow: none;
}

.raq-b2b-button--small {
	min-height: 34px;
	padding: 7px 10px;
	border-radius: 8px;
	font-size: 13px;
}

/* ==========================================================================
   Add to Quote Button v2.0 State
   ========================================================================== */

.raq-b2b-quote-button-wrap--action-quote_cart {
	display: grid;
	gap: 8px;
}

.raq-b2b-add-to-quote-button {
	position: relative;
}

.raq-b2b-add-to-quote-button.is-loading {
	opacity: 0.76;
	pointer-events: none;
	cursor: progress;
}

.raq-b2b-add-to-quote-button.is-loading::after {
	content: "";
	width: 14px;
	height: 14px;
	border: 2px solid currentColor;
	border-top-color: transparent;
	border-radius: 999px;
	animation: raq-b2b-spin 0.75s linear infinite;
}

.raq-b2b-add-to-quote-button.is-added {
	background: #0b5f59;
	border-color: #0b5f59;
	color: #ffffff;
}

.raq-b2b-quote-button__text,
.raq-b2b-quote-button__added {
	display: inline-flex;
	align-items: center;
}

.raq-b2b-quote-button__message {
	display: block;
	margin: 0;
	padding: 9px 11px;
	border-radius: 10px;
	border: 1px solid transparent;
	font-size: 13px;
	line-height: 1.45;
}

.raq-b2b-quote-button__message[hidden] {
	display: none;
}

.raq-b2b-quote-button__message a {
	color: inherit;
	font-weight: 800;
	text-decoration: underline;
	text-underline-offset: 2px;
}


/* Frontend Add to Quote visual repair: keep loop buttons styled and prevent duplicate state text. */
.raq-b2b-quote-button-wrap--action-quote_cart {
	display: grid;
	gap: 8px;
	justify-items: stretch;
	align-items: center;
	max-width: 100%;
}

.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-add-to-quote-button,
.woocommerce ul.products li.product .raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-add-to-quote-button {
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	min-height: 42px;
	padding: 10px 18px;
	border: 1px solid #0f766e;
	border-radius: 10px;
	background: #0f766e;
	color: #ffffff;
	font: inherit;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.2;
	text-align: center;
	text-decoration: none;
	white-space: normal;
	box-shadow: 0 8px 18px rgba(15, 118, 110, 0.18);
	appearance: none;
	-webkit-appearance: none;
}

.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-add-to-quote-button:hover,
.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-add-to-quote-button:focus,
.woocommerce ul.products li.product .raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-add-to-quote-button:hover,
.woocommerce ul.products li.product .raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-add-to-quote-button:focus {
	background: #0b5f59;
	border-color: #0b5f59;
	color: #ffffff;
	text-decoration: none;
	box-shadow: 0 10px 22px rgba(15, 118, 110, 0.24);
}

.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-quote-button__text,
.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-quote-button__added {
	align-items: center;
	justify-content: center;
	min-width: 0;
	pointer-events: none;
}

.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-quote-button__added,
.raq-b2b-add-to-quote-button.is-added .raq-b2b-quote-button__added,
.raq-b2b-quote-button__added[hidden],
.raq-b2b-quote-button__message[hidden] {
	display: none !important;
}

.raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-quote-button__message,
.woocommerce ul.products li.product .raq-b2b-quote-button-wrap--action-quote_cart .raq-b2b-quote-button__message {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	margin: 0;
	text-align: center;
	word-break: normal;
	overflow-wrap: anywhere;
}

/* ==========================================================================
   Global Quote Cart Count
   ========================================================================== */

.raq-b2b-quote-cart-count {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-height: 30px;
	padding: 5px 10px;
	background: #eaf7f1;
	border: 1px solid #dce7e2;
	border-radius: 999px;
	color: #0b5f59;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.2;
	text-decoration: none;
}

.raq-b2b-quote-cart-count:hover,
.raq-b2b-quote-cart-count:focus {
	background: #d1fae5;
	border-color: #a7f3d0;
	color: #094c47;
	text-decoration: none;
}

.raq-b2b-quote-cart-count__quantity,
.raq-b2b-quote-cart-count__items {
	font-variant-numeric: tabular-nums;
}

body.raq-b2b-quote-cart-empty .raq-b2b-quote-cart-count--hide-empty {
	display: none;
}

/* ==========================================================================
   Quote Cart WooCommerce / Elementor Compatibility
   ========================================================================== */

.woocommerce div.product .raq-b2b-quote-button-wrap--action-quote_cart {
	margin-top: 12px;
	margin-bottom: 12px;
}

.woocommerce ul.products li.product .raq-b2b-quote-button-wrap--action-quote_cart {
	width: 100%;
}

.woocommerce ul.products li.product .raq-b2b-add-to-quote-button {
	width: 100%;
}

.elementor-widget-woocommerce-product-add-to-cart .raq-b2b-quote-button-wrap--action-quote_cart,
.wp-block-woocommerce-product-button .raq-b2b-quote-button-wrap--action-quote_cart {
	margin-top: 12px;
}

/* When old Add to Cart is hidden, keep variation forms visible enough for option selection. */
.raq-b2b-add-to-cart-hidden form.variations_form.cart {
	display: block !important;
}

.raq-b2b-add-to-cart-hidden form.variations_form.cart .single_variation_wrap .woocommerce-variation-add-to-cart,
.raq-b2b-add-to-cart-hidden form.variations_form.cart .single_add_to_cart_button {
	display: none !important;
}

/* ==========================================================================
   Quote Cart Messages
   ========================================================================== */

.raq-b2b-quote-cart .raq-b2b-message--success,
.raq-b2b-quote-button__message.raq-b2b-message--success {
	background: #ecfdf5;
	border-color: #a7f3d0;
	color: #065f46;
}

.raq-b2b-quote-cart .raq-b2b-message--error,
.raq-b2b-quote-button__message.raq-b2b-message--error {
	background: #fef2f2;
	border-color: #fecaca;
	color: #991b1b;
}

.raq-b2b-quote-cart .raq-b2b-message--info,
.raq-b2b-quote-button__message.raq-b2b-message--info {
	background: #eff6ff;
	border-color: #bfdbfe;
	color: #1e40af;
}

/* ==========================================================================
   Loading Animation
   ========================================================================== */

@keyframes raq-b2b-spin {
	to {
		transform: rotate(360deg);
	}
}

/* ==========================================================================
   Quote Cart Responsive
   ========================================================================== */

@media (max-width: 768px) {
	.raq-b2b-quote-cart {
		margin: 22px auto;
	}

	.raq-b2b-quote-cart__header {
		display: grid;
		gap: 12px;
		align-items: start;
	}

	.raq-b2b-quote-cart__title {
		font-size: 24px;
	}

	.raq-b2b-quote-cart__header-summary {
		width: 100%;
	}

	.raq-b2b-quote-cart__summary-item {
		flex: 1 1 auto;
		justify-content: space-between;
		border-radius: 12px;
	}

	.raq-b2b-quote-cart__item {
		grid-template-columns: 76px minmax(0, 1fr);
		gap: 14px;
		align-items: start;
		padding: 14px;
	}

	.raq-b2b-quote-cart__item-media,
	.raq-b2b-quote-cart__image-link,
	.raq-b2b-quote-cart__image,
	.raq-b2b-quote-cart__image-placeholder {
		width: 76px;
		height: 76px;
		min-width: 76px;
	}

	.raq-b2b-quote-cart__item-actions {
		grid-column: 1 / -1;
		grid-template-columns: 120px minmax(0, 1fr);
		gap: 10px;
		align-items: end;
	}

	.raq-b2b-quote-cart__qty-label {
		grid-column: 1 / -1;
	}

	.raq-b2b-quote-cart__item-buttons {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.raq-b2b-quote-cart__actions {
		display: grid;
		grid-template-columns: 1fr;
		justify-items: stretch;
	}

	.raq-b2b-quote-cart__continue {
		margin-right: 0;
	}

	.raq-b2b-quote-cart__actions .raq-b2b-button,
	.raq-b2b-quote-cart__item-buttons .raq-b2b-button,
	.raq-b2b-quote-cart__continue {
		width: 100%;
	}
}

@media (max-width: 480px) {
	.raq-b2b-quote-cart__title {
		font-size: 22px;
	}

	.raq-b2b-quote-cart__empty {
		padding: 22px 16px;
		border-radius: 16px;
	}

	.raq-b2b-quote-cart__item {
		grid-template-columns: 64px minmax(0, 1fr);
		padding: 12px;
		border-radius: 16px;
	}

	.raq-b2b-quote-cart__item-media,
	.raq-b2b-quote-cart__image-link,
	.raq-b2b-quote-cart__image,
	.raq-b2b-quote-cart__image-placeholder {
		width: 64px;
		height: 64px;
		min-width: 64px;
		border-radius: 12px;
	}

	.raq-b2b-quote-cart__item-title {
		font-size: 15px;
	}

	.raq-b2b-quote-cart__item-meta {
		font-size: 12px;
	}

	.raq-b2b-quote-cart__item-actions {
		grid-template-columns: 1fr;
	}

	.raq-b2b-quote-cart__summary {
		padding: 14px;
		border-radius: 14px;
	}

	.raq-b2b-quote-cart__summary-row {
		font-size: 14px;
	}

	.raq-b2b-quote-button__message {
		font-size: 12px;
	}
}

/* ==========================================================================
   Quote Cart Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	.raq-b2b-quote-cart__item,
	.raq-b2b-button,
	.raq-b2b-add-to-quote-button,
	.raq-b2b-quote-button__message {
		transition: none;
	}

	.raq-b2b-button:active {
		transform: none;
	}

	.raq-b2b-add-to-quote-button.is-loading::after {
		animation: none;
	}
}
/* Quote Cart RFQ modal (V2.0 repair) */
body.raq-b2b-quote-cart-modal-open {
	overflow: hidden;
}

.raq-b2b-quote-cart-modal[hidden] {
	display: none !important;
}

.raq-b2b-quote-cart-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.raq-b2b-quote-cart-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.56);
}

.raq-b2b-quote-cart-modal__dialog {
	position: relative;
	z-index: 1;
	width: min(720px, 100%);
	max-height: calc(100vh - 48px);
	overflow: auto;
	background: #fff;
	border: 1px solid #dce7e2;
	border-radius: 18px;
	box-shadow: 0 24px 80px rgba(15, 23, 42, 0.22);
}

.raq-b2b-quote-cart-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	z-index: 2;
	width: 38px;
	height: 38px;
	border: 1px solid #dce7e2;
	border-radius: 999px;
	background: #fff;
	color: #0f172a;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
}

.raq-b2b-quote-cart-modal__close:hover,
.raq-b2b-quote-cart-modal__close:focus {
	border-color: #a7f3d0;
	color: #0f766e;
	outline: none;
}

.raq-b2b-quote-cart-modal__body {
	padding: 28px;
}

.raq-b2b-quote-cart-modal .raq-b2b-quote-form-section,
.raq-b2b-quote-cart-modal .raq-b2b-quote-form {
	margin: 0;
	padding: 0;
	box-shadow: none;
	border: 0;
	background: transparent;
}

.raq-b2b-quote-cart-modal .raq-b2b-quote-form__inner,
.raq-b2b-quote-cart-modal .raq-b2b-quote-cart-form__inner {
	padding: 0;
}

.raq-b2b-quote-cart__request {
	margin-left: auto;
}

.raq-b2b-quote-cart__submit-fallback {
	margin-top: 24px;
}

@media (max-width: 768px) {
	.raq-b2b-quote-cart-modal {
		align-items: flex-end;
		padding: 12px;
	}

	.raq-b2b-quote-cart-modal__dialog {
		width: 100%;
		max-height: calc(100vh - 24px);
		border-radius: 18px 18px 12px 12px;
	}

	.raq-b2b-quote-cart-modal__body {
		padding: 24px 18px 18px;
	}

	.raq-b2b-quote-cart__request {
		margin-left: 0;
	}
}


/* ==========================================================================
   Variable Product / Model Selection Safety
   ========================================================================== */

.raq-b2b-quote-button--requires-options.is-disabled,
.raq-b2b-add-to-quote-button.is-disabled {
	cursor: not-allowed;
	opacity: 0.72;
}

.raq-b2b-quote-button--select-options {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

/* ==========================================================================
   Header Count, Mini Quote Cart, Floating Quote Cart
   ========================================================================== */

.raq-b2b-quote-cart-count {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	color: inherit;
}

.raq-b2b-quote-cart-count__badge,
.raq-b2b-mini-quote-cart__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 24px;
	height: 24px;
	padding: 0 7px;
	border-radius: 999px;
	background: #0f766e;
	color: #ffffff;
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
}

.raq-b2b-mini-quote-cart {
	position: relative;
	z-index: 30;
	font-family: inherit;
}

.raq-b2b-mini-quote-cart--floating {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 9998;
}

.raq-b2b-mini-quote-cart__toggle {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-height: 44px;
	padding: 10px 14px;
	border: 1px solid #0f766e;
	border-radius: 999px;
	background: #0f766e;
	color: #ffffff;
	box-shadow: 0 14px 30px rgba(15, 23, 42, 0.14);
	cursor: pointer;
	font: inherit;
	font-weight: 700;
}

.raq-b2b-mini-quote-cart__panel {
	position: absolute;
	right: 0;
	bottom: calc(100% + 12px);
	width: min(360px, calc(100vw - 32px));
	max-height: min(520px, calc(100vh - 120px));
	overflow: auto;
	padding: 16px;
	border: 1px solid #dce7e2;
	border-radius: 16px;
	background: #ffffff;
	box-shadow: 0 18px 44px rgba(15, 23, 42, 0.16);
	color: #0f172a;
}

.raq-b2b-mini-quote-cart--inline .raq-b2b-mini-quote-cart__panel {
	top: calc(100% + 10px);
	bottom: auto;
}

.raq-b2b-mini-quote-cart__panel-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}

.raq-b2b-mini-quote-cart__close {
	width: 32px;
	height: 32px;
	border: 1px solid #dce7e2;
	border-radius: 999px;
	background: #ffffff;
	color: #334155;
	cursor: pointer;
	font-size: 20px;
	line-height: 1;
}

.raq-b2b-mini-quote-cart__empty {
	margin: 8px 0 14px;
	color: #64748b;
}

.raq-b2b-mini-quote-cart__items {
	display: grid;
	gap: 10px;
	margin: 0 0 14px;
	padding: 0;
	list-style: none;
}

.raq-b2b-mini-quote-cart__item {
	display: grid;
	gap: 4px;
	padding: 10px;
	border: 1px solid #dce7e2;
	border-radius: 12px;
	background: #f7faf9;
}

.raq-b2b-mini-quote-cart__item-name {
	font-weight: 700;
	color: #0f172a;
}

.raq-b2b-mini-quote-cart__item-meta,
.raq-b2b-mini-quote-cart__item-qty,
.raq-b2b-mini-quote-cart__more {
	color: #64748b;
	font-size: 13px;
	line-height: 1.35;
}

.raq-b2b-mini-quote-cart__summary {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	margin: 12px 0;
	padding-top: 12px;
	border-top: 1px solid #dce7e2;
	color: #334155;
	font-size: 14px;
}

.raq-b2b-mini-quote-cart__view {
	width: 100%;
	justify-content: center;
}

@media (max-width: 640px) {
	.raq-b2b-mini-quote-cart--floating {
		right: 14px;
		bottom: 14px;
	}

	.raq-b2b-mini-quote-cart__title {
		display: none;
	}

	.raq-b2b-mini-quote-cart__panel {
		position: fixed;
		right: 14px;
		left: 14px;
		bottom: 72px;
		width: auto;
		max-height: min(70vh, 520px);
	}
}

/* B2B Quote Suite v2.1.0 - RFQ custom fields and uploads */
.raq-b2b-rfq-fields {
	margin-top: 1.25rem;
	padding: 1rem;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	background: #fff;
}
.raq-b2b-rfq-fields__title {
	margin: 0 0 1rem;
	font-size: 1.05rem;
	font-weight: 700;
}
.raq-b2b-rfq-fields__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}
.raq-b2b-rfq-field--textarea,
.raq-b2b-rfq-field--checkbox,
.raq-b2b-rfq-field--radio,
.raq-b2b-rfq-field--file {
	grid-column: 1 / -1;
}
.raq-b2b-rfq-field label,
.raq-b2b-rfq-field__label {
	display: block;
	margin-bottom: 0.35rem;
	font-weight: 600;
}
.raq-b2b-rfq-field input[type="text"],
.raq-b2b-rfq-field input[type="email"],
.raq-b2b-rfq-field input[type="number"],
.raq-b2b-rfq-field input[type="tel"],
.raq-b2b-rfq-field input[type="date"],
.raq-b2b-rfq-field select,
.raq-b2b-rfq-field textarea {
	width: 100%;
	max-width: 100%;
}
.raq-b2b-rfq-field__description,
.raq-b2b-file-upload-help,
.raq-b2b-file-upload-feedback {
	display: block;
	margin-top: 0.35rem;
	font-size: 0.875rem;
	color: #646970;
}
.raq-b2b-rfq-options {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
}
.raq-b2b-rfq-option {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-weight: 400;
}
.raq-b2b-file-upload-feedback.is-error {
	color: #b32d2e;
}
.raq-b2b-file-upload-feedback.is-ok {
	color: #008a20;
}
@media (max-width: 640px) {
	.raq-b2b-rfq-fields__grid {
		grid-template-columns: 1fr;
	}
}

/* B2B Quote Suite v2.4.25 - style native upload input while preserving browser/customer-language text */
.raq-b2b-file-upload-input {
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin-top: 0.35rem;
	padding: 0.55rem 0.65rem;
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	background: #ffffff;
	color: #0f172a;
	font: inherit;
	line-height: 1.35;
}

.raq-b2b-file-upload-input::file-selector-button {
	margin: 0 0.8rem 0 0;
	padding: 0.48rem 0.9rem;
	border: 1px solid #0f766e;
	border-radius: 8px;
	background: #eaf7f1;
	color: #0f766e;
	font: inherit;
	font-weight: 700;
	line-height: 1.2;
	cursor: pointer;
}

.raq-b2b-file-upload-input::-webkit-file-upload-button {
	margin: 0 0.8rem 0 0;
	padding: 0.48rem 0.9rem;
	border: 1px solid #0f766e;
	border-radius: 8px;
	background: #eaf7f1;
	color: #0f766e;
	font: inherit;
	font-weight: 700;
	line-height: 1.2;
	cursor: pointer;
}

.raq-b2b-file-upload-input:hover::file-selector-button,
.raq-b2b-file-upload-input:hover::-webkit-file-upload-button {
	border-color: #0b5f59;
	background: #d1fae5;
	color: #0b5f59;
}

.raq-b2b-file-upload-input:focus,
.raq-b2b-file-upload-input:focus-visible {
	outline: 3px solid rgba(167, 243, 208, 0.8);
	outline-offset: 2px;
	border-color: #0f766e;
}

/* B2B Buyer Application / Account Status */
.raq-b2b-registration,
.raq-b2b-status {
	border: 1px solid #d9e2e7;
	border-radius: 12px;
	padding: 20px;
	margin: 20px 0;
	background: #fff;
}
.raq-b2b-registration__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px 16px;
}
.raq-b2b-registration label {
	display: block;
	font-weight: 600;
}
.raq-b2b-registration input,
.raq-b2b-registration textarea {
	width: 100%;
	margin-top: 6px;
}
.raq-b2b-registration__notice {
	padding: 12px 14px;
	border-radius: 10px;
	margin: 14px 0;
}
.raq-b2b-registration__notice--success {
	background: #ecfdf3;
	border: 1px solid #bbf7d0;
}
.raq-b2b-registration__notice--error {
	background: #fff1f2;
	border: 1px solid #fecdd3;
}
.raq-b2b-status--pending {
	border-left: 4px solid #f59e0b;
}
.raq-b2b-status--approved {
	border-left: 4px solid #16a34a;
}
.raq-b2b-status--rejected {
	border-left: 4px solid #dc2626;
}
@media (max-width: 640px) {
	.raq-b2b-registration__grid {
		grid-template-columns: 1fr;
	}
}
