/* =========================================================
   Fidei LP Segmento A — Tainacan · Sustentação Especializada
   Design system · Light variant
   ========================================================= */

:root {
	--fsa-green:        #16a34a;
	--fsa-green-light:  #22c55e;
	--fsa-green-dim:    rgba(22, 163, 74, 0.08);
	--fsa-green-border: rgba(22, 163, 74, 0.2);
	--fsa-bg:           #f8faf8;
	--fsa-bg2:          #ffffff;
	--fsa-bg3:          #f1f5f1;
	--fsa-border:       rgba(0, 0, 0, 0.07);
	--fsa-text:         #0d1a0f;
	--fsa-text2:        #374151;
	--fsa-text3:        #6b7280;
	--fsa-red-dim:      rgba(220, 38, 38, 0.06);
	--fsa-red-border:   rgba(220, 38, 38, 0.18);
}

body.fsa-lp-body {
	font-family: 'Inter', sans-serif;
	background: var(--fsa-bg);
	color: var(--fsa-text);
	overflow-x: hidden;
	margin: 0; padding: 0;
}
body.fsa-lp-body::before {
	content: '';
	position: fixed; inset: 0;
	background-image:
		linear-gradient(rgba(22, 163, 74, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(22, 163, 74, 0.03) 1px, transparent 1px);
	background-size: 40px 40px;
	pointer-events: none; z-index: 0;
}
#fsa-lp-page { position: relative; z-index: 1; }

/* --- Utility --- */
.fsa-container    { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.fsa-container-sm { max-width: 700px;  margin: 0 auto; padding: 0 24px; }
.fsa-container-md { max-width: 900px;  margin: 0 auto; padding: 0 24px; }

/* --- NAV --- */
.fsa-nav {
	position: sticky; top: 0; z-index: 50;
	border-bottom: 1px solid var(--fsa-border);
	backdrop-filter: blur(16px);
	background: rgba(248, 250, 248, 0.85);
}
.fsa-nav-inner {
	display: flex; justify-content: space-between; align-items: center;
	padding: 16px 24px;
}
.fsa-logo { display: flex; align-items: center; gap: 10px; }
.fsa-logo-icon {
	width: 36px; height: 36px; background: #000; border-radius: 8px;
	display: flex; align-items: center; justify-content: center;
	font-weight: 700; font-size: 16px; color: #fff;
}
.fsa-logo-bracket { color: #22c55e; font-size: 12px; }
.fsa-site-name { font-size: 18px; font-weight: 700; color: var(--fsa-text); }
.fsa-site-name .fsa-accent { color: var(--fsa-green); }
.fsa-nav-cta {
	background: var(--fsa-green); color: #fff; font-weight: 700; font-size: 13px;
	padding: 9px 22px; border-radius: 999px; text-decoration: none;
	box-shadow: 0 2px 12px rgba(22, 163, 74, 0.25); transition: background .2s;
}
.fsa-nav-cta:hover { background: #15803d; color: #fff; }

/* --- HERO --- */
.fsa-hero {
	position: relative;
	padding: 88px 24px 104px;
	text-align: center;
	background: radial-gradient(ellipse 80% 55% at 50% 0%, rgba(22, 163, 74, 0.09) 0%, transparent 70%);
}
.fsa-hero__inner { max-width: 820px; margin: 0 auto; position: relative; z-index: 1; }
.fsa-scan-badge {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--fsa-green-dim); border: 1px solid var(--fsa-green-border);
	border-radius: 999px; padding: 6px 16px; margin-bottom: 28px;
	font-size: 11px; font-weight: 600; letter-spacing: .1em;
	text-transform: uppercase; color: var(--fsa-green);
}
.fsa-pulse-dot {
	width: 7px; height: 7px; border-radius: 50%; background: var(--fsa-green-light);
	animation: fsa-pulse 2s infinite; flex-shrink: 0; display: inline-block;
}
@keyframes fsa-pulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, .5); transform: scale(.95); }
	70%       { box-shadow: 0 0 0 8px rgba(34, 197, 94, 0); transform: scale(1); }
}
.fsa-hero__title {
	font-size: clamp(36px, 6vw, 68px); font-weight: 700; line-height: 1.08;
	margin: 0 0 24px; color: var(--fsa-text);
}
.fsa-hero__title-italic {
	font-family: 'DM Serif Display', serif; color: var(--fsa-green); font-style: italic;
}
.fsa-hero__subtitle {
	font-size: 18px; color: var(--fsa-text2);
	max-width: 580px; margin: 0 auto 18px; line-height: 1.75;
}
.fsa-hero__code {
	font-family: 'Fira Code', monospace; font-size: 12px;
	color: rgba(22, 163, 74, .65); margin-bottom: 40px; display: block;
}
.fsa-hero__cta {
	display: inline-block; background: var(--fsa-green); color: #fff;
	font-weight: 700; font-size: 16px; padding: 18px 40px; border-radius: 12px;
	text-decoration: none; box-shadow: 0 4px 24px rgba(22, 163, 74, 0.28);
	transition: background .2s;
}
.fsa-hero__cta:hover { background: #15803d; color: #fff; }
.fsa-hero__note { font-size: 12px; color: var(--fsa-text3); margin-top: 12px; }

/* --- SECTIONS --- */
.fsa-section     { padding: 80px 24px; }
.fsa-section-alt { padding: 80px 24px; background: var(--fsa-bg3); }
.fsa-eyebrow {
	font-family: 'Fira Code', monospace; font-size: 11px;
	color: rgba(22, 163, 74, .6); margin-bottom: 10px; display: block;
}
.fsa-h2     { font-size: clamp(26px, 4vw, 40px); font-weight: 700; margin: 0 0 12px; color: var(--fsa-text); line-height: 1.2; }
.fsa-h2-sm  { font-size: clamp(24px, 3.5vw, 36px); font-weight: 700; margin: 0 0 10px; color: var(--fsa-text); line-height: 1.2; }
.fsa-desc   { font-size: 15px; color: var(--fsa-text2); line-height: 1.75; margin: 0 0 48px; max-width: 560px; }
.fsa-desc-sm { font-size: 14px; color: var(--fsa-text2); line-height: 1.65; margin: 0 0 48px; }
.fsa-sep    { border: none; border-top: 1px solid var(--fsa-border); margin: 0; }

/* --- RISK CARDS --- */
.fsa-risk-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.fsa-risk-card {
	background: var(--fsa-red-dim); border: 1px solid var(--fsa-red-border);
	border-radius: 16px; padding: 28px;
	transition: border-color .25s, box-shadow .25s;
}
.fsa-risk-card:hover {
	border-color: rgba(220, 38, 38, .35);
	box-shadow: 0 4px 20px rgba(220, 38, 38, 0.08);
}
.fsa-risk-card__icon { font-size: 26px; margin-bottom: 12px; }
.fsa-risk-card__title { font-weight: 700; font-size: 15px; color: #b91c1c; margin: 0 0 8px; }
.fsa-risk-card__text  { font-size: 13px; color: var(--fsa-text2); line-height: 1.65; margin: 0; }

/* --- FEATURE CARDS (diferenciais) --- */
.fsa-features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.fsa-feature-card {
	background: var(--fsa-bg2); border: 1px solid var(--fsa-border);
	border-radius: 24px; padding: 32px;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
	transition: border-color .25s, transform .25s, box-shadow .25s;
}
.fsa-feature-card:hover {
	border-color: var(--fsa-green-border);
	transform: translateY(-4px);
	box-shadow: 0 8px 32px rgba(22, 163, 74, 0.1);
}
.fsa-icon-box {
	width: 44px; height: 44px; border-radius: 12px;
	background: var(--fsa-green-dim); border: 1px solid var(--fsa-green-border);
	display: flex; align-items: center; justify-content: center;
	color: var(--fsa-green); flex-shrink: 0; margin-bottom: 20px;
}
.fsa-icon-box svg { width: 20px; height: 20px; }
.fsa-feature-card__title { font-size: 17px; font-weight: 700; margin: 0 0 10px; color: var(--fsa-text); }
.fsa-feature-card__text  { font-size: 13px; color: var(--fsa-text2); line-height: 1.65; margin: 0; }

/* --- STATS (números) --- */
.fsa-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 32px; }
.fsa-stat-val { font-size: 42px; font-weight: 700; color: var(--fsa-green); line-height: 1; font-family: 'DM Serif Display', serif; }
.fsa-stat-lbl { font-size: 12px; color: var(--fsa-text3); margin-top: 6px; text-transform: uppercase; letter-spacing: .07em; }
.fsa-stats-footnote { margin-top: 36px; font-size: 13px; color: var(--fsa-text3); text-align: center; }

/* --- TIMELINE (como funciona) --- */
.fsa-steps { position: relative; padding-left: 60px; display: flex; flex-direction: column; gap: 36px; }
.fsa-step-item { display: flex; gap: 20px; align-items: flex-start; position: relative; }
.fsa-step-dot {
	position: absolute; left: -60px; top: 0;
	width: 38px; height: 38px; border-radius: 50%;
	background: var(--fsa-green-dim); border: 1.5px solid var(--fsa-green-border);
	display: flex; align-items: center; justify-content: center;
	color: var(--fsa-green); font-size: 14px; font-weight: 700;
	font-family: 'Fira Code', monospace;
}
.fsa-steps::before {
	content: '';
	position: absolute; left: 19px; top: 48px; bottom: 0;
	width: 1px;
	background: linear-gradient(to bottom, var(--fsa-green-light), transparent);
}
.fsa-step-title { font-size: 15px; font-weight: 700; margin: 0 0 6px; color: var(--fsa-text); }
.fsa-step-text  { font-size: 13px; color: var(--fsa-text2); line-height: 1.6; margin: 0; }

/* --- CONTACT FORM --- */
.fsa-form-header { text-align: center; margin-bottom: 40px; }
.fsa-form-card {
	background: var(--fsa-bg2); border: 1px solid var(--fsa-border);
	border-radius: 28px; padding: 36px;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
}
.fsa-form { display: flex; flex-direction: column; gap: 16px; }
.fsa-form-group label {
	font-size: 12px; color: var(--fsa-text3); display: block; margin-bottom: 6px;
	letter-spacing: .05em; text-transform: uppercase; font-weight: 600;
}
.fsa-field {
	background: var(--fsa-bg3); border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 12px; padding: 14px 16px;
	color: var(--fsa-text); font-family: 'Inter', sans-serif;
	font-size: 14px; width: 100%; outline: none;
	transition: border-color .2s, box-shadow .2s; box-sizing: border-box;
}
.fsa-field:focus { border-color: var(--fsa-green); box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.12); }
.fsa-field::placeholder { color: var(--fsa-text3); }
.fsa-btn-primary {
	background: var(--fsa-green); color: #fff; font-weight: 700; font-size: 15px;
	padding: 16px 32px; border-radius: 12px; border: none; cursor: pointer; width: 100%;
	transition: background .2s, transform .15s, box-shadow .2s;
	font-family: 'Inter', sans-serif; box-shadow: 0 4px 20px rgba(22, 163, 74, 0.25);
}
.fsa-btn-primary:hover { background: #15803d; transform: scale(1.01); box-shadow: 0 6px 28px rgba(22, 163, 74, 0.35); }
.fsa-form-note { font-size: 11px; color: var(--fsa-text3); text-align: center; margin-top: 10px; }
.fsa-form-links {
	margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--fsa-border);
	display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap;
}
.fsa-form-links span { font-size: 12px; color: var(--fsa-text3); }
.fsa-form-links a { font-size: 13px; color: var(--fsa-green); text-decoration: none; font-weight: 600; }
.fsa-form-links a:hover { text-decoration: underline; }

