/* ==========================================================================
   Fysi Skin para YITH Request a Quote
   Visual moderno e minimalista. Mira nas classes geradas pelo YITH.
   Variáveis (--fysi-qs-*) são injetadas no <head> pela página de config.
   ========================================================================== */

:root {
	--fysi-qs-accent: #111827;
	--fysi-qs-accent-hover: #0b0f1a;
	--fysi-qs-accent-text: #ffffff;
	--fysi-qs-radius: 12px;
	--fysi-qs-radius-sm: 8px;
	--fysi-qs-field-pad: 14px 18px;
	--fysi-qs-gap: 16px;
	--fysi-qs-card-shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 8px 24px -12px rgba(16, 24, 40, .18);

	--fysi-qs-border: #e6e8ee;
	--fysi-qs-border-strong: #d3d7e0;
	--fysi-qs-surface: #ffffff;
	--fysi-qs-surface-muted: #f7f8fa;
	--fysi-qs-text: #1a2233;
	--fysi-qs-text-muted: #667085;
	--fysi-qs-focus: rgba(17, 24, 39, .12);
}

/* --------------------------------------------------------------------------
   1. Botão "Solicitar orçamento" (loja / página de produto)
   -------------------------------------------------------------------------- */

.yith-ywraq-add-to-quote {
	margin: 10px 0;
}

.yith-ywraq-add-to-quote a,
a.add_to_quote_button,
.yith-ywraq-add-button a {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin: 0 !important;
	padding: 12px 22px;
	font-size: .98rem !important;
	font-weight: 600;
	line-height: 1.1;
	text-decoration: none;
	color: var(--fysi-qs-accent-text);
	background: var(--fysi-qs-accent);
	border: 1px solid var(--fysi-qs-accent);
	border-radius: var(--fysi-qs-radius-sm);
	box-shadow: 0 1px 2px rgba(16, 24, 40, .08);
	transition: transform .12s ease, background .15s ease, box-shadow .15s ease;
	cursor: pointer;
}

.yith-ywraq-add-to-quote a:hover,
a.add_to_quote_button:hover,
.yith-ywraq-add-button a:hover {
	background: var(--fysi-qs-accent-hover);
	border-color: var(--fysi-qs-accent-hover);
	color: var(--fysi-qs-accent-text);
	transform: translateY(-1px);
	box-shadow: 0 6px 16px -6px rgba(16, 24, 40, .35);
}

.yith-ywraq-add-to-quote a:active,
a.add_to_quote_button:active {
	transform: translateY(0);
}

/* Ícone opcional antes do texto do botão (carrinho/orçamento) */
.yith-ywraq-add-to-quote a::before {
	content: "";
	display: inline-block;
	width: 17px;
	height: 17px;
	background-color: currentColor;
	-webkit-mask: center / contain no-repeat url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/><path d='M14 2v6h6'/><path d='M9 13h6M9 17h4'/></svg>");
	mask: center / contain no-repeat url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/><path d='M14 2v6h6'/><path d='M9 13h6M9 17h4'/></svg>");
}

/* Mensagem "já está na lista" + link para ver a lista */
.yith_ywraq_add_item_response_message {
	margin-top: 8px;
	font-size: .9rem;
	color: var(--fysi-qs-text-muted);
}

.yith_ywraq_add_item_browse_message a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 6px;
	font-size: .92rem !important;
	font-weight: 600;
	color: var(--fysi-qs-accent);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color .15s ease;
}

.yith_ywraq_add_item_browse_message a:hover {
	border-bottom-color: currentColor;
}

.ajax-loading {
	margin-left: 6px;
}

/* --------------------------------------------------------------------------
   2. Página da lista / carrinho de orçamento
   -------------------------------------------------------------------------- */

.woocommerce .ywraq-wrapper,
.ywraq-wrapper {
	max-width: 1180px;
	margin: 0 auto;
	color: var(--fysi-qs-text);
}

/* Layout lado a lado (modo "wide" do YITH) vira grid responsivo */
.ywraq-form-table-wrapper.wide {
	display: grid !important;
	grid-template-columns: 1.5fr 1fr;
	gap: 32px;
	align-items: start !important;
}

.ywraq-form-table-wrapper.wide .yith-ywraq-mail-form-wrapper,
.ywraq-form-table-wrapper.wide form#yith-ywraq-form {
	flex-basis: auto !important;
	margin-left: 0 !important;
}

/* Tabela de itens vira "card" limpo */
#yith-ywrq-table-list.shop_table,
table#yith-ywrq-table-list {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid var(--fysi-qs-border);
	border-radius: var(--fysi-qs-radius);
	overflow: hidden;
	background: var(--fysi-qs-surface);
	box-shadow: var(--fysi-qs-card-shadow);
	margin: 0;
}

