/**
 * Single product page: variable product layout fix.
 *
 * Default WooCommerce template puts price (.woocommerce-variation-price) and
 * availability (.woocommerce-variation-availability) inside .single_variation_wrap
 * AFTER the attribute table. Several premium themes (The7 in particular) break
 * the cascade so the dynamically inserted price ends up rendered inline next
 * to the "Очистить" reset link — ugly and confusing.
 *
 * We force the variation block to render as a proper section under the dropdown
 * and right above the quantity / add-to-cart row.
 */

.variations_form .single_variation_wrap {
	display: block !important;
	clear: both !important;
	margin-top: 1em;
	width: 100%;
}

.variations_form .woocommerce-variation.single_variation {
	display: block;
	width: 100%;
	margin: 0 0 0.75em;
}

.variations_form .woocommerce-variation-price {
	display: block;
	font-size: 1.35em;
	font-weight: 600;
	line-height: 1.3;
	margin: 0 0 0.5em;
}

.variations_form .woocommerce-variation-price .price small.woocommerce-price-suffix {
	font-size: 0.65em;
	font-weight: 400;
	margin-left: 0.4em;
	white-space: nowrap;
}

.variations_form .woocommerce-variation-availability {
	display: block;
	margin: 0 0 0.75em;
}

.variations_form .woocommerce-variation-availability p {
	margin: 0;
}

.variations_form .woocommerce-variation-add-to-cart {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5em;
}

/* The reset link must stay attached to the dropdown row, not bleed into the
   price area. */
.variations_form table.variations .reset_variations {
	display: inline-block;
	margin-left: 0.5em;
}

/* Replace the native <select> with a button group. The select stays in the DOM
   for WC's JS — we just hide it visually and drive value+change events through
   the buttons. */
.variations_form .wpaic-variation-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
	margin-top: 0.4em;
}

.variations_form .wpaic-variation-buttons + select,
.variations_form .wpaic-variation-buttons ~ select {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

.variations_form .wpaic-variation-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 6em;
	padding: 0.55em 1.1em;
	background: #fff;
	border: 1.5px solid #d6dbe1;
	border-radius: 8px;
	color: #1a1a1a;
	font-size: 0.95em;
	line-height: 1.2;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
	user-select: none;
}

.variations_form .wpaic-variation-button:hover {
	border-color: #1e8be8;
	color: #1e8be8;
}

.variations_form .wpaic-variation-button[aria-pressed="true"],
.variations_form .wpaic-variation-button.is-selected {
	background: #1e8be8;
	border-color: #1e8be8;
	color: #fff;
	box-shadow: 0 1px 4px rgba(30, 139, 232, 0.25);
}

.variations_form .wpaic-variation-button[disabled],
.variations_form .wpaic-variation-button.is-disabled {
	background: #f3f4f5;
	border-color: #e1e3e6;
	color: #9ca0a4;
	cursor: not-allowed;
	text-decoration: line-through;
}