/* --- FOOTER --- */
.fsa-footer { border-top: 1px solid var(--fsa-border); padding: 32px 24px; background: var(--fsa-bg2); }
.fsa-footer-inner {
	display: flex; flex-wrap: wrap; justify-content: space-between;
	align-items: center; gap: 16px;
}
.fsa-footer-logo { display: flex; align-items: center; gap: 10px; }
.fsa-footer-logo-icon {
	width: 30px; height: 30px; background: #000; border-radius: 6px;
	display: flex; align-items: center; justify-content: center;
	font-weight: 700; font-size: 13px; color: #fff;
}
.fsa-footer-site-name { font-size: 15px; font-weight: 700; color: var(--fsa-text); }
.fsa-footer-copy  { font-size: 12px; color: var(--fsa-text3); }
.fsa-footer-email { font-size: 12px; color: var(--fsa-green); text-decoration: none; }
.fsa-footer-email:hover { text-decoration: underline; }

/* --- REVEAL ANIMATION --- */
.fsa-reveal { opacity: 0; transform: translateY(20px); transition: opacity .65s, transform .65s; }
.fsa-reveal.fsa-visible { opacity: 1; transform: none; }

/* --- RESPONSIVE --- */
@media (max-width: 768px) {
	.fsa-hero  { padding: 48px 16px 64px; }
	.fsa-section, .fsa-section-alt { padding: 48px 16px; }
	.fsa-features-grid { grid-template-columns: 1fr; }
	.fsa-risk-grid { grid-template-columns: 1fr 1fr; }
	.fsa-stats-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
	.fsa-risk-grid { grid-template-columns: 1fr; }
	.fsa-stats-grid { grid-template-columns: 1fr 1fr; }
}

/* --- EDITOR --- */
.wp-block[data-type^="fidei/fsa-"] .components-placeholder { min-height: 80px; }