#yith-ywrq-table-list thead th {
	background: var(--fysi-qs-surface-muted);
	color: var(--fysi-qs-text-muted);
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	text-align: left;
	padding: 14px 16px;
	border: 0;
	border-bottom: 1px solid var(--fysi-qs-border);
}

#yith-ywrq-table-list tbody td {
	padding: 16px;
	border: 0;
	border-bottom: 1px solid var(--fysi-qs-border);
	vertical-align: middle;
	background: transparent;
}

#yith-ywrq-table-list tbody tr.cart_item:last-child td {
	border-bottom: 0;
}

#yith-ywrq-table-list tbody tr.cart_item {
	transition: background .15s ease;
}

#yith-ywrq-table-list tbody tr.cart_item:hover {
	background: var(--fysi-qs-surface-muted);
}

/* Miniatura do produto */
#yith-ywrq-table-list td.product-thumbnail {
	width: 84px;
}

#yith-ywrq-table-list td.product-thumbnail img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: var(--fysi-qs-radius-sm);
	border: 1px solid var(--fysi-qs-border);
	display: block;
}

/* Nome do produto */
#yith-ywrq-table-list td.product-name a {
	font-weight: 600;
	color: var(--fysi-qs-text);
	text-decoration: none;
	font-size: 1rem;
}

#yith-ywrq-table-list td.product-name a:hover {
	color: var(--fysi-qs-accent);
}

/* Botão remover (x) vira chip redondo */
#yith-ywrq-table-list td.product-remove {
	width: 44px;
}

.yith-ywraq-item-remove.remove,
a.yith-ywraq-item-remove {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	font-size: 18px;
	line-height: 1;
	color: var(--fysi-qs-text-muted) !important;
	background: var(--fysi-qs-surface-muted);
	border: 1px solid var(--fysi-qs-border);
	border-radius: 50%;
	text-decoration: none;
	transition: all .15s ease;
}

.yith-ywraq-item-remove.remove:hover,
a.yith-ywraq-item-remove:hover {
	color: #fff !important;
	background: #ef4444;
	border-color: #ef4444;
}

/* Campo de quantidade */
#yith-ywrq-table-list .quantity input.qty,
.ywraq-wrapper .quantity input.qty {
	width: 72px;
	padding: 10px 8px;
	text-align: center;
	font-size: .95rem;
	color: var(--fysi-qs-text);
	background: var(--fysi-qs-surface);
	border: 1px solid var(--fysi-qs-border-strong);
	border-radius: var(--fysi-qs-radius-sm);
	transition: border-color .15s ease, box-shadow .15s ease;
}

#yith-ywrq-table-list .quantity input.qty:focus {
	outline: none;
	border-color: var(--fysi-qs-accent);
	box-shadow: 0 0 0 3px var(--fysi-qs-focus);
}

/* Linha de ações (Atualizar lista) */
#yith-ywrq-table-list td.actions {
	background: var(--fysi-qs-surface-muted);
	text-align: right;
	padding: 16px;
}

/* --------------------------------------------------------------------------
   3. Formulário "Enviar a solicitação"
   -------------------------------------------------------------------------- */

.yith-ywraq-mail-form-wrapper {
	background: var(--fysi-qs-surface);
	border: 1px solid var(--fysi-qs-border);
	border-radius: var(--fysi-qs-radius);
	box-shadow: var(--fysi-qs-card-shadow);
	padding: 28px !important;
}

.yith-ywraq-mail-form-wrapper h3 {
	margin: 0 0 4px;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--fysi-qs-text);
	letter-spacing: -.01em;
}

.yith-ywraq-mail-form-wrapper h3 + form::before,
.yith-ywraq-mail-form-wrapper h3 ~ form {
	display: block;
}

#yith-ywraq-mail-form .form-row {
	margin: 0 0 var(--fysi-qs-gap);
	padding: 0;
	display: block;
}

#yith-ywraq-mail-form label {
	display: block;
	margin-bottom: 6px;
	font-size: .85rem;
	font-weight: 600;
	color: var(--fysi-qs-text);
}

#yith-ywraq-mail-form .required {
	color: #ef4444;
	border: 0;
	text-decoration: none;
}

#yith-ywraq-mail-form input.input-text,
#yith-ywraq-mail-form textarea,
.ywraq-wrapper input.input-text,
.ywraq-wrapper textarea.input-text {
	width: 100%;
	box-sizing: border-box;
	padding: var(--fysi-qs-field-pad);
	font-size: .98rem;
	color: var(--fysi-qs-text);
	background: var(--fysi-qs-surface);
	border: 1px solid var(--fysi-qs-border-strong);
	border-radius: var(--fysi-qs-radius-sm);
	transition: border-color .15s ease, box-shadow .15s ease;
	-webkit-appearance: none;
	appearance: none;
}

