/*
Theme Name: Lavari
Theme URI: https://lavari.test/
Author: Lavari
Author URI: https://lavari.test/
Description: Custom blank theme for Lavari.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lavari
*/

/* ==========================================================================
   Lavari — theme glue: replicate the React component states with plain CSS/JS.
   The bulk of the design lives in assets/css/verstka.css (extracted verbatim).
   ========================================================================== */

/* Dropdown opens on hover (React used catOpen state) */
.dropdown__panel { display: none; }
.dropdown:hover .dropdown__panel,
.dropdown.is-open .dropdown__panel { display: block; }

/* Wishlist heart on/off (two SVGs toggled by .is-on) */
.fav-heart .ico-heart-on { display: none; }
.fav-heart.is-on .ico-heart-off { display: none; }
.fav-heart.is-on .ico-heart-on { display: inline-block; }

/* Add-to-cart "added" state */
.pcard__add .ico-check { display: none; }
.pcard__add.added .ico-plus { display: none; }
.pcard__add.added .ico-check { display: inline-block !important; }

/* Header heart count badge sits like the cart count */
.site__actions .cart-count { position: absolute; top: -6px; right: -8px; }

/* Make whole product card clickable (cursor already set inline) */
.pcard a, .pcard button:not(.fav-heart) { position: relative; z-index: 2; }
.pcard .fav-heart {
	position: absolute;
	top: 12px;
	right: 12px;
	left: auto;
	z-index: 3;
	width: 28px;
	height: 28px;
	background: var(--paper);
	border-color: var(--ink);
	box-shadow: none;
}
.pcard .fav-heart .ico { width: 13px; height: 13px; }

/* WooCommerce notices — keep them subtle (we surface via toasts) */
.lavari-wc-main > .woocommerce-notices-wrapper { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }

/* Hide express checkout without removing the template markup. */
.woocommerce-checkout .ck-express { display: none !important; }

/* Hide WP admin bar offset glitches on full-bleed sections */
html { scroll-behavior: smooth; }

/* Toast container reused for JS toasts (markup matches header.jsx Toast) */
.js-toast-root .toast,
body > .toast {
	z-index: 420;
	top: 94px;
	right: 24px;
	width: min(460px, calc(100vw - 32px));
	max-width: none;
	border-radius: 12px;
}
.js-toast-root .toast__inner,
body > .toast .toast__inner {
	grid-template-columns: 28px minmax(0, 1fr) 28px;
	gap: 12px;
	padding: 14px 14px 14px 16px;
	align-items: start;
}
.js-toast-root .toast__body,
body > .toast .toast__body {
	grid-column: 2;
	grid-row: 1;
	min-width: 0;
	padding-top: 1px;
}
.js-toast-root .toast__title,
body > .toast .toast__title {
	line-height: 1.25;
}
.js-toast-root .toast__sub,
body > .toast .toast__sub {
	max-width: 100%;
	line-height: 1.25;
}
.js-toast-root .toast__cta,
body > .toast .toast__cta {
	grid-column: 2 / 4;
	grid-row: 2;
	justify-self: start;
	margin-top: 2px;
	line-height: 1;
}
.js-toast-root .toast__close,
body > .toast .toast__close {
	grid-column: 3;
	grid-row: 1;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.js-toast-root .toast__icon,
body > .toast .toast__icon {
	grid-column: 1;
	grid-row: 1;
}
@media (min-width: 940px) {
	body.is-cart-open .js-toast-root .toast {
		right: calc(460px + 24px);
	}
}
@media (max-width: 640px) {
	.js-toast-root .toast,
	body > .toast {
		top: 12px;
		left: 12px;
		right: 12px;
		width: auto;
	}
}

/* B2B page: no global chrome spacing */
body.page-b2b { background: var(--bg); }

/* Footer payment chips can otherwise add ~30px horizontal overflow on phones. */
@media (max-width: 520px) {
	footer .meta > div,
	footer .meta > div > div { width: 100%; min-width: 0; flex-wrap: wrap; }
	footer .pay { flex-wrap: wrap; max-width: 100%; min-width: 0; }
	footer .pay span { overflow-wrap: anywhere; }
}

/* ==========================================================================
   WooCommerce classic cart & checkout — restyled to the verstka aesthetic.
   ========================================================================== */
.ck-header { padding: 8px 0 36px; border-bottom: 1px solid var(--rule); margin-bottom: 40px; }
.woocommerce-checkout .lavari-page,
.woocommerce-cart .lavari-page { padding-top: 28px; }

/* Inputs */
.woocommerce form .form-row { padding: 0; margin: 0 0 16px; }
.woocommerce .form-row label,
.woocommerce-checkout .form-row label {
	font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
	text-transform: uppercase; color: var(--ink-muted); display: block; margin-bottom: 6px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-checkout input.input-text,
.woocommerce select,
.select2-container .select2-selection {
	border: 1px solid var(--rule); border-radius: 0; padding: 13px 14px;
	font-family: var(--font-sans); font-size: 15px; background: var(--paper); width: 100%;
	color: var(--ink); transition: border-color .15s;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { border-color: var(--ink); outline: 0; }
.woocommerce .select2-container--default .select2-selection--single { height: auto; }
.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 1.4; padding: 0; }

/* Two-column checkout layout */
.woocommerce-checkout #customer_details { width: 58%; float: left; }
.woocommerce-checkout #order_review,
.woocommerce-checkout #order_review_heading { width: 38%; float: right; }
.woocommerce-checkout #order_review {
	background: var(--bg-card); border: 1px solid var(--rule); padding: 28px;
	position: sticky; top: 90px;
}
.woocommerce-checkout #order_review_heading {
	font-family: var(--font-display); font-size: 22px; font-weight: 400;
	letter-spacing: .02em; margin: 0 0 0 0;
}
@media (max-width: 900px) {
	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review,
	.woocommerce-checkout #order_review_heading { width: 100%; float: none; }
	.woocommerce-checkout #order_review { position: static; }
}

