/**
 * ZUKI Propostas — Estilos do formulário público.
 *
 * Identidade visual:
 *   Azul ZUKI:  #3030C8 (primária)
 *   Texto:      #464646
 *   Cinza:      #EEEEEE
 *   Laranja:    #FF8719 (acento)
 *   Fonte:      Poppins (títulos e corpo)
 *
 * Todas as classes têm prefixo .zuki- para evitar conflito com Elementor / tema.
 */

:root {
	--zuki-primary: #3030c8;
	--zuki-primary-dark: #25259a;
	--zuki-primary-hover: #2828b0;
	--zuki-accent: #ff8719;
	--zuki-text: #464646;
	--zuki-text-light: #6b6b6b;
	--zuki-gray-light: #eeeeee;
	--zuki-gray-border: #d9d9d9;
	--zuki-white: #ffffff;
	--zuki-error: #d63638;
	--zuki-success: #00a32a;

	--zuki-radius: 8px;
	--zuki-radius-lg: 12px;
	--zuki-shadow: 0 4px 20px rgba(48, 48, 200, 0.08);

	--zuki-font-heading: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--zuki-font-body: 'Poppins', Arial, sans-serif;

	--zuki-transition: 0.2s ease-in-out;
}

/* =========================================================
   Wrapper e card
   ========================================================= */

.zuki-form-wrapper {
	font-family: var(--zuki-font-body);
	color: var(--zuki-text);
	width: 100%;
	margin: 0 auto;
	padding: 16px;
	box-sizing: border-box;
}

/* =========================================================
   Tipografia — força fonte em TODO o conteúdo do plugin.
   Necessário porque temas/Elementor frequentemente impõem
   font-family com alta especificidade (Barlow, Montserrat, etc.).
   ========================================================= */

.zuki-form-wrapper,
.zuki-form-wrapper *:not(svg):not(path):not(circle):not(polyline) {
	font-family: var(--zuki-font-body) !important;
}

/* Reaplica fonte de heading nos elementos visuais de destaque. */
.zuki-form-wrapper .zuki-form-title,
.zuki-form-wrapper .zuki-result-title,
.zuki-form-wrapper .zuki-result-section-title,
.zuki-form-wrapper .zuki-result-price-value,
.zuki-form-wrapper .zuki-button,
.zuki-form-wrapper .zuki-button * {
	font-family: var(--zuki-font-heading) !important;
}

.zuki-form-wrapper *,
.zuki-form-wrapper *::before,
.zuki-form-wrapper *::after {
	box-sizing: border-box;
}

.zuki-form-card {
	position: relative;
	background: var(--zuki-white);
	border-radius: 14px;
	box-shadow: 0 10px 40px rgba(48, 48, 200, 0.10), 0 2px 6px rgba(48, 48, 200, 0.04);
	padding: 36px;
	border: 1px solid #ECEEF2;
	overflow: hidden;
}

/* Barra superior gradiente azul→laranja: assina visualmente o card. */
.zuki-form-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--zuki-primary) 0%, var(--zuki-primary) 65%, var(--zuki-accent) 100%);
}

/* =========================================================
   Header
   ========================================================= */

.zuki-form-header {
	text-align: left;
	margin-bottom: 24px;
}

.zuki-form-title {
	font-family: var(--zuki-font-heading) !important;
	font-size: 28px !important;
	font-weight: 700 !important;
	color: var(--zuki-primary) !important;
	margin: 0 0 6px !important;
	line-height: 1.2 !important;
	letter-spacing: -0.3px;
}

.zuki-form-subtitle {
	font-size: 14px !important;
	color: var(--zuki-text-light) !important;
	margin: 0 !important;
	line-height: 1.5 !important;
}

/* =========================================================
   Layout do formulário — grid 2 colunas
   ========================================================= */

.zuki-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px 18px;
}

/* Campos que precisam ocupar a linha toda do grid. */
.zuki-field-full,
.zuki-field-consent,
.zuki-field-submit,
.zuki-feedback,
.zuki-trust-footer,
.zuki-info-note {
	grid-column: 1 / -1;
}

/* Nota informativa — alinha expectativa sobre fluxo consultivo */
.zuki-info-note {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 14px;
	background: rgba(48, 48, 200, 0.05);
	border-left: 3px solid var(--zuki-primary);
	border-radius: 6px;
	margin: 0;
}

.zuki-info-note svg {
	color: var(--zuki-primary);
	flex-shrink: 0;
	margin-top: 2px;
}