#yith-ywraq-mail-form input.input-text::placeholder,
#yith-ywraq-mail-form textarea::placeholder {
	color: #98a2b3;
}

#yith-ywraq-mail-form input.input-text:focus,
#yith-ywraq-mail-form textarea:focus {
	outline: none;
	border-color: var(--fysi-qs-accent);
	box-shadow: 0 0 0 3px var(--fysi-qs-focus);
}

#yith-ywraq-mail-form textarea {
	min-height: 120px;
	resize: vertical;
}

/* Bloco de privacidade */
.ywraq-privacy-wrapper {
	margin-bottom: var(--fysi-qs-gap);
	padding: 14px 16px;
	background: var(--fysi-qs-surface-muted);
	border: 1px solid var(--fysi-qs-border);
	border-radius: var(--fysi-qs-radius-sm);
	font-size: .88rem;
	color: var(--fysi-qs-text-muted);
}

#rqa_privacy_row {
	display: flex !important;
	align-items: flex-start;
	gap: 10px;
}

#rqa_privacy_row label {
	display: inline !important;
	margin: 0 !important;
	padding: 0 !important;
	font-weight: 400;
	color: var(--fysi-qs-text-muted);
}

input#rqa_privacy {
	margin-top: 2px;
	width: 18px;
	height: 18px;
	accent-color: var(--fysi-qs-accent);
}

/* --------------------------------------------------------------------------
   4. Botões "submit" do formulário e da lista (Enviar / Atualizar)
   -------------------------------------------------------------------------- */

.ywraq-wrapper input.button,
#yith-ywraq-mail-form input.button,
#yith-ywraq-form input.button,
input.raq-send-request {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: auto;
	padding: 14px 26px;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.1;
	color: var(--fysi-qs-accent-text);
	background: var(--fysi-qs-accent);
	border: 1px solid var(--fysi-qs-accent);
	border-radius: var(--fysi-qs-radius-sm);
	box-shadow: 0 1px 2px rgba(16, 24, 40, .08);
	cursor: pointer;
	transition: transform .12s ease, background .15s ease, box-shadow .15s ease;
}

input.raq-send-request {
	width: 100%;
}

.ywraq-wrapper input.button:hover,
#yith-ywraq-mail-form input.button:hover,
#yith-ywraq-form input.button:hover,
input.raq-send-request:hover {
	background: var(--fysi-qs-accent-hover);
	border-color: var(--fysi-qs-accent-hover);
	color: var(--fysi-qs-accent-text);
	transform: translateY(-1px);
	box-shadow: 0 8px 20px -8px rgba(16, 24, 40, .4);
}

/* Botão "Atualizar lista" fica secundário (outline) */
input[name="update_raq"] {
	background: var(--fysi-qs-surface);
	color: var(--fysi-qs-text);
	border-color: var(--fysi-qs-border-strong);
	box-shadow: none;
}

input[name="update_raq"]:hover {
	background: var(--fysi-qs-surface-muted);
	color: var(--fysi-qs-text);
	border-color: var(--fysi-qs-border-strong);
	box-shadow: none;
}

/* --------------------------------------------------------------------------
   5. Mensagens / notices
   -------------------------------------------------------------------------- */

#yith-ywraq-message:not(:empty),
.ywraq-wrapper .woocommerce-message,
.ywraq-wrapper .woocommerce-info,
.ywraq-wrapper .woocommerce-error {
	border-radius: var(--fysi-qs-radius-sm);
	border: 1px solid var(--fysi-qs-border);
	padding: 14px 18px;
	margin-bottom: 20px;
	font-size: .95rem;
	background: var(--fysi-qs-surface-muted);
}

.ywraq-wrapper .woocommerce-message {
	border-left: 4px solid #16a34a;
}

.ywraq-wrapper .woocommerce-error {
	border-left: 4px solid #ef4444;
}

/* --------------------------------------------------------------------------
   6. Botão flutuante / widget "Ver lista de orçamento" (quando usado)
   -------------------------------------------------------------------------- */

.yith-ywraq-quote-list a,
a.yith-ywraq-show-table-list {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	font-weight: 600;
	color: var(--fysi-qs-accent-text);
	background: var(--fysi-qs-accent);
	border-radius: var(--fysi-qs-radius-sm);
	text-decoration: none;
}