/* Section headings */
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3,
#ship-to-different-address {
	font-family: var(--font-mono); font-size: 11px; letter-spacing: .15em;
	text-transform: uppercase; color: var(--ink); margin: 0 0 18px; font-weight: 500;
}

/* Order table */
.woocommerce-checkout .shop_table,
.woocommerce-cart .shop_table {
	border: 1px solid var(--rule); border-radius: 0; font-family: var(--font-sans);
}
.woocommerce-checkout .shop_table th,
.woocommerce-cart .shop_table th {
	font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em;
	text-transform: uppercase; color: var(--ink-muted);
}
.woocommerce-checkout .order-total .amount,
.cart_totals .order-total .amount { color: var(--ink); font-weight: 700; }

/* Payment methods */
#payment { background: transparent; border-radius: 0; }
#payment ul.payment_methods { border: 1px solid var(--rule); padding: 0; }
#payment ul.payment_methods li { padding: 16px 18px; border-bottom: 1px solid var(--rule-soft); list-style: none; }
#payment ul.payment_methods li:last-child { border-bottom: 0; }
#payment div.payment_box { background: var(--bg-soft); border-radius: 0; font-size: 13px; }
#payment div.payment_box::before { display: none; }

/* Buttons */
.woocommerce #payment #place_order,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce .button.alt, .wc-block-components-button {
	background: var(--accent) !important; color: var(--paper) !important; border: 1px solid var(--accent) !important;
	border-radius: 0 !important; font-family: var(--font-mono); font-size: 12px; letter-spacing: .12em;
	text-transform: uppercase; padding: 16px 26px !important; font-weight: 500; transition: background .15s;
}
.woocommerce #payment #place_order:hover,
.woocommerce a.button:hover, .woocommerce button.button:hover { background: var(--accent-deep) !important; }
.woocommerce #payment #place_order { width: 100%; margin-top: 8px; }
.woocommerce .button.wc-backward,
.woocommerce a.button.wc-forward.wp-element-button:not(.checkout-button) {
	background: transparent !important; color: var(--ink) !important; border-color: var(--rule) !important;
}

/* Coupon */
.woocommerce-cart .coupon .input-text { width: auto; display: inline-block; }
.woocommerce form.checkout_coupon { border: 1px solid var(--rule); border-radius: 0; }

/* Notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	border-top-color: var(--accent); border-radius: 0; background: var(--bg-soft); font-size: 14px;
}

/* Cart table images */
.woocommerce-cart .shop_table img { width: 64px; border: 1px solid var(--rule); }

/* Order received (thank you) */
.woocommerce-order { max-width: 760px; margin: 0 auto; }
.woocommerce-thankyou-order-received {
	font-family: var(--font-display); font-size: clamp(32px,5vw,56px); letter-spacing: .01em;
}

/* Checkout page: WooCommerce functionality inside the source B2C layout. */
.woocommerce-checkout .ck-header--page {
	background: var(--bg-soft);
	border-bottom: 1px solid var(--rule);
	margin-bottom: 0;
	padding: 0;
}
.woocommerce-checkout .ck-header--page .wrap { padding-top: 28px; padding-bottom: 36px; }
.ck-header__row {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 32px;
	flex-wrap: wrap;
}
.ck-header__title {
	font-size: clamp(36px, 5vw, 64px);
	margin: 0;
	letter-spacing: .01em;
}
.ck-header__title span { display: block; }
.ck-header__title span + span { font-style: italic; }
.ck-section { padding: 48px 0 96px; }
.woocommerce-checkout form.ck-layout {
	width: 100%;
	max-width: var(--maxw);
	margin: 0 auto;
	padding-left: var(--gutter);
	padding-right: var(--gutter);
}
.woocommerce-checkout form.ck-layout #customer_details,
.woocommerce-checkout form.ck-layout #order_review,
.woocommerce-checkout form.ck-layout #order_review_heading {
	float: none;
	width: auto;
}
.woocommerce-checkout form.ck-layout #order_review {
	background: transparent;
	border: 0;
	padding: 0;
	position: sticky;
	top: 100px;
	align-self: start;
}
.woocommerce-checkout form.ck-layout #order_review_heading { display: none; }
.woocommerce-checkout .ck-form .form-row {
	margin: 0;
	padding: 0;
	float: none;
	width: auto;
	clear: none;
}
.woocommerce-checkout .ck-form .form-row-wide,
.woocommerce-checkout .ck-form [data-ck-span="2"] { grid-column: 1 / -1; }
.woocommerce-checkout .ck-form .form-row-first,
.woocommerce-checkout .ck-form .form-row-last {
	float: none;
	width: auto;
	overflow: visible;
}
.woocommerce-checkout .ck-form .form-row label,
.woocommerce-checkout .ck-form .ck-field__l {
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--ink-muted);
	display: block;
	margin: 0 0 6px;
}
.woocommerce-checkout .ck-form .required { color: var(--accent); text-decoration: none; }
.woocommerce-checkout .ck-form .optional { color: var(--ink-muted); opacity: .72; }
.woocommerce-checkout .ck-form input.input-text,
.woocommerce-checkout .ck-form textarea,
.woocommerce-checkout .ck-form select,
.woocommerce-checkout .ck-form .select2-container .select2-selection {
	border: 1px solid var(--rule);
	border-radius: 0;
	background: var(--paper);
	color: var(--ink);
	font-family: var(--font-sans);
	font-size: 14px;
	line-height: 1.45;
	padding: 12px 14px;
	width: 100%;
	min-height: 44px;
	transition: border-color .15s, box-shadow .15s;
}
.woocommerce-checkout .ck-form textarea {
	min-height: 72px;
	resize: vertical;
}
.woocommerce-checkout .ck-form input.input-text:focus,
.woocommerce-checkout .ck-form textarea:focus,
.woocommerce-checkout .ck-form select:focus {
	border-color: var(--ink);
	box-shadow: none;
	outline: 0;
}
.woocommerce-checkout .ck-form .select2-container { width: 100% !important; }
.woocommerce-checkout .ck-form .select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 1.45;
	padding: 0 24px 0 0;
	color: var(--ink);
}
.woocommerce-checkout .ck-form .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 100%;
	right: 8px;
}
.woocommerce-checkout .ck-form .woocommerce-invalid input.input-text,
.woocommerce-checkout .ck-form .woocommerce-invalid select,
.woocommerce-checkout .ck-form .woocommerce-invalid .select2-selection {
	border-color: var(--accent);
}
.woocommerce-checkout .ck-form .woocommerce-input-wrapper { display: block; }
.woocommerce-checkout .ck-express__bolt {
	color: var(--green);
	font-size: 10px;
	letter-spacing: .14em;
}
.woocommerce-checkout #payment.woocommerce-checkout-payment {
	background: transparent;
	border-radius: 0;
	padding: 0;
}
.woocommerce-checkout .ck-fieldset--payment #payment ul.payment_methods {
	border: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.woocommerce-checkout .ck-fieldset--payment #payment ul.payment_methods li.ck-pay-opt {
	position: relative;
	border: 1px solid var(--rule);
	border-radius: 0;
	background: var(--paper);
	padding: 0;
	list-style: none;
	transition: border-color .15s, background .15s, box-shadow .15s;
}
.woocommerce-checkout .ck-fieldset--payment #payment ul.payment_methods li.ck-pay-opt:hover { border-color: var(--ink-muted); }
.woocommerce-checkout .ck-fieldset--payment #payment ul.payment_methods li.ck-pay-opt.is-active {
	border-color: var(--ink);
	background: var(--paper);
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt__inner {
	min-height: 74px;
	display: flex;
	align-items: center;
	gap: 18px;
	padding: 18px 22px;
	cursor: pointer;
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt input.input-radio {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt__radio {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	border: 1.5px solid var(--rule);
	background: var(--paper);
	flex: 0 0 auto;
	position: relative;
	transition: border-color .15s;
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt.is-active .ck-pay-opt__radio {
	border-color: var(--ink);
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt.is-active .ck-pay-opt__radio::after {
	content: '';
	position: absolute;
	inset: 4px;
	border-radius: 50%;
	background: var(--ink);
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt__l {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt__title {
	font-family: var(--font-sans);
	font-size: 16px;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0;
	text-transform: none;
	color: var(--ink);
	margin: 0;
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt__hint {
	font-family: var(--font-mono);
	font-size: 11px;
	line-height: 1.2;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--ink-muted);
}
.woocommerce-checkout .ck-fieldset--payment .ck-pay-opt__icon {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex: 0 0 auto;
}
.woocommerce-checkout .ck-fieldset--payment #payment div.payment_box {
	margin: 0;
	padding: 0 22px 20px 58px;
	background: var(--paper);
	border-radius: 0;
	color: var(--ink-2);
	font-size: 13px;
	line-height: 1.55;
}
.woocommerce-checkout .ck-fieldset--payment #payment div.payment_box::before { display: none; }
.woocommerce-checkout .ck-place-order {
	display: flex;
	flex-direction: column;
	gap: 14px;
	margin: 0;
}
.woocommerce-checkout .ck-place-order .woocommerce-terms-and-conditions-wrapper {
	display: block;
}
.woocommerce-checkout .ck-place-order .woocommerce-terms-and-conditions-wrapper p {
	margin: 0 0 10px;
	font-size: 13px;
	color: var(--ink-2);
}
.woocommerce-checkout .ck-place-order .woocommerce-form__label-for-checkbox {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 18px 20px;
	background: var(--bg-card);
	border: 1px solid var(--rule);
	cursor: pointer;
	font-family: var(--font-sans);
	font-size: 14px;
	letter-spacing: 0;
	text-transform: none;
	color: var(--ink-2);
	margin: 0;
}
.woocommerce-checkout .ck-place-order .woocommerce-form__label-for-checkbox input {
	width: 18px;
	height: 18px;
	margin: 1px 0 0;
	accent-color: var(--ink);
	flex: 0 0 auto;
}
.woocommerce-checkout .ck-place-order .woocommerce-form__label-for-checkbox .required { color: var(--accent); }
.woocommerce-checkout .ck-place-order .woocommerce-form__label-for-checkbox a {
	border-bottom: 1px solid currentColor;
	color: var(--ink);
}
.woocommerce-checkout .ck-submit,
.woocommerce-checkout #place_order.ck-submit {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 18px 24px !important;
	font-size: 12px;
	letter-spacing: .14em;
	margin: 0;
}
.woocommerce-checkout .ck-secure-text {
	color: var(--ink-muted);
	text-align: center;
	margin: 0;
	font-size: 10px;
}
.woocommerce-checkout .ck-summary {
	width: 100%;
	box-sizing: border-box;
	position: static;
	top: auto;
}
.woocommerce-checkout .ck-summary__head h3 {
	font-family: var(--font-display);
	font-size: 22px;
	margin: 0;
	font-weight: 400;
	letter-spacing: .02em;
}
.woocommerce-checkout .ck-line__img .ph {
	height: 64px !important;
	min-height: 64px;
	border-radius: 0;
}
.woocommerce-checkout .ck-line__body .pcard__spec {
	margin-top: 2px;
	font-size: 10px;
}
.woocommerce-checkout .ck-line__body dl.variation {
	margin: 6px 0 0;
	font-size: 11px;
	color: var(--ink-muted);
}
.woocommerce-checkout .ck-line__body dl.variation dt,
.woocommerce-checkout .ck-line__body dl.variation dd {
	display: inline;
	margin: 0;
}
.woocommerce-checkout .ck-line__body dl.variation p { display: inline; margin: 0; }
.woocommerce-checkout .ck-line__price del,
.woocommerce-checkout .ck-line__price s { color: var(--ink-muted); font-weight: 400; margin-right: 4px; }
.woocommerce-checkout .ck-promo { margin-bottom: 8px; }
.woocommerce-checkout .ck-promo button:disabled { opacity: .55; cursor: wait; }
.woocommerce-checkout .ck-promo-msg {
	min-height: 14px;
	margin: 0 0 8px;
	color: var(--green);
	font-size: 10px;
	letter-spacing: .08em;
}
.woocommerce-checkout .ck-promo-msg.is-error { color: var(--accent); }
.woocommerce-checkout .ck-row .amount { font-weight: inherit; }
.woocommerce-checkout .ck-row--discount,
.woocommerce-checkout .ck-row--discount a { color: var(--accent); }
.woocommerce-checkout .ck-row--discount .woocommerce-remove-coupon {
	margin-left: 6px;
	font-size: 10px;
	color: var(--ink-muted);
}
.woocommerce-checkout .ck-free { color: var(--green); }
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup,
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup-checkout,
.woocommerce-checkout form.ck-layout > .woocommerce-notices-wrapper,
.woocommerce-checkout form.ck-layout > .woocommerce-error,
.woocommerce-checkout form.ck-layout > .woocommerce-info,
.woocommerce-checkout form.ck-layout > .woocommerce-message {
	grid-column: 1 / -1;
	width: 100%;
	min-width: 0;
	margin: 0;
}
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup:empty,
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup-checkout:empty { display: none; }
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup .woocommerce-error,
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup .woocommerce-info,
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup .woocommerce-message {
	max-width: none;
	width: 100%;
	margin: 0 0 24px;
	box-sizing: border-box;
}
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup .woocommerce-error:last-child,
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup .woocommerce-info:last-child,
.woocommerce-checkout form.ck-layout > .woocommerce-NoticeGroup .woocommerce-message:last-child { margin-bottom: 24px; }
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
	max-width: var(--maxw);
	margin: 18px auto;
}
@media (max-width: 960px) {
	.woocommerce-checkout form.ck-layout #order_review {
		position: static;
		top: 0;
		order: -1;
	}
}
@media (max-width: 520px) {
	.woocommerce-checkout .ck-header--page .wrap { padding-top: 22px; padding-bottom: 28px; }
	.ck-header__row { align-items: flex-start; }
	.woocommerce-checkout .ck-form .form-row-wide,
	.woocommerce-checkout .ck-form [data-ck-span="2"] { grid-column: auto; }
	.woocommerce-checkout .ck-promo { grid-template-columns: 1fr; }
	.woocommerce-checkout .ck-promo button { min-height: 44px; }
}

/* B2B Contact Form 7 */
.b2b-page .hero-a-buttons .btn--primary,
.b2b-page .hero-a-buttons .btn--primary:hover,
.b2b-page .hero-a-buttons .btn--primary:focus {
	color: var(--paper);
}

.b2b-page .wpcf7 {
	width: 100%;
	margin: 0;
}
.b2b-page .b2b-form-grid > .wpcf7,
.b2b-page .b2b-contact > .wpcf7 {
	min-width: 0;
}
.b2b-page .b2b-modal .wpcf7-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
	background: transparent;
	border: 0;
	padding: 0;
}
.b2b-page .b2b-form > p,
.b2b-page .b2b-form__row > p {
	margin: 0;
}
.b2b-page .b2b-modal .wpcf7-form > p {
	margin: 0;
}
.b2b-page .b2b-form > p:not(.b2b-form__privacy),
.b2b-page .b2b-form__row > p,
.b2b-page .b2b-modal .wpcf7-form > p:not(.b2b-form__privacy) {
	display: contents;
}
.b2b-page .b2b-form > p:empty,
.b2b-page .b2b-form br,
.b2b-page .b2b-modal .wpcf7-form br {
	display: none;
}
.b2b-page .b2b-modal .wpcf7-form > .hidden-fields-container {
	display: none;
}
.b2b-page .b2b-field .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
}
.b2b-page .b2b-field .wpcf7-form-control-wrap,
.b2b-page .b2b-field .wpcf7-form-control-wrap span {
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
	letter-spacing: 0;
}
.b2b-page .b2b-field input.wpcf7-not-valid,
.b2b-page .b2b-field textarea.wpcf7-not-valid,
.b2b-page .b2b-field select.wpcf7-not-valid {
	border-color: #dc2626;
}
.b2b-page .wpcf7-not-valid-tip {
	display: block;
	margin-top: 6px;
	color: #dc2626;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0;
}
.b2b-page .b2b-chips .wpcf7-form-control-wrap,
.b2b-page .b2b-chips .wpcf7-checkbox {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.b2b-page .b2b-chips .wpcf7-list-item {
	margin: 0;
}
.b2b-page .b2b-chips label {
	position: relative;
	display: block;
	margin: 0;
	cursor: pointer;
}
.b2b-page .b2b-chips input[type="checkbox"] {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: 0;
	opacity: 0;
	pointer-events: none;
}
.b2b-page .b2b-chips .wpcf7-list-item-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 8px 14px;
	border: 1px solid var(--b2b-rule);
	background: #fff;
	color: var(--b2b-ink-2);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.b2b-page .b2b-chips input[type="checkbox"]:checked + .wpcf7-list-item-label {
	border-color: var(--b2b-accent);
	background: var(--b2b-accent);
	color: #fff;
}
.b2b-page .b2b-submit {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 8px;
}
.b2b-page .b2b-form input[type="submit"].b2b-btn {
	min-height: 48px;
	cursor: pointer;
	appearance: none;
}
.b2b-page .b2b-form input[type="submit"].b2b-btn--primary {
	border-color: var(--b2b-accent);
	background: var(--b2b-accent);
	color: #fff;
	box-shadow: 0 6px 20px rgba(196,88,36,0.25);
}
.b2b-page .b2b-form input[type="submit"].b2b-btn--primary:hover {
	border-color: var(--b2b-accent-deep);
	background: var(--b2b-accent-deep);
	color: #fff;
	box-shadow: 0 10px 28px rgba(196,88,36,0.35);
}
.b2b-page .b2b-form input[type="submit"].b2b-btn:disabled {
	opacity: .65;
	cursor: wait;
	transform: none;
}
.b2b-page .wpcf7-spinner {
	align-self: center;
	margin: 0;
}
.b2b-page .wpcf7 form .wpcf7-response-output {
	margin: 0;
	padding: 14px 16px;
	border: 1px solid var(--b2b-rule);
	color: var(--b2b-ink-2);
	font-size: 13px;
	line-height: 1.45;
}
.b2b-page .wpcf7 form.sent .wpcf7-response-output {
	border-color: var(--b2b-accent);
	color: var(--b2b-accent);
}
.b2b-page .wpcf7 form.invalid .wpcf7-response-output,
.b2b-page .wpcf7 form.failed .wpcf7-response-output,
.b2b-page .wpcf7 form.aborted .wpcf7-response-output,
.b2b-page .wpcf7 form.spam .wpcf7-response-output {
	border-color: #dc2626;
	color: #dc2626;
}
@media (max-width: 960px) {
	.b2b-page .b2b-contact > .wpcf7 {
		width: 100%;
	}
}