.zuki-info-note p {
	margin: 0 !important;
	font-size: 12px !important;
	color: var(--zuki-text-light) !important;
	line-height: 1.5 !important;
}

/* Honeypot fica fora do flow — não conta como célula do grid. */
.zuki-honeypot {
	grid-column: 1 / -1;
}

/* =========================================================
   Campos
   ========================================================= */

.zuki-field {
	margin-bottom: 0;
}

.zuki-label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--zuki-text);
	margin-bottom: 7px;
	letter-spacing: 0.1px;
}

.zuki-required {
	color: var(--zuki-accent);
	margin-left: 2px;
	font-weight: 700;
}

.zuki-input {
	width: 100% !important;
	padding: 13px 14px !important;
	font-size: 15px !important;
	font-family: var(--zuki-font-body) !important;
	color: var(--zuki-text) !important;
	background-color: #FAFBFC !important;
	background-image: none !important;
	border: 1.5px solid #D5D9DF !important;
	border-radius: var(--zuki-radius) !important;
	transition: border-color var(--zuki-transition), box-shadow var(--zuki-transition), background var(--zuki-transition);
	-webkit-appearance: none !important;
	appearance: none !important;
	box-shadow: none !important;
}

.zuki-input::placeholder {
	color: #9CA3AF;
}

.zuki-input:hover:not(:focus) {
	border-color: #B5BBC4;
}

.zuki-input:focus {
	outline: none;
	border-color: var(--zuki-primary);
	background: var(--zuki-white);
	box-shadow: 0 0 0 4px rgba(48, 48, 200, 0.12);
}

.zuki-input.zuki-input-error {
	border-color: var(--zuki-error);
}

.zuki-input.zuki-input-error:focus {
	box-shadow: 0 0 0 3px rgba(214, 54, 56, 0.15);
}

/* Remove spinners do input number */
.zuki-input[type='number']::-webkit-outer-spin-button,
.zuki-input[type='number']::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
.zuki-input[type='number'] {
	-moz-appearance: textfield;
}

/* =========================================================
   Mensagens de erro
   ========================================================= */

.zuki-error {
	display: block;
	min-height: 18px;
	font-size: 13px;
	color: var(--zuki-error);
	margin-top: 4px;
	line-height: 1.4;
}

.zuki-error:empty {
	display: none;
}

/* =========================================================
   Honeypot — invisível para usuário, visível para bots
   ========================================================= */

.zuki-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
}

/* =========================================================
   Consentimento LGPD
   ========================================================= */

.zuki-field-consent {
	margin-top: 4px;
	padding: 14px;
	background: var(--zuki-gray-light);
	border-radius: var(--zuki-radius);
}

.zuki-consent-label,
.zuki-consent-label span,
.zuki-consent-label a {
	font-size: 12px !important;
	line-height: 1.45 !important;
	font-family: var(--zuki-font-body) !important;
	font-weight: 400 !important;
}

.zuki-consent-label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--zuki-text-light);
	cursor: pointer;
	margin: 0 !important;
}

.zuki-consent-label input[type='checkbox'] {
	margin-top: 2px;
	width: 16px;
	height: 16px;
	accent-color: var(--zuki-primary);
	flex-shrink: 0;
	cursor: pointer;
}

.zuki-consent-label a {
	color: var(--zuki-primary);
	text-decoration: underline;
}

.zuki-consent-label a:hover {
	color: var(--zuki-primary-dark);
}

/* =========================================================
   Botão
   ========================================================= */

.zuki-field-submit {
	margin-top: 8px;
}

.zuki-button {
	position: relative;
	display: block;
	width: 100%;
	padding: 14px 20px;
	font-size: 16px;
	font-weight: 600;
	font-family: var(--zuki-font-heading);
	color: var(--zuki-white);
	background: var(--zuki-primary);
	border: none;
	border-radius: var(--zuki-radius);
	cursor: pointer;
	transition: background var(--zuki-transition), transform var(--zuki-transition);
	letter-spacing: 0.3px;
	text-decoration: none;
}

/* Força TODA a estética do botão (overcomes theme/Elementor overrides).
   - Gradiente azul ZUKI sólido (não pill, cantos 8px)
   - Texto branco em todos os estados de link
   - Shadow azul colorida para sensação de "elevação premium" */