/* Contador de itens (badge) */
.yith-ywraq-count,
.ywraq-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	font-size: .72rem;
	font-weight: 700;
	color: #fff;
	background: #ef4444;
	border-radius: 999px;
}

/* --------------------------------------------------------------------------
   7. Overrides "à prova de tema/YITH" (vencem CSS inline com !important)
   O YITH injeta um CSS inline com a cor do botão (!important) e o tema
   Hello Elementor + WooCommerce forçam radius/cor. Subimos a especificidade
   e usamos !important para garantir o visual do skin.
   -------------------------------------------------------------------------- */

.woocommerce .yith-ywraq-add-to-quote a.add-request-quote-button,
.woocommerce .yith-ywraq-add-button a.add-request-quote-button,
.yith-ywraq-add-to-quote a.add-request-quote-button,
.yith-ywraq-add-button a.add-request-quote-button,
.woocommerce a.add-request-quote-button.button {
	background: var(--fysi-qs-accent) !important;
	background-color: var(--fysi-qs-accent) !important;
	border: 1px solid var(--fysi-qs-accent) !important;
	color: var(--fysi-qs-accent-text) !important;
	border-radius: var(--fysi-qs-radius-sm) !important;
	padding: 12px 22px !important;
	box-shadow: 0 1px 2px rgba(16, 24, 40, .08) !important;
}

.woocommerce .yith-ywraq-add-to-quote a.add-request-quote-button:hover,
.yith-ywraq-add-to-quote a.add-request-quote-button:hover,
.woocommerce a.add-request-quote-button.button:hover {
	background: var(--fysi-qs-accent-hover) !important;
	background-color: var(--fysi-qs-accent-hover) !important;
	border-color: var(--fysi-qs-accent-hover) !important;
	color: var(--fysi-qs-accent-text) !important;
}

/* Botões "Enviar" e "Atualizar lista" também blindados */
.woocommerce .ywraq-wrapper input.button,
.woocommerce #yith-ywraq-mail-form input.button,
.woocommerce #yith-ywraq-form input.button,
.ywraq-wrapper input.raq-send-request {
	background: var(--fysi-qs-accent) !important;
	background-color: var(--fysi-qs-accent) !important;
	border: 1px solid var(--fysi-qs-accent) !important;
	color: var(--fysi-qs-accent-text) !important;
	border-radius: var(--fysi-qs-radius-sm) !important;
}

.woocommerce .ywraq-wrapper input[name="update_raq"] {
	background: var(--fysi-qs-surface) !important;
	background-color: var(--fysi-qs-surface) !important;
	border: 1px solid var(--fysi-qs-border-strong) !important;
	color: var(--fysi-qs-text) !important;
}

/* Carrinho do Elementor em modo catálogo: esconde o "R$ 0,00" sem sentido */
.fysi-qs-cart-quote .elementor-menu-cart__subtotal {
	display: none !important;
}

.fysi-qs-cart-quote .elementor-menu-cart__toggle_button {
	cursor: pointer;
}

/* --------------------------------------------------------------------------
   8. Responsivo
   -------------------------------------------------------------------------- */

@media (max-width: 980px) {
	.ywraq-form-table-wrapper.wide {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

@media (max-width: 768px) {
	/* Tabela responsiva: cada linha vira um card */
	#yith-ywrq-table-list,
	#yith-ywrq-table-list tbody,
	#yith-ywrq-table-list tr,
	#yith-ywrq-table-list td {
		display: block;
		width: 100%;
	}

	#yith-ywrq-table-list thead {
		display: none;
	}

	#yith-ywrq-table-list tbody tr.cart_item {
		position: relative;
		border: 1px solid var(--fysi-qs-border);
		border-radius: var(--fysi-qs-radius);
		padding: 14px 14px 14px 92px;
		margin-bottom: 14px;
		min-height: 92px;
	}

	#yith-ywrq-table-list tbody td {
		border: 0 !important;
		padding: 4px 0;
	}

	#yith-ywrq-table-list td.product-thumbnail {
		position: absolute;
		top: 14px;
		left: 14px;
		width: 64px;
	}

	#yith-ywrq-table-list td.product-remove {
		position: absolute;
		top: 14px;
		right: 14px;
		width: auto;
	}

	#yith-ywrq-table-list td.product-quantity::before {
		content: attr(data-title);
		display: block;
		font-size: .72rem;
		font-weight: 700;
		text-transform: uppercase;
		letter-spacing: .05em;
		color: var(--fysi-qs-text-muted);
		margin-bottom: 4px;
	}

	#yith-ywrq-table-list td.actions {
		border-radius: var(--fysi-qs-radius);
		text-align: center;
	}

	input.raq-send-request {
		width: 100%;
	}
}
