/* =========================================================================
 * Formulários nativos - visual Carlos Sodré (Direção B · Editorial Humano)
 * Reaproveita os tokens do site.css (--navy, --sky, --red, --line, --disp…)
 * e espelha o estilo .field do design original: inputs arredondados, labels
 * em Archivo, foco azul com halo sky. O .dsf é transparente para se encaixar
 * dentro de qualquer cartão (ex.: .c-form, .news-letter, .join-form).
 * ========================================================================= */

.dsf{display:grid;gap:22px;width:100%}
.dsf-fields{display:grid;gap:18px}

.dsf-row{display:flex;flex-direction:column;gap:8px;min-width:0}
.dsf-split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dsf-split .dsf-row{gap:8px}

/* Labels - Archivo, igual a .field label */
.dsf-row label{font-family:var(--disp);font-weight:600;font-size:14px;color:var(--navy)}
.dsf-req{color:var(--red);margin-left:3px}

/* Campos - arredondados, igual a .field input */
.dsf-row input,
.dsf-row select,
.dsf-row textarea{
	font-family:var(--body);font-size:16px;padding:14px 16px;
	border:1.5px solid var(--line);border-radius:12px;background:#fff;
	color:var(--ink);transition:.2s;width:100%;-webkit-appearance:none;appearance:none
}
.dsf-row textarea{resize:vertical;min-height:130px;line-height:1.5}
.dsf-row input::placeholder,
.dsf-row textarea::placeholder{color:var(--muted)}

.dsf-row input:focus,
.dsf-row select:focus,
.dsf-row textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,143,213,.12)}

/* Select com seta custom em navy */
.dsf-row select{
	background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'><path fill='none' stroke='%230B2E63' stroke-width='1.6' d='M1 1.5 6 6.5 11 1.5'/></svg>");
	background-repeat:no-repeat;background-position:right 16px center;background-size:12px;
	padding-right:40px;cursor:pointer
}

/* Erro por campo */
.dsf-row.dsf-invalid input,
.dsf-row.dsf-invalid select,
.dsf-row.dsf-invalid textarea{border-color:var(--red);box-shadow:0 0 0 3px rgba(226,20,42,.1)}
.dsf-error{font-family:var(--disp);font-weight:600;font-size:12px;color:var(--red);display:none}
.dsf-row.dsf-invalid .dsf-error{display:block}

/* Consentimento (LGPD) */
.dsf-consent{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;font-size:14px;color:var(--muted);line-height:1.55;padding-top:4px}
.dsf-consent input[type="checkbox"]{width:18px;height:18px;accent-color:var(--blue);margin-top:3px;border-radius:0}
.dsf-consent a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}

/* Honeypot - fora da tela */
.dsf-hp{position:absolute !important;left:-9999px !important;top:auto;width:1px;height:1px;overflow:hidden}

/* Ações + botão (estilo .btn-red .btn-lg) */
.dsf-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:4px}
.dsf-submit{
	position:relative;display:inline-flex;align-items:center;gap:8px;
	background:var(--red);color:#fff;border:none;border-radius:40px;
	padding:16px 32px;font-family:var(--disp);font-weight:700;font-size:16px;
	letter-spacing:.01em;cursor:pointer;transition:.2s
}
.dsf-submit:hover{background:#bd1023;transform:translateY(-1px)}
.dsf-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}
.dsf-submit-arrow{margin-left:2px}

/* Spinner */
.dsf-spinner{display:none;width:15px;height:15px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:dsf-spin .7s linear infinite}
.dsf.is-sending .dsf-spinner{display:inline-block}
.dsf.is-sending .dsf-submit-arrow{display:none}
@keyframes dsf-spin{to{transform:rotate(360deg)}}

.dsf-note{font-family:var(--disp);font-weight:600;font-size:13px;color:var(--muted)}

/* Feedback global */
.dsf-feedback{font-family:var(--body);font-size:14.5px;line-height:1.5;display:none}
.dsf-feedback.is-error{display:block;color:var(--red)}

/* Sucesso */
.dsf-success{background:var(--cream2);border:1px solid var(--line);border-left:4px solid var(--sky);border-radius:0 16px 16px 0;padding:34px 36px;animation:dsf-fade-up .5s ease both}
.dsf-success-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--disp);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#1f9d57}
.dsf-success-badge .dsf-dot{font-size:9px}
.dsf-success h3{font-family:var(--disp);font-weight:800;font-size:26px;color:var(--navy);letter-spacing:-.01em;margin:12px 0 0;line-height:1.1}
.dsf-success p{margin-top:12px;color:#41506a;line-height:1.6;font-size:16px}
@keyframes dsf-fade-up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* reCAPTCHA */
.dsf-recaptcha{margin-top:8px;display:flex;flex-direction:column;align-items:flex-start}
.dsf-recaptcha-box{display:inline-block}
.dsf-recaptcha .dsf-error{margin-top:6px}
.dsf-recaptcha.dsf-invalid .dsf-error{display:block}

@media (prefers-reduced-motion: reduce){
	.dsf-spinner{animation:none}
	.dsf-success{animation:none}
}

@media (max-width:720px){
	.dsf-split{grid-template-columns:1fr;gap:18px}
}