.zuki-button,
.zuki-button:link,
.zuki-button:visited,
.zuki-button:hover,
.zuki-button:focus,
.zuki-button:active {
	color: var(--zuki-white) !important;
	background: linear-gradient(135deg, var(--zuki-primary) 0%, var(--zuki-primary-dark) 100%) !important;
	background-color: var(--zuki-primary) !important;
	border: none !important;
	border-radius: var(--zuki-radius) !important;
	text-decoration: none !important;
	text-transform: none !important;
	font-family: var(--zuki-font-heading) !important;
	font-weight: 600 !important;
	letter-spacing: 0.3px !important;
	box-shadow: 0 4px 14px rgba(48, 48, 200, 0.28) !important;
}

.zuki-button:hover:not(:disabled) {
	background: linear-gradient(135deg, var(--zuki-primary-hover) 0%, var(--zuki-primary-dark) 100%) !important;
	background-color: var(--zuki-primary-hover) !important;
	transform: translateY(-1px);
	box-shadow: 0 6px 18px rgba(48, 48, 200, 0.36) !important;
}

.zuki-button:active:not(:disabled) {
	transform: translateY(0);
}

.zuki-button:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.zuki-button-loader {
	display: none;
	width: 18px;
	height: 18px;
	border: 2.5px solid rgba(255, 255, 255, 0.35);
	border-top-color: var(--zuki-white);
	border-radius: 50%;
	animation: zuki-spin 0.7s linear infinite;
	margin-left: 8px;
	vertical-align: middle;
}

.zuki-button.is-loading .zuki-button-loader {
	display: inline-block;
}

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

/* =========================================================
   Feedback global (sucesso / erro de envio)
   ========================================================= */

.zuki-feedback {
	margin-top: 16px;
	padding: 0;
	font-size: 14px;
	line-height: 1.5;
}

.zuki-feedback:not(:empty) {
	padding: 12px 16px;
	border-radius: var(--zuki-radius);
}

.zuki-feedback.is-error {
	background: rgba(214, 54, 56, 0.08);
	color: var(--zuki-error);
	border-left: 3px solid var(--zuki-error);
}

.zuki-feedback.is-success {
	background: rgba(0, 163, 42, 0.08);
	color: var(--zuki-success);
	border-left: 3px solid var(--zuki-success);
}

/* =========================================================
   Telas de Resultado (auto x consultivo) — Etapa 3
   ========================================================= */

.zuki-result-card {
	padding: 32px;
}

/* Header */

.zuki-result-header {
	text-align: center;
	margin-bottom: 28px;
}

.zuki-result-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	border-radius: 999px;
	margin-bottom: 14px;
}

.zuki-result-badge-success {
	background: rgba(0, 163, 42, 0.1);
	color: var(--zuki-success);
}

.zuki-result-badge-info {
	background: rgba(48, 48, 200, 0.1);
	color: var(--zuki-primary);
}

.zuki-result-title {
	font-family: var(--zuki-font-heading);
	font-size: 26px;
	font-weight: 600;
	color: var(--zuki-text);
	margin: 0 0 8px;
	line-height: 1.2;
}

.zuki-result-code {
	font-size: 13px;
	color: var(--zuki-text-light);
	margin: 0;
}

.zuki-result-code strong {
	color: var(--zuki-text);
	font-weight: 600;
	letter-spacing: 0.5px;
}

.zuki-result-message {
	font-size: 15px;
	color: var(--zuki-text-light);
	line-height: 1.55;
	margin: 4px 0 0;
}

/* Seções */

.zuki-result-section {
	padding: 18px 0;
	border-top: 1px solid var(--zuki-gray-light);
}

.zuki-result-section:first-of-type {
	border-top: 0;
	padding-top: 0;
}

.zuki-result-section-title {
	font-family: var(--zuki-font-heading);
	font-size: 14px;
	font-weight: 600;
	color: var(--zuki-primary) !important;
	text-transform: none;
	letter-spacing: normal;
	margin: 0 0 10px;
}

/* Lista chave/valor */

.zuki-result-list {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 8px 16px;
	margin: 0;
}

.zuki-result-list dt {
	font-size: 13px;
	color: var(--zuki-text-light);
	font-weight: 500;
}

.zuki-result-list dd {
	font-size: 14px;
	color: var(--zuki-text);
	margin: 0;
	word-break: break-word;
}

.zuki-result-muted {
	color: var(--zuki-text-light);
	font-weight: 400;
}

/* Caixa de preço (fluxo automático) */

.zuki-result-price {
	background: linear-gradient(135deg, var(--zuki-primary) 0%, var(--zuki-primary-dark) 100%);
	color: var(--zuki-white);
	border-radius: var(--zuki-radius);
	padding: 24px;
	text-align: center;
	margin: 20px 0 24px;
	border: 0;
}

.zuki-result-price-label {
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	margin: 0 0 6px;
	opacity: 0.85;
}

.zuki-result-price-value {
	font-family: var(--zuki-font-heading);
	font-size: 38px;
	font-weight: 700;
	margin: 0 0 8px;
	letter-spacing: -0.5px;
}

.zuki-result-price-meta {
	font-size: 12px;
	margin: 0;
	opacity: 0.85;
	line-height: 1.5;
}

/* Ações (botões) */

.zuki-result-actions {
	margin-top: 8px;
}

.zuki-result-actions-consultive {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.zuki-result-actions .zuki-button {
	margin-top: 0;
}

.zuki-result-actions-note {
	font-size: 12px;
	color: var(--zuki-text-light);
	text-align: center;
	margin: 10px 0 0;
}

.zuki-result-soon {
	font-style: italic;
}

/* Callout de confirmação (fluxo consultivo) */

.zuki-result-confirmation {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px 16px;
	background: rgba(0, 163, 42, 0.08);
	border-left: 3px solid var(--zuki-success);
	border-radius: var(--zuki-radius);
	margin: 16px 0 20px;
}

.zuki-result-confirmation svg {
	flex-shrink: 0;
	color: var(--zuki-success);
	margin-top: 1px;
}

.zuki-result-confirmation p {
	margin: 0;
	font-size: 14px;
	color: var(--zuki-text);
	line-height: 1.5;
}

.zuki-result-confirmation strong {
	color: var(--zuki-success);
}

/* Variação do botão — WhatsApp */

.zuki-button-whatsapp,
.zuki-button-whatsapp:link,
.zuki-button-whatsapp:visited,
.zuki-button-whatsapp:hover,
.zuki-button-whatsapp:focus,
.zuki-button-whatsapp:active {
	background-color: #25d366 !important;
	background-image: none !important;
	color: #ffffff !important;
	text-decoration: none !important;
	border-radius: var(--zuki-radius) !important;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.zuki-button-whatsapp:hover:not(:disabled) {
	background-color: #1ebe5a !important;
}

.zuki-button-whatsapp svg,
.zuki-button-whatsapp svg path {
	fill: #ffffff !important;
	color: #ffffff !important;
}

/* Botão secundário (e-mail) */

.zuki-button-secondary {
	background: var(--zuki-white);
	color: var(--zuki-primary);
	border: 1.5px solid var(--zuki-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.zuki-button-secondary:hover:not(:disabled) {
	background: var(--zuki-primary);
	color: var(--zuki-white);
	transform: translateY(-1px);
}

/* Footer do card */

.zuki-result-footer {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid var(--zuki-gray-light);
	text-align: center;
}

.zuki-result-footer p {
	font-size: 13px;
	color: var(--zuki-text-light);
	margin: 0;
	line-height: 1.5;
}

.zuki-result-footer a {
	color: var(--zuki-primary);
	font-weight: 600;
	text-decoration: none;
}

.zuki-result-footer a:hover {
	text-decoration: underline;
}

/* =========================================================
   Responsivo
   ========================================================= */

/* Trust footer — selos de confiança abaixo do botão */

.zuki-trust-footer {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	justify-content: center !important;
	align-items: center !important;
	gap: 22px !important;
	margin-top: 14px !important;
	padding-top: 12px !important;
	border-top: 1px solid var(--zuki-gray-light) !important;
}

.zuki-trust-item {
	display: inline-flex !important;
	align-items: center !important;
	gap: 6px !important;
	font-size: 12px !important;
	color: var(--zuki-text-light) !important;
	font-weight: 500 !important;
	white-space: nowrap;
}

.zuki-trust-item svg {
	color: var(--zuki-primary);
	flex-shrink: 0;
}

@media (max-width: 600px) {
	.zuki-form-card {
		padding: 24px 20px;
		border-radius: var(--zuki-radius);
	}

	.zuki-form-title {
		font-size: 22px;
	}

	.zuki-form-subtitle {
		font-size: 14px;
	}

	.zuki-input {
		font-size: 16px; /* evita zoom automático no iOS */
	}

	/* Tela de resultado em mobile */

	.zuki-result-card {
		padding: 24px 20px;
	}

	.zuki-result-title {
		font-size: 22px;
	}

	.zuki-result-list {
		grid-template-columns: 1fr;
		gap: 2px 0;
	}

	.zuki-result-list dt {
		font-size: 12px;
		margin-top: 8px;
	}

	.zuki-result-list dt:first-child {
		margin-top: 0;
	}

	.zuki-result-price {
		padding: 20px;
	}

	.zuki-result-price-value {
		font-size: 32px;
	}
}
